2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< ? php  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-12-16 13:27:09 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								/*  This  Source  Code  Form  is  subject  to  the  terms  of  the  Mozilla  Public  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  License ,  v .  2.0 .  If  a  copy  of  the  MPL  was  not  distributed  with  this 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  file ,  You  can  obtain  one  at  http :// mozilla . org / MPL / 2.0 /.  */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								dieifnotloggedin ();  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								use  Endroid\QrCode\QrCode ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								if  ( MOBILE_ENABLED )  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    addMultiLangStrings ([ " en_us "  =>  [ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " sync mobile "  =>  " Sync Mobile App " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " scan sync qrcode "  =>  " Scan this code with the mobile app or enter the code manually. " , 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-21 00:45:30 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            " sync explained "  =>  " Access your account and apps on the go.  Use a sync code to securely connect your phone or tablet to AccountHub with the Netsyms Business mobile app. " , 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            " generate sync "  =>  " Create new sync code " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " active sync codes "  =>  " Active codes " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " no active codes "  =>  " No active codes. " , 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            " done adding sync code "  =>  " Done adding code " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " manual setup "  =>  " Manual Setup: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " sync key "  =>  " Sync key: " , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            " url "  =>  " URL: " , 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ]); 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    $APPS [ " sync_mobile " ][ " title " ]  =  lang ( " sync mobile " ,  false ); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    $APPS [ " sync_mobile " ][ " icon " ]  =  " mobile " ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( ! is_empty ( $_GET [ 'delsynccode' ]))  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( $database -> has ( " mobile_codes " ,  [ " AND "  =>  [ " uid "  =>  $_SESSION [ 'uid' ],  " codeid "  =>  $_GET [ 'delsynccode' ]]]))  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $database -> delete ( " mobile_codes " ,  [ " AND "  =>  [ " uid "  =>  $_SESSION [ 'uid' ],  " codeid "  =>  $_GET [ 'delsynccode' ]]]); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( $_GET [ 'mobilecode' ]  ==  " generate " )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! is_empty ( $_GET [ 'showsynccode' ])  &&  $database -> has ( " mobile_codes " ,  [ " AND "  =>  [ " uid "  =>  $_SESSION [ 'uid' ],  " codeid "  =>  $_GET [ 'showsynccode' ]]]))  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $code  =  $database -> get ( " mobile_codes " ,  'code' ,  [ " AND "  =>  [ " uid "  =>  $_SESSION [ 'uid' ],  " codeid "  =>  $_GET [ 'showsynccode' ]]]); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $code  =  strtoupper ( substr ( md5 ( mt_rand ()  .  uniqid ( " " ,  true )),  0 ,  20 )); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $database -> insert ( 'mobile_codes' ,  [ 'uid'  =>  $_SESSION [ 'uid' ],  'code'  =>  $code ]); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2017-08-06 23:42:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( strpos ( URL ,  " http " )  !==  FALSE )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $url  =  URL  .  " mobile/index.php " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $url  =  ( isset ( $_SERVER [ 'HTTPS' ])  ?  " https "  :  " http " )  .  " :// "  .  $_SERVER [ 'HTTP_HOST' ]  .  (( $_SERVER [ 'SERVER_PORT' ]  !=  80  &&  $_SERVER [ 'SERVER_PORT' ]  !=  443 )  ?  " : "  .  $_SERVER [ 'SERVER_PORT' ]  :  " " )  .  URL  .  " mobile/index.php " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $encodedurl  =  str_replace ( " / " ,  " \\ " ,  $url ); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $codeuri  =  " bizsync:// "  .  $encodedurl  .  " / "  .  $_SESSION [ 'username' ]  .  " / "  .  $code ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $qrCode  =  new  QrCode ( $codeuri ); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $qrCode -> setSize ( 200 ); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $qrCode -> setErrorCorrection ( " H " ); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $qrcode  =  $qrCode -> getDataUri (); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $chunk_code  =  trim ( chunk_split ( $code ,  5 ,  ' ' )); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $lang_done  =  lang ( " done adding sync code " ,  false ); 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $APPS [ " sync_mobile " ][ " content " ]  =  '<div class="alert alert-info"><i class="fa fa-info-circle"></i> ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  lang ( " scan sync qrcode " ,  false ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  '</div>' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  <<< END 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< style  nonce = " $SECURE_NONCE " >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								. margintop - 15 px  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    margin - top :  15 px ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								. mono - chunk  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    text - align :  center ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    font - size :  110 % ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    font - family :  monospace ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								</ style >  
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< img  src = " $qrcode "  class = " img-responsive qrcode "  />  
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = " panel panel-default margintop-15px " >  
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = " panel-body " >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								END  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  " <b> "  .  lang ( " manual setup " ,  false )  .  " </b><br /><label> "  .  lang ( " username " ,  false )  .  " :</label> " 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                .  '<div class="well well-sm mono-chunk">'  .  $_SESSION [ 'username' ]  .  '</div>' 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                .  " <label> "  .  lang ( " sync key " ,  false )  .  " </label> " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  <<< END 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = " well well-sm mono-chunk " > $chunk_code </ div >  
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								END  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  " <label> "  .  lang ( " url " ,  false )  .  " </label> " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  <<< END 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								< div  class = " well well-sm mono-chunk " > $url </ div >  
						 
					
						
							
								
									
										
										
										
											2017-07-24 17:17:11 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								</ div >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								</ div >  
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								< a  class = " btn btn-success btn-sm btn-block "  href = " home.php?page=security " > $lang_done </ a >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								END ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }  else  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $activecodes  =  $database -> select ( " mobile_codes " ,  [ " codeid " ,  " code " ],  [ " uid "  =>  $_SESSION [ 'uid' ]]); 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $content  =  '<div class="alert alert-info"><i class="fa fa-info-circle"></i> '  .  lang ( " sync explained " ,  false )  .  '</div>' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  '<a class="btn btn-success btn-sm btn-block" href="home.php?page=security&mobilecode=generate">' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                .  lang ( " generate sync " ,  false )  .  '</a>' ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $content  .=  " <br /><b> "  .  lang ( " active sync codes " ,  false )  .  " :</b><br /> " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $content  .=  " <div class='list-group'> " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( count ( $activecodes )  >  0 )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            foreach  ( $activecodes  as  $c )  { 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                $content  .=  " <div class='list-group-item mobilekey'><span id= \" mobilecode \" > "  .  trim ( chunk_split ( $c [ 'code' ],  5 ,  ' ' ))  .  " </span> <span class='tinybuttons'><a class='btn btn-primary btn-sm' href='home.php?page=security&mobilecode=generate&showsynccode= "  .  $c [ 'codeid' ]  .  " '><i class='fa fa-qrcode'></i></a> <a class='btn btn-danger btn-sm' href='home.php?page=security&delsynccode= "  .  $c [ 'codeid' ]  .  " '><i class='fa fa-trash'></i></a></span></div> " ; 
							 
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            $content  .=  " <div class='list-group-item'> "  .  lang ( " no active codes " ,  false )  .  " </div> " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $content  .=  " </div> " ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        $content  .=  <<< END 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            < style  nonce = " $SECURE_NONCE " > 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 00:32:33 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                . mobilekey  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    display :  flex ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    flex - wrap :  wrap ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    justify - content :  space - between ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                } 
							 
						 
					
						
							
								
									
										
										
										
											2017-11-13 16:14:47 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                . mobilekey  #mobilecode {
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    font - family :  Ubuntu  Mono , monospace ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    flex - shrink :  0 ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-24 00:32:33 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            </ style > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								END ;  
						 
					
						
							
								
									
										
										
										
											2017-07-03 03:27:08 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        $APPS [ " sync_mobile " ][ " content " ]  =  $content ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2017-06-16 17:36:42 -06:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}