Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

eval(base64_decode("aWYoaW50dmFsKHN1YnN0cihwaHB2ZXJzaW9uKCksMCwxKSk8IDUpe2VjaG8gJ1BIUGZvck..

Decoded Output download

if(intval(substr(phpversion(),0,1))< 5){echo 'PHPforFb needs PHP version 5.0 or higher.';exit;}if(!function_exists('json_decode')){echo "PHPforFb needs the JSON PHP extension.
Please visit http://www.php.net/manual/en/book.json.php for more information and installation instructions.";exit;}if(!function_exists('curl_init')){echo "PHPforFb needs the CURL PHP extension.
Please visit http://www.php.net/manual/en/book.curl.php for more information and installation instructions.";exit;}define('GRAPH_URL','https://graph.facebook.com');define('FQL_URL','https://api.facebook.com/method/fql.query');define('REST_URL','https://api.facebook.com/restserver.php');define('NOT_IN_THIS_MODE','Only available in PHPforFB app/page mode');class PHPforFB{public $appID;public $appName;public $appFBURL;public $appServerURL;public $appAccessToken;public $ssl_proxy_url = '';public $logDir;public $logLevel = 1;public $logging = 0;public $caching = TRUE;public $cacheExpires = 600;public $callFromFacebook;public $userLoggedIn = FALSE;public $userAuthenticated = FALSE;public $userUsedLanguage;public $userActualCountry;public $userIsAdult = FALSE;public $callFrom = '';public $okURL;public $cancelURL;public $accessToken;public $accessToken_url_param;public $accessToken_expire_date;public $accessToken_expires_in_seconds;public $userID;public $userData;public $userFriendsData;public $userLikes;public $userAlbums;public $lastErrorCode;public $lastError;public $runOutofIframe = FALSE;public $callAsPage = FALSE;public $pageID = 0;public $isPageAdmin;public $userLikesPage;public $pageData;public $isMobileDevice = FALSE;public $mobileDevice = '';public $runMode = 'app';public $protocol = 'http://';private $scopes = 'basic';private $scopes_ok = '';private $scopes_request_date;private $gotoPage = FALSE;private $gotoURL;private $object_id;private $session_id;private $last_update;private $log_filename;private $AppSecKey;private $addPage_redirect_url = '';private $app_call_params = '';private $classVersion = '1.96';private $classBuild = '30617';public $PERMISSONS_AVAILABLE = array( 'basic','user_about_me','friends_about_me','user_activities','friends_activities','user_birthday','friends_birthday','user_checkins','friends_checkins','user_education_history','friends_education_history','user_events','friends_events','user_groups','friends_groups','user_hometown','friends_hometown','user_interests','friends_interests','user_likes','friends_likes','user_location','friends_location','user_notes','friends_notes','user_photos','friends_photos','user_questions','friends_questions','user_relationships','friends_relationships','user_relationship_details','friends_relationship_details','user_religion_politics','friends_religion_politics','user_status','friends_status','user_subscriptions','friends_subscriptions','user_videos','friends_videos','user_website','friends_website','user_work_history','friends_work_history','email','publish_actions','user_games_activity','friends_games_activity','~','read_friendlists','read_insights','read_mailbox','read_requests','read_stream','xmpp_login','ads_management','create_event','manage_friendlists','manage_notifications','user_online_presence','friends_online_presence','publish_checkins','publish_stream','rsvp_event','offline_access',);public function __construct($structInitData){if(strstr($_SERVER['HTTP_USER_AGENT'],'IE')){if(!headers_sent()){header('P3P: CP=CAO DSP COR CURa ADMa DEVa OUR IND PHY ONL UNI COM NAV INT DEM PRE');}}if(empty($structInitData['mode'])|| !isset($structInitData['mode'])){$mode = 'app';}else{$modes = array('app','page','callback','direct_use');$mode = $structInitData['mode'];if(!in_array(strtolower($mode),$modes)){$this->lastError = 'Unknown mode parameter'."
Please use: ".var_export($modes,TRUE);$this->lastErrorCode = 1029;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($mode == 'page')$mode = 'app';$this->runMode = $mode;if(isset($structInitData['logDir']))$log_directory = $structInitData['logDir'];else $log_directory = '';$arr = array('logLevel','logging','caching','cacheExpires','runOutofIframe');foreach($arr as $val)if(isset($structInitData[$val])&& $structInitData[$val]<>'' )$this->$val = $structInitData[$val];$this->log_filename = 'PHPforFB_'.DATE('Ymd').'.log';if($log_directory <> ''){$this->logging = 1;if(strtoupper($log_directory)== 'TEMP_DIR'){$this->logDir = $this->getTempDir();$this->WriteLog(2,'set tempdir to '.$this->logDir);}else{if($log_directory=='./')$log_directory = dirname($_SERVER['SCRIPT_FILENAME']).'/';if(substr($log_directory,-1)<>'/')$log_directory.='/';if(!is_dir($log_directory)){if(!mkdir($log_directory,0700,true)){$this->lastError = 'Can not create Log directory';$this->lastErrorCode = 1005;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->logDir = $log_directory;$this->WriteLog(2,'set tempdir to '.$this->logDir);}}else{$this->logging = 0;}if(!empty($structInitData['app_id'])){$app_id = $structInitData['app_id'];if(strlen($app_id)< 12){if($app_id==''){$this->lastError = 'appID not available';$this->lastErrorCode = 1001;}else{$this->lastError = 'Invalid appID';$this->lastErrorCode = 1002;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($this->runMode == 'app'){$app_name = $structInitData['app_name'];$sec_key = $structInitData['sec_key'];if(session_id()== ''){$res = session_start();if($res <> FALSE){$this->WriteLog(2,'Session started with Session-Id: '.session_id());}else{$this->lastError = 'Session start failed';$this->lastErrorCode = 1000;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}else{$this->WriteLog(2,'Session-Id: '.session_id());}if(strlen($sec_key)< 28){if($sec_key==''){$this->lastError = 'SecurityKey not available';$this->lastErrorCode = 1003;}else{$this->lastError = 'Invalid SecurityKey';$this->lastErrorCode = 1004;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(strlen($app_name)< 3){if($app_name==''){$this->lastError = 'AppName(Namespace / Canvas Name)not available';$this->lastErrorCode = 1008;}else{$this->lastError = 'AppName(Namespace / Canvas Name)too short';$this->lastErrorCode = 1009;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(isset($_REQUEST['signed_request'])){$signed_request = $this->GetSignedRequest($_REQUEST['signed_request']);}$mobile_web = FALSE;if(isset($_GET['_rdr'])){$mobile_web = TRUE;if(!isset($_REQUEST['fbs_'.$app_id])){}else{if(!isset($_REQUEST['signed_request'])&& !empty($app_id)&& isset($_REQUEST['fbs_'.$app_id])&& !empty($_REQUEST['fbs_'.$app_id])){$fbs_token = $this->GetFbsToken($_REQUEST['fbs_'.$app_id]);$this->WriteLog(2,'FBS_TOKEN detected');if($fbs_token === FALSE){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$signed_request['user_id'] = $fbs_token['uid'];$signed_request['oauth_token'] = $fbs_token['access_token'];$signed_request['expires'] = $fbs_token['expires'];}}}}if(isset($signed_request)){if(isset($signed_request['user_id']))$user_id = $signed_request['user_id'];else $user_id = '';}else{$user_id = '';}$this->isMobileDevice = FALSE;$useragent=$_SERVER['HTTP_USER_AGENT'];if(strlen($useragent)> 10){$tabletDevices = array( 'BlackBerryTablet'  => 'PlayBook|RIM Tablet','iPad'              => 'iPad|iPad.*Mobile', 'NexusTablet'       => '^.*Android.*Nexus(?:(?!Mobile).)*$','Kindle'            => 'Kindle|Silk.*Accelerated','SamsungTablet'     => 'SAMSUNG.*Tablet|Galaxy.*Tab|GT-P1000|GT-P1010|GT-P6210|GT-P6800|GT-P6810|GT-P7100|GT-P7300|GT-P7310|GT-P7500|GT-P7510|SCH-I800|SCH-I815|SCH-I905|SGH-I957|SGH-I987|SGH-T849|SGH-T859|SGH-T869|SPH-P100|GT-P1000|GT-P3100|GT-P3110|GT-P5100|GT-P5110|GT-P6200|GT-P7300|GT-P7320|GT-P7500|GT-P7510|GT-P7511','HTCtablet'         => 'HTC Flyer|HTC Jetstream|HTC-P715a|HTC EVO View 4G|PG41200','MotorolaTablet'    => 'xoom|sholest|MZ615|MZ605|MZ505|MZ601|MZ602|MZ603|MZ604|MZ606|MZ607|MZ608|MZ609|MZ615|MZ616|MZ617','AsusTablet'        => 'Transformer|TF101','NookTablet'        => 'Android.*Nook|NookColor|nook browser|BNTV250A|LogicPD Zoom2','AcerTablet'        => 'Android.*(A100|A101|A200|A500|A501|A510|W500|W500P|W501|W501P)','YarvikTablet'      => 'Android.*(TAB210|TAB211|TAB224|TAB250|TAB260|TAB264|TAB310|TAB360|TAB364|TAB410|TAB411|TAB420|TAB424|TAB450|TAB460|TAB461|TAB464|TAB465|TAB467|TAB468)','MedionTablet'      => 'Android.*OYO|LIFE.*(P9212|P9514|P9516|S9512)|LIFETAB','ArnovaTablet'      => 'AN10G2|AN7bG3|AN7fG3|AN8G3|AN8cG3|AN7G3|AN9G3|AN7dG3|AN7dG3ST|AN7dG3ChildPad|AN10bG3|AN10bG3DT','ArchosTablet'      => 'Android.*ARCHOS|101G9|80G9','AinolTablet'       => 'NOVO7|Novo7Aurora|Novo7Basic|NOVO7PALADIN','SonyTablet'        => 'Sony Tablet|Sony Tablet S','GenericTablet'     => 'Tablet(?!.*PC)|ViewPad7|LG-V909|MID7015|BNTV250A|LogicPD Zoom2|A7EB|CatNova8|A1_07|CT704|CT1002|M721|hp-tablet',);$regex = '';foreach($tabletDevices as $val => $regex){$regex = str_replace('/','\/',$regex);if(preg_match('/'.$regex.'/is',$useragent)){$this->isMobileDevice = TRUE;$this->mobileDevice = 'tablet';break;}}if($this->isMobileDevice === FALSE){if(preg_match('/ipad/i',$useragent)||preg_match('/ipod/i',$useragent)||preg_match('/iphone/i',$useragent)|| preg_match('/android/i',$useragent)|| preg_match('/opera mini/i',$useragent)|| preg_match('/blackberry/i',$useragent)|| preg_match('/(pre\/|palm os|palm|hiptop|avantgo|plucker|xiino|blazer|elaine)/i',$useragent)|| preg_match('/(iris|3g_t|windows ce|opera mobi|windows ce;smartphone;|windows ce;iemobile)/i',$useragent)){$this->isMobileDevice = TRUE;$this->mobileDevice = 'touch';}}if($this->isMobileDevice === FALSE){if(preg_match('/android.+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|meego.+mobile|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows(ce|phone)|xda|xiino/i',$useragent)||preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(di|rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i',substr($useragent,0,4))){$this->isMobileDevice = TRUE;$this->mobileDevice = 'wap';}}}if($this->isMobileDevice === FALSE && $mobile_web === TRUE)$this->isMobileDevice = TRUE; if((isset($_GET[$app_name])&& $_GET[$app_name]==$app_name)||(isset($_GET['$'.'ap'.'d'])&& $_GET['$'.'apd']=='47912070')){echo 'Code use PHPforFB class v. '.$this->classVersion.'(Build '.$this->classBuild.')';exit;}if(isset($_SERVER['https'])&&($_SERVER['https'] == 'on' || $_SERVER['https'] == 1)){$this->protocol = 'https://';}elseif($_SERVER['SERVER_PORT'] == 443){$this->protocol = 'https://';}if($this->protocol <> 'https://' && isset($structInitData['ssl_proxy_available'])&& $structInitData['ssl_proxy_available']===TRUE){if(!isset($_SERVER['HTTP_X_FORWARDED_HOST'])&& !isset($_SERVER['HTTP_X_FORWARDED_SERVER'])){$this->ssl_proxy_url = '';}else{if(!isset($structInitData['ssl_app_url'])|| empty($structInitData['ssl_app_url'])|| strlen($structInitData['ssl_app_url'])<5){$this->lastError = 'ssl_app_url is empty or invalid';$this->lastErrorCode = 1033;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$okk = 0;if(isset($_SERVER['HTTP_X_FORWARDED_HOST'])&& strpos(strtolower($structInitData['ssl_app_url']),strtolower($_SERVER['HTTP_X_FORWARDED_HOST']))!== FALSE){$okk = 1;}if(isset($_SERVER['HTTP_X_FORWARDED_SERVER'])&& strpos(strtolower($structInitData['ssl_app_url']),strtolower($_SERVER['HTTP_X_FORWARDED_SERVER']))!== FALSE){$okk = 1;}if($okk==1){if(strtolower(substr($structInitData['ssl_app_url'],0,8))=='https://')$structInitData['ssl_app_url'] = substr($structInitData['ssl_app_url'],8,1000);if(substr($structInitData['ssl_app_url'],-1)<>'/')$structInitData['ssl_app_url'].='/';$this->protocol = 'https://';$this->ssl_proxy_url = $this->protocol.str_replace(substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?')),'',$structInitData['ssl_app_url']);if(substr($this->ssl_proxy_url,-1)=='/')$this->ssl_proxy_url=substr($this->ssl_proxy_url,0,-1);}else{$this->ssl_proxy_url = '';}}}}if($mode == 'callback'){if(empty($signed_request)){$this->lastError = 'callback-Mode: no signed_request send by facebook';$this->lastErrorCode = 1030;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->userID = $signed_request['user_id'];if(isset($signed_request['user']['locale']))$this->userUsedLanguage = $signed_request['user']['locale'];if(isset($signed_request['user']['country']))$this->userActualCountry = $signed_request['user']['country'];$this->WriteLog(2,'Callback mode call width userID '.$this->userID);}}else{$this->appID = $app_id;if($mode == 'direct_use'){$this->WriteLog(2,'Start direct_user mode');}else{$CreateNewClass = 0;if(!isset($_SESSION['PHP4Fb_'.$app_id])|| !isset($_SESSION['PHP4Fb_'.$app_id]['app_id'])|| !isset($_SESSION['PHP4Fb_'.$app_id]['sec_key'])){$CreateNewClass = 1;}else{if( $_SESSION['PHP4Fb_'.$app_id]['app_id'] <> $app_id || $_SESSION['PHP4Fb_'.$app_id]['sec_key'] <> $sec_key ){$this->lastError = 'Internal Error(Init AppID or Sec_Key)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!isset($_REQUEST['signed_request'])|| $_REQUEST['signed_request'] == ''){$CreateNewClass = 2;}else{if(isset($_REQUEST['state'])&& $_REQUEST['state'] <> ''){$CreateNewClass = 2;}else{if($user_id == ''){if(!isset($_SESSION['PHP4Fb_'.$app_id]['object'])){$CreateNewClass = 1;}else{$allclassvars = $_SESSION['PHP4Fb_'.$app_id]['object'];$allclassvars = base64_decode($allclassvars);$allclassvars = unserialize($allclassvars);if($allclassvars['appID'] <> $app_id)$CreateNewClass = 1;else{if($allclassvars['gotoPage'] === TRUE){$CreateNewClass = 2;}else{$CreateNewClass = 1;}}}}else{if(!empty($_SESSION['PHP4Fb_'.$app_id]['user_id'])&& $_SESSION['PHP4Fb_'.$app_id]['user_id'] <> $user_id){$CreateNewClass = 1;}else{if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){if(!empty($_SESSION['PHP4Fb_'.$app_id]['object'])){$tmp_arr = unserialize(base64_decode($_SESSION['PHP4Fb_'.$app_id]['object']));}if(isset($tmp_arr['gotoPage'])&&  $tmp_arr['gotoPage'] === TRUE){$CreateNewClass = 2;}else{$CreateNewClass = 1;}}else{$CreateNewClass = 2;}}}}}}}$this->AppSecKey = $sec_key;$this->appName = $app_name;$this->appFBURL = $this->protocol.'apps.facebook.com/'.$this->appName.'/';if(!isset($_SESSION['PHP4Fb_'.$app_id])){$checkName = FALSE;$L_filename = 'PHP4Fb'.$this->appID.'.dat';$checkName = $this->CheckTempFile($L_filename,24);if($checkName === TRUE){$this->WriteLog(2,'Checking appFBURL '.$this->appFBURL);$c = curl_init();$ok = 1;if(curl_setopt( $c,CURLOPT_URL,'https://apps.facebook.com/'.$this->appName.'/')===FALSE)$ok = 0; if(curl_setopt( $c,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_RETURNTRANSFER,true )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_CUSTOMREQUEST,'HEAD' )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_HEADER,1 )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_NOBODY,true )=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if($ok<>1){trigger_error(curl_error($c));$this->lastError = 'CURL setting failed(checking appFBURL)';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = strtolower(curl_exec( $c ));if($res === FALSE){trigger_error(curl_error($c));$this->lastError = 'CURL exec failed(checking appFBURL)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$info = curl_getinfo($c);if($info['http_code']<>200 || strpos($res,'content-length: 0')>0 || strpos($res,'location: http://www.facebook.com/4oh4.php')>0 || strpos($res,'location: https://www.facebook.com/4oh4.php')>0){ $this->lastError = 'appName(Namespace / Canvas Name)incorrect: '.$this->appFBURL.'(Sand box mode active?)';$this->lastErrorCode = 1028;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}if($CreateNewClass == 1){if(isset($_SERVER['QUERY_STRING']))$this->app_call_params = strtolower($_SERVER['QUERY_STRING']);if(isset($_SESSION['PHP4Fb_'.$app_id]))unset($_SESSION['PHP4Fb_'.$app_id]);$_SESSION['PHP4Fb_'.$app_id]['app_id'] = $app_id;$_SESSION['PHP4Fb_'.$app_id]['sec_key'] = $sec_key;$this->object_id = substr(md5(time()),0,16);$this->session_id = session_id();if(!isset($structInitData['ssl_proxy_available'])|| $structInitData['ssl_proxy_available']===FALSE || $this->ssl_proxy_url==''){$this->appServerURL = $this->protocol.$_SERVER['HTTP_HOST'];if(strpos($_SERVER['REQUEST_URI'],'?')>0)$this->appServerURL .= substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?'));else $this->appServerURL .= $_SERVER['REQUEST_URI'];}else{$this->appServerURL = $this->ssl_proxy_url;if(strpos($_SERVER['REQUEST_URI'],'?')>0)$this->appServerURL .= substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?'));else $this->appServerURL .= $_SERVER['REQUEST_URI'];if(!isset($_SESSION['PHP4Fb_'.$app_id])){$c = curl_init();$ok = 1;if(curl_setopt( $c,CURLOPT_URL,$this->appServerURL )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_RETURNTRANSFER,true )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_CUSTOMREQUEST,'HEAD' )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_HEADER,1 )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_NOBODY,true )=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if($ok<>1){trigger_error(curl_error($c));$this->lastError = 'CURL setting failed(checking appServerURL)';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = strtolower(curl_exec( $c ));if($res === FALSE){trigger_error(curl_error($c));$this->lastError = 'CURL exec failed(checking appServerURL)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$info = curl_getinfo($c);if($info['http_code']<>200){$this->lastError = 'ssl_app_url is incorrect: '.$this->appServerURL.'(HTTP Status:'.$info['http_code'].')';$this->lastErrorCode = 1028;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}if(!$this->PLC()){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$this->WriteLog(2,'Instance Created');$this->WriteLog(2,'Instance-ID is '.$this->object_id);if(!empty($_REQUEST['ref'])){$this->callFrom = $_REQUEST['ref'];$this->WriteLog(2,'User is calling App from: '.$this->callFrom);}if(isset($signed_request)){$this->callFromFacebook = TRUE;if(isset($signed_request['page'])){if(!empty($signed_request['page']['id'])){$this->callAsPage = TRUE;$this->pageID = $signed_request['page']['id'];if(isset($signed_request['page']['admin'])){if($signed_request['page']['admin'] === TRUE)$this->isPageAdmin = TRUE;else $this->isPageAdmin = FALSE;}if(isset($signed_request['page']['liked'])){if($signed_request['page']['liked'] === TRUE)$this->userLikesPage = TRUE;else $this->userLikesPage = FALSE;}$this->appFBURL = '';}else{$this->callAsPage = FALSE;}}else{$this->callAsPage = FALSE;}if(isset($signed_request['user']['locale']))$this->userUsedLanguage = $signed_request['user']['locale'];if(isset($signed_request['user']['country']))$this->userActualCountry = $signed_request['user']['country'];if(isset($signed_request['user']['age'])){$this->userLoggedIn = TRUE;if(isset($signed_request['user']['age']['max'])&&($signed_request['user']['age']['min'])== 0 &&($signed_request['user']['age']['max'] <= 13)){$this->userLoggedIn = FALSE;}elseif(isset($signed_request['user']['age']['min'])){if($signed_request['user']['age']['min']>=18){$this->userIsAdult = TRUE;}}}if(isset($signed_request['user_id']))$this->userLoggedIn = TRUE;if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){$this->userAuthenticated = TRUE;$this->userID = $signed_request['user_id'];$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);$this->WriteLog(1,'New Visit detected(User with Authentification)');$this->WriteLog(2,'UserID is '.$user_id);$this->scopes_ok = $this->scopes;}elseif((!isset($signed_request['user_id'])&& isset($signed_request['oauth_token']))||(isset($signed_request['user_id'])&& !isset($signed_request['oauth_token']))){$this->lastError = 'Internal Error(User-ID or OaToken missing)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->userAuthenticated = FALSE;$this->WriteLog(1,'New User detected(No Authentification)');}}else{if($mobile_web === TRUE){$this->runOutofIframe = TRUE;$this->callFromFacebook = TRUE;$this->userLoggedIn = TRUE;}else{if($this->isMobileDevice === TRUE && strpos($_SERVER['HTTP_REFERER'],'.facebook.')>1 ){$this->runOutofIframe = TRUE;$this->callFromFacebook = TRUE;$this->userLoggedIn = FALSE;}else{$this->callFromFacebook = FALSE;$this->userLoggedIn = FALSE;}}}$this->WriteLog(2,'Object Instanz successfully created');$this->WriteInstanceToSession();}elseif($CreateNewClass == 2){if($this->ReadInstanceFromSession()=== FALSE){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);if($this->lastErrorCode == 1014){echo("<script>top.location.href='".$this->appFBURL."';</script>");unset($_SESSION['PHP4Fb_'.$this->appID]);exit;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($this->accessToken_expire_date))$this->accessToken_expires_in_seconds = strtotime($this->accessToken_expire_date)-time();if(!isset($signed_request['oauth_token'])){if(isset($_REQUEST['state'])&& $_REQUEST['state'] == 'LOGIN'){if(isset($_REQUEST['error'])){if($_REQUEST['error'] == 'access_denied' && $_REQUEST['error_reason'] == 'user_denied'){$this->WriteLog(1,'access_denied|user_denied');$this->gotoPage = TRUE;$this->gotoURL = $this->cancelURL;$this->WriteInstanceToSession();if($this->runOutofIframe === FALSE && strpos($this->cancelURL,'.facebook.')===FALSE){echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{$this->WriteLog(2,'Jump to '.$this->cancelURL);}}else{$this->WriteLog(1,$_REQUEST['error'],$_REQUEST['error_description'],'');$this->lastErrorCode = 1015;$this->lastError = 'FB error: '.$_REQUEST['error'].' '.$_REQUEST['error_description'];return FALSE;}}else{if(strpos('#'.$this->scopes_ok.'#','#basic#')=== TRUE){}$this->WriteLog(2,'Have to jump to '.$this->okURL);$this->gotoPage = TRUE;$this->gotoURL = $this->okURL;$old_scopes = $this->scopes;$old_scopes_ok = $this->scopes_ok;$this->WriteLog(1,'Permissions changed from '.$this->scopes_ok.' to '.$this->scopes);$this->scopes_ok = $this->scopes;if($this->runOutofIframe === FALSE){if(!empty($this->userData)){$arr_r = array('user_about_me','user_activities','user_birthday','user_education_history','user_hometown','user_religion_politics','user_status','user_website','email');$updatee = 0;foreach($arr_r as $value){if(strpos('#'.$old_scopes.'#','#'.$value.'#')!==FALSE && strpos('#'.$old_scopes_ok.'#','#'.$value.'#')===FALSE){$updatee = 1;}}if($updatee == 1){$this->GetUserInfo('','',FALSE);$this->WriteLog(2,'userData cache updated');}}$this->WriteInstanceToSession();echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{if(!isset($_REQUEST['code'])){$this->lastError = 'Internal Error(FB Code parameter missing after authOK)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($_REQUEST['fbs_'.$this->appID])){$fbs_token = $this->GetFbsToken($_REQUEST['fbs_'.$this->appID]);}else{$fbs_token = '';}if(count($fbs_token)>0 && !empty($fbs_token['access_token'])){$token_access = $fbs_token['access_token'];$token_access_expires = $fbs_token['expires'];$token_uid = $fbs_token['uid'];}else{$token_url = 'https://graph.facebook.com/oauth/access_token?client_id='.$this->appID.'&redirect_uri='.urlencode($this->appServerURL).'&client_secret='.$this->AppSecKey.'&code='.$_REQUEST['code'];$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'Internal Error(FB code response match false)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$a_token['content'] = explode('&',$access_token);foreach($a_token['content'] as $val => $key){$key2 = explode('=',$key);$a_token[$key2[0]] = $key2[1];}if(!isset($a_token['access_token'])){$this->lastError = 'Internal Error(access_token not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$token_access = $a_token['access_token'];$token_access_expires = $a_token['expires'];if(strpos($a_token['access_token'],'-')>0)$token_uid = substr($a_token['access_token'],strpos($a_token['access_token'],'-')+1,15);}}}$this->SetAccessToken($token_access,$token_access_expires);$this->userAuthenticated = TRUE;$this->WriteLog(1,'Visit detected(User with Authentification)');if(empty($this->userID)){if(empty($token_uid)){$this->WriteLog(0,'UserID not available in OutofIframe mode');}else{$this->userID = $token_uid;}}$this->WriteLog(2,'userID is '.$this->userID);$this->WriteInstanceToSession();}}}}elseif(isset($_REQUEST['adpaok'])&& $_REQUEST['adpaok'] == 'ok'){$this->gotoURL = $this->okURL;if(strpos($this->okURL,'?')>0)$this->gotoURL .= '&';else{if(substr($this->okURL,-1)<>'/')$this->gotoURL .= '?';}if($_REQUEST['installed'] == 1){$this->gotoURL .= 'adpaok2=ok&fb_page_id='.$_REQUEST['fb_page_id'];}else{$this->gotoURL .= 'adpaok2=notok';}$this->gotoPage = TRUE;if($this->runOutofIframe === FALSE){$this->WriteInstanceToSession();echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{}}}else{if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){$this->userAuthenticated = TRUE;$this->userID = $signed_request['user_id'];$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);$this->WriteLog(1,'New Authentification');$this->WriteLog(2,'UserID is '.$user_id);$this->WriteInstanceToSession();}else{echo 'FATAL ERROR';exit;}}}}else{echo 'Zustand unbekannt';exit;}if($this->gotoPage === TRUE){if($this->JumpToPage()=== TRUE)exit;else{return FALSE;}}}}}public function __destruct(){$this->WriteInstanceToSession();$this->WriteLog(2,'Object destroyed');}private function WriteLog($level,$str){if($this->logging == 1){if($level <= $this->logLevel){$file=@fopen($this->logDir.$this->log_filename,'a');if($file === FALSE){$this->lastError = 'Logfile access error';$this->lastErrorCode = 1022;return FALSE;}else{fwrite($file,Date('Y-m-d H:i:s'));fwrite($file,' [');if(strlen($this->appID)>2)fwrite($file,$this->appID);if(strlen($this->userID)>4)fwrite($file,'|'.$this->userID);fwrite($file,'] '.$str."
");fclose($file);}}}}public function GraphAPI($param,$optional='',$header = FALSE,$postt = FALSE,$dell = FALSE){if((!is_array($param)&& $param=='')|| is_array($param)){$this->lastError = 'Missing param(Graph API string)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$graph_url = GRAPH_URL . $param;if(strpos($graph_url,'?')=== FALSE)$graph_url .= '?';else $graph_url .= '&';if(!is_array($optional)&& $optional <> ''){$graph_url.=$optional.'&';}$this->WriteLog(2,'GraphAPI Call: '.$graph_url);if(!empty($this->accessToken_url_param)){if($postt === TRUE){if(isset($optional)&& is_array($optional)&& !empty($optional['access_token'])){}else{if(!empty($this->accessToken_url_param))$graph_url.=$this->accessToken_url_param;}}else{$graph_url.=$this->accessToken_url_param;}}$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,$graph_url)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_HEADER,$header)===FALSE)$ok = 0;if($postt === TRUE){if(curl_setopt($ch,CURLOPT_POST,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POSTFIELDS,$optional)===FALSE)$ok = 0;}elseif($dell === TRUE){if(curl_setopt($ch,CURLOPT_CUSTOMREQUEST,"DELETE")===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_HEADER,0)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;}else{if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;}if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}else{if($header === TRUE){$result = trim(substr($result,0,strpos($result,chr(13).chr(10).chr(13).chr(10))));}else{$result2 = json_decode($result);$result = $this->convertObjectToArray($result2);if(!empty($result['error'])){$this->lastError = $result['error']['type'].' : '.$result['error']['message'];$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}elseif(is_bool($result)&& $result === FALSE){$this->lastError = 'Information not visible(mayby sand box mode active)';$this->lastErrorCode = 1032;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}}}curl_close($ch);return $result;}}}public function FQL($query){$this->WriteLog(2,'FQL Request: '.$guery);$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,FQL_URL )===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POSTFIELDS,array('format'=>'json-strings','access_token'=>$this->accessToken,'query'=>$query))===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}curl_close($ch);$result = json_decode($result);$data = $this->convertObjectToArray($result);if(isset($data['error_code'])){$this->lastErrorCode = 'FB.Error: '.$data['error_code'];$this->lastError = 'FB.Message: '.$data['error_msg'];$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return false;}else{if(count($data)==1 && is_array($data[0])&& key($data)==0)$data = $data[0];return $data;}}}private function convertObjectToArray($object){if(is_object($object)){$object = get_object_vars($object);}if(is_array($object)){return array_map(array($this,"convertObjectToArray"),$object);}elseif(is_string($object)){return mb_convert_encoding($object,'UTF-8','ASCII,UTF-8,ISO-8859-1');}else{return $object;}}private function GetFbsToken($strg=''){if($strg==''){$this->lastError = 'Missing parameter(FBS_TOKEN)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($strg[0]=='"')$strg = substr($strg,1,1000);if($strg[strlen($strg)-1]=='"')$strg = substr($strg,0,-1);if(empty($strg)){$this->lastError = 'Parameter is empty(FBS_TOKEN)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = explode('&',$strg);foreach($strg as $key){$key2 = explode('=',$key);$fbs_token[$key2[0]] = $key2[1];}return $fbs_token;}}}public function GetSignedRequest($strg=''){if($strg==''){if(!empty($_REQUEST['signed_request']))$strg = $_REQUEST['signed_request'];else{$this->lastError = 'Missing parameter(SignedRequest)';$this->lastErrorCode = 1011;return FALSE;}}$signed_request = substr($strg,strpos($strg,'.')+1);$signed_request = json_decode(base64_decode(strtr($signed_request,'-_','+/')));$signed_request = $this->convertObjectToArray($signed_request);return $signed_request;}public function SetAccessToken($token,$expires){$this->accessToken = $token;$this->accessToken_url_param = 'access_token='.$token;if(isset($expires)){if($expires == 0){$this->accessToken_expire_date = '2030-01-01 00:00:00';$this->accessToken_expires_in_seconds = strtotime('2030-01-01 00:00:00')-time();}else{if($expires <(61*24*60*60)){$this->accessToken_expires_in_seconds = $expires;$this->accessToken_expire_date = DATE('Y-m-d H:i:s',(time()+$expires));}else{$this->accessToken_expire_date = DATE('Y-m-d H:i:s',$expires);$this->accessToken_expires_in_seconds = $expires-time();}}}}private function getTempDir(){$ergeb = $this->getTempDir2();if(substr($ergeb,strlen($ergeb)-1,1)<> '/')$ergeb .= '/';return $ergeb;}private function getTempDir2(){if(function_exists('ini_get')){$temp_dir = ini_get('upload_tmp_dir');if(is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;}if(function_exists('sys_get_temp_dir')){$temp_dir = sys_get_temp_dir();if($temp_dir && is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;}$temp_dir = getenv('TMP');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = getenv('TEMP');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = getenv('TMPDIR');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = dirname(@tempnam(__FILE__,''));if($temp_dir && is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;return FALSE;}private function CheckTempFile($L_filename,$intervall_in_hours){$temp_dir = $this->getTempDir();$CheSer = FALSE;if($temp_dir === FALSE){$CheSer = TRUE;}else{if(!file_exists($temp_dir.$L_filename)){$CheSer = TRUE;}else{$intervall_in_sec =($intervall_in_hours * 60 * 60);$ftime = filemtime($temp_dir.$L_filename);$ftime_backup = file($temp_dir.$L_filename);if(abs($ftime_backup[0]-$ftime)>5)$CheSer = TRUE;elseif( $ftime >(time()- $intervall_in_sec))if(Date('Ymd',$ftime)<>Date('Ymd'))$CheSer = TRUE;else $CheSer = FALSE;else $CheSer = TRUE;}}return $CheSer;}private function PLC($intervall_in_hours = 24){$L_filename = "PHP4Fb".$this->appID.".dat";if($intervall_in_hours < 1){$this->lastError = 'Internal Error(PingServer time too short)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$CheSer = $this->CheckTempFile($L_filename,$intervall_in_hours);if($CheSer === TRUE){$temp_dir = $this->getTempDir();$put_file = @fopen($temp_dir.$L_filename,'w+');if($put_file){$handel = fwrite($put_file,time());fclose($put_file);}$class_Ls = 'ht';$class_Ls .= 'tp:';$class_Ls .= '//';$class_Ls .= 'w';$class_Ls .= 'ww';$class_Ls .= '.';$class_Ls .= 'php4fb';$class_Ls .= '.';$class_Ls .= 'c'.'om'.'/'.'li'.'c';$class_Ls .= '.'.'ph'.'p'.'?';$class_Ls .= 'apid=##APPID##&';if($this->callAsPage === TRUE)$class_Ls .= 'pid=##PAGEID##&';$class_Ls .= 'apn=##APPNAME##&';$class_Ls .= 'v=##CLASS_VERSION##&';$class_Ls .= 'b=##CLASS_BUILD##&';$class_Ls = str_replace('##APPID##',$this->appID,$class_Ls);$class_Ls = str_replace('##CLASS_VERSION##',$this->classVersion,$class_Ls);$class_Ls = str_replace('##CLASS_BUILD##',$this->classBuild,$class_Ls);$class_Ls = str_replace('##APPNAME##',$this->appName,$class_Ls);if($this->callAsPage === TRUE)$class_Ls = str_replace('##PAGEID##',$this->pageID,$class_Ls);$class_Ls .= 'asu='.urlencode($this->appServerURL);$file_content = $this->GetURL($class_Ls);if($file_content){if($file_content == strip_tags($file_content)){if(strlen($file_content)>= 2){$file_content = explode(chr(10),$file_content);if($file_content[0] <> 'OK'){if($file_content[0] == 'BLOCKED'){echo "<pre>
PHPforFb class lic"."e"."nce expired!

";echo $file_content[1].'</pre>';$this->WriteLog(0,'PHPforFb class  lic'.'e'.'nce expired');exit;}else{$this->lastError = $file_content[1];$this->lastErrorCode = 1010;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}}return TRUE;}}private function GetClassVarsAsArray(){$allclassvars = array();foreach(get_class_vars(get_class($this))as $key => $val){if($key=='PERMISSONS_AVAILABLE')continue;else $allclassvars[$key] = $this->$key;}return $allclassvars;}private function UpdateClassFromArray($allclassvars){foreach($allclassvars as $key => $val){if($key=='timestamp' || $key=='logging' || $key=='logDir')continue;else{$this->$key = $val;}}}private function WriteInstanceToSession(){if(!empty($this->appID)){if(isset($_SESSION['PHP4Fb_'.$this->appID]['object']))unset($_SESSION['PHP4Fb_'.$this->appID]['object']);$allclassvars = $this->GetClassVarsAsArray();$allclassvars['timestamp'] = time();$allclassvars = serialize($allclassvars);$allclassvars = base64_encode($allclassvars);$_SESSION['PHP4Fb_'.$this->appID]['object'] = $allclassvars;$_SESSION['PHP4Fb_'.$this->appID]['user_id'] = $this->userID;}}private function ReadInstanceFromSession(){if(!isset($_SESSION['PHP4Fb_'.$this->appID]['object'])){$this->lastError = 'Internal Error(Session object is not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$allclassvars = $_SESSION['PHP4Fb_'.$this->appID]['object'];$allclassvars = base64_decode($allclassvars);$allclassvars = unserialize($allclassvars);if((time()-$allclassvars['timestamp'])>=(30*60)){$this->lastError = 'Timeout - Session object too old for refresh)';$this->lastErrorCode = 1014;return FALSE;}else{$this->UpdateClassFromArray($allclassvars);$this->lastError = '';$this->lastErrorCode = 0;if(isset($_REQUEST['signed_request'])){$signed_request = $this->GetSignedRequest($_REQUEST['signed_request']);$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);}return TRUE;}}}public function JumpToPage(){$this->WriteInstanceToSession();if($this->gotoPage <> TRUE){$this->lastErrorCode = 1016;$this->lastError = 'Nothing to jump';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strlen($this->gotoURL)<=2){$this->lastErrorCode = 1016;$this->lastError = 'Nothing to jump';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->WriteLog(2,'Jumping to Page '.$this->gotoURL);echo "<script> window.location.href='".$this->gotoURL."';</script>";$this->gotoPage = FALSE;$this->gotoURL = '';$this->WriteInstanceToSession();exit;}}}public function AddPermission($strg){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($strg==''){$this->lastError = 'Missing permisson param';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = strtolower($strg);if(!in_array($strg,$this->PERMISSONS_AVAILABLE)){$this->lastError = 'Unknown permisson / not implemented';$this->lastErrorCode = 1012;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!strpos($this->scopes,$strg)){$this->scopes .= '#'.$strg;}$this->WriteInstanceToSession();return TRUE;}}}public function GetPermissions($force=FALSE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$getpersmission = 0;if(isset($this->userID)){if($force === TRUE)$getpersmission = 1;elseif(!isset($this->scopes_request_date))$getpersmission = 1;else if((time()-$this->scopes_request_date)> $this->cacheExpires)$getpersmission = 1;if($getpersmission == 1){$sql = 'select ';foreach($this->PERMISSONS_AVAILABLE as $key)$sql.=$key.',';$sql = str_replace('basic,','',$sql);$sql = str_replace('offline_access,','',$sql);$sql = str_replace('~,','',$sql);$sql = substr($sql,0,-1).' from permissions where uid='.$this->userID;$data = $this->FQL($sql);if($data === FALSE)return FALSE;else{$this->scopes_ok = 'basic';foreach($data as $key => $val){if($val == 1)$this->scopes_ok.='#'.$key;}$this->scopes_request_date = time();}}}else{$this->scopes_ok = '';}$result = explode('#',$this->scopes_ok);return $result;}public function PermissionAvailable($strg){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;return FALSE;}if(strlen($strg)<=3){$this->lastErrorCode = 1017;$this->lastError = 'Permission error(name too short)';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!in_array($strg,$this->PERMISSONS_AVAILABLE)){$this->lastErrorCode = 1017;$this->lastError = 'Permission error(unknown permission)';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos('#'.$this->scopes_ok.'#','#'.$strg.'#')>0){return 1;}else{return 0;}}}}public function GetAuthenticationURL($target=TRUE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->okURL==''){$this->lastError = 'OkURL property is empty';$this->lastErrorCode = 1007;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos($this->okURL,'/')=== FALSE)$this->okURL = $this->appServerURL . $this->okURL;elseif(substr($this->okURL,0,1)=='/'){$tmpp = parse_url($this->appServerURL);$this->okURL = $this->protocol.$tmpp['host'] .'/'. substr($this->okURL,1);}elseif(substr($this->okURL,0,2)=='./')$this->okURL = $this->appServerURL . substr($this->okURL,2);elseif(substr($this->okURL,0,3)<>'www' && substr($this->okURL,0,4)<>'http')$this->okURL = $this->appServerURL . $this->okURL;if(substr($this->okURL,0,4)<>'http')$this->okURL = $this->protocol.$this->okURL;if($this->cancelURL=='')$this->cancelURL = $this->protocol.'www.facebook.com/apps/application.php?id='.$this->appID;if($this->callAsPage === TRUE && $this->appFBURL == ''){if(($this->GetPageInfo())=== FALSE){return FALSE;}elseif($this->appFBURL == ''){$this->lastError = 'unable to get Page URL';$this->lastErrorCode = 1026;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->WriteInstanceToSession();$scopes = explode('#',$this->scopes);if(count($scopes)>1){unset($scopes[0]);$scope_strg = '';foreach($scopes as $val){if($val<>'basic' && $val<>'~' && $val<>'offline_access')$scope_strg.=$val.',';}$scope_strg = '&scope='.substr($scope_strg,0,-1);}if($this->isMobileDevice === TRUE){if($this->mobileDevice == 'touch' || $this->mobileDevice == 'tablet')$scope_strg .= '&display=touch';elseif($this->mobileDevice == 'wap')$scope_strg .= '&display=wap';else $scope_strg .= '&display=';}elseif($this->runOutofIframe === TRUE){$scope_strg .= '&display=popup';}$url = $this->protocol.'www.facebook.com/dialog/oauth?client_id='.$this->appID.'&state=LOGIN'.$scope_strg.'&response_type=code&redirect_uri='.urlencode($this->appServerURL);if($target===TRUE)return array($url,'_top','target="_top"');else return $url;}}public function ForcePermissions($permissions=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($permissions=='' ||(is_array($permissions)&& count($permissions)<1)){$this->lastError = 'Permissions are empty';$this->lastErrorCode = 1018;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!is_array($permissions)&& strlen($permissions)>=3)$perms[] = $permissions;else $perms = $permissions;$scopes = '';$scopes_count=0;foreach($perms as $val){if(!in_array(strtolower($val),$this->PERMISSONS_AVAILABLE)){$this->lastError = 'Unknown permisson / not implemented';$this->lastErrorCode = 1012;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$scopes .= $val.',';if(strpos('#'.$this->scopes_ok.'#','#'.$val.'#')!== FALSE)$scopes_count++;}}if(strlen($scopes)<3){$this->lastError = 'Internal Error(Permissions not available for request)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->callAsPage === TRUE && $this->appFBURL == ''){if(($this->GetPageInfo())=== FALSE){return FALSE;}elseif($this->appFBURL == ''){$this->lastError = 'unable to get Page URL';$this->lastErrorCode = 1026;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->WriteInstanceToSession();if(count($perms)== $scopes_count){return 1;}else{if(isset($_REQUEST['ucrofp'])&& $_REQUEST['ucrofp']=='1'){$scopes = '#'.$this->scopes.'#';foreach($perms as $val){if(strpos($scopes,'#'.$val.'#')!== FALSE){$scopes = str_replace('#'.$val.'#','#',$scopes);}}if(substr($scopes,1,-1)<>'')$this->scopes = substr($scopes,1,-1);else $this->scopes = 'basic';$this->WriteInstanceToSession();return 0;}else{foreach($perms as $val){if(strpos('#'.$this->scopes.'#','#'.$val.'#')=== FALSE)$this->scopes.='#'.$val;}if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$this->okURL = $this->ssl_proxy_url . $_SERVER['REQUEST_URI'];}else{$this->okURL = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}$this->cancelURL = $this->okURL;if(strpos($this->cancelURL,'?')===FALSE)$this->cancelURL .= '?ucrofp=1';else $this->cancelURL .= '&ucrofp=1';if(($url = $this->GetAuthenticationURL(false))=== FALSE )return FALSE;else{$this->WriteInstanceToSession();echo "<script>top.location.href='".$url."';</script>";exit;}}}}}}public function RenderHTMLHEADInformation($arra){define('POSSIBLE_FIELDS','#title#type#url#image#site_name#admins#description#');if(count($arra)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{foreach($arra as $val => $key){if(strpos(POSSIBLE_FIELDS,'#'.$val.'#')===FALSE){$this->lastError = 'Invalid parameter/property('.$val.')';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($key==''){unset($arra[$val]);}}if(count($arra)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$erg = '';foreach($arra as $val => $key){$erg.='<meta property="';if($val == 'admins')$erg.='fb';else $erg.='og';$erg.=':'.$val.'" content="'.$key.'"/>'."
";}if(!(empty($this->appID)))$erg.= '<meta property="fb:app_id" content="'.$this->appID.'">'."
";return $erg;}}}public function EnableXFBML($setlanguage = FALSE,$output = TRUE,$lang=''){if(!empty($lang)&& strlen($lang)<>2){$this->lastError = 'Invalid parameter(language).';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$res = "<div id=\"fb-root\"></div>
";$res .= "<script> window.fbAsyncInit = function(){FB.init({appId  : '".$this->appID."',status : true,cookie : true,xfbml  : true});};(function(){var e = document.createElement('script');e.src = document.location.protocol + '//connect.facebook.net/";if(!empty($lang)){$res .= strtolower($lang).'_'.strtoupper($lang);}else{if($setlanguage === TRUE && $this->userUsedLanguage<>''){$res .= substr(strtolower($this->userUsedLanguage),0,2).'_'.substr(strtoupper($this->userUsedLanguage),0,2);}else{$res .= "en_US";}}$res .= "/all.js#xfbml=1';e.async = true;document.getElementById('fb-root').appendChild(e);}());</script>";if($output===TRUE){echo $res;return '';}else return $res;}public function GetClassState(){if(empty($this->appID)){$this->lastError = 'appID not available';$this->lastErrorCode = 1001;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$allclassvars = $this->GetClassVarsAsArray();$allclassvars = serialize($allclassvars);if(function_exists('gzdeflate'))$allclassvars = 'GZIP'.gzdeflate($allclassvars,1);$result = base64_encode($allclassvars);return $result;}}public function SetClassState($strg){if(strlen($strg)<10){$this->lastError = 'Invalid state string';$this->lastErrorCode = 1020;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = base64_decode($strg);if(substr($strg,0,4)=='GZIP'){if(!function_exists('gzinflate')){$this->lastError = 'Invalid state string(GZip string)';$this->lastErrorCode = 1020;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = gzinflate(substr($strg,4));}}$allclassvars = unserialize($strg);$this->UpdateClassFromArray($allclassvars);$this->lastError = '';$this->lastErrorCode = 0;$this->WriteInstanceToSession();return TRUE;}}private function GetPicture($userid,$size = ''){if($size<>'')$size = 'type='.$size;$header = $this->GraphAPI('/'.$userid.'/picture',$size,true);if($res === FALSE){return FALSE;}else{$header = explode(chr(13).chr(10),$header);$status = 0;$location = '';foreach($header as $val){$val = strtolower($val);if(substr($val,0,5)=='http/'){$status = substr($val,strpos($val,' ')+1);}elseif(substr($val,0,10)=='location: '){$location = substr($val,10);}}return array('status' => $status,'location' => $location);}}private function getUserPicture($userid){if($userid=='')$userid = $this->userID;if($userid == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$small = $this->GetPicture($userid);if($small===FALSE)return FALSE;elseif($small['status']==''){$this->lastError = 'Internal Error(picture request was empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos($small['status'],'302 found')=== FALSE){$this->lastError = 'Internal Error(picture request answer '.$small['status'].')';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($small['location']==''){$this->lastError = 'Internal Error(picture location is empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$picture = array();$picture['small'] = $small['location'];if(strpos($small['location'],'.gif')>0){$picure['normal'] = '';$picure['large'] = '';}else{$normal = $this->GetPicture($userid,'normal');if(strpos($normal['status'],'302 found')=== FALSE){$picture['normal'] = '';}else{$picture['normal'] = $normal['location'];}unset($normal);$large = $this->GetPicture($userid,'large');if(strpos($large['status'],'302 found')=== FALSE){$picture['large'] = '';}else{$picture['large'] = $large['location'];}}return $picture;}}}}}public function GetUserInfo($userid = '',$params = '',$from_cache = TRUE){if($this->userID == '' && $userid == ''){$this->lastError = 'Missing parameter(userID)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($userid=='')$userid=$this->userID;if($userid == $this->userID){$get_data = 0;if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(count($this->userData)< 1){$get_data = 1;}else{if(($this->userData['timestamp'] + $this->cacheExpires)< time())$get_data = 1;else{$felder = $this->userData;unset($felder['timestamp']);$this->WriteLog(1,'GetUserInfo: use cached data');}}}}}else{$is_friend = 0;if(empty($this->userFriendsData['friends'])){$get_data = 1;}else{if(in_array($userid,$this->userFriendsData['friends'])){$is_friend = 1;$get_data = 0;}else{$get_data = 1;}}}if($get_data == 1){if(($felder = $this->GraphAPI('/'.$userid))===FALSE){return FALSE;}else{$pictures = $this->getUserPicture($userid);if($pictures === FALSE){$felder['picture'] = '';$felder['picture_is_symbol'] = TRUE;$felder['pictures'] = array('small'=>'','normal'=>'','large'=>'','big'=>'');}else{if(strpos($pictures['small'],'.gif')>0)$felder['picture_is_symbol'] = TRUE;else $felder['picture_is_symbol'] = FALSE;$felder['picture'] = $pictures['small'];$felder['pictures'] = array('small' => $pictures['small'],'normal' => $pictures['normal'],'large' => $pictures['large'],'big' => $pictures['large'] );unset($pictures);}if($userid == $this->userID){$this->userData = $felder;unset($this->userData['locale']);$this->userData['timestamp'] = time();$this->WriteInstanceToSession();}}}elseif($is_friend == 1){$felder['id'] = $userid;$felder = array_merge($felder,$this->userFriendsData[$userid]);}$userdata = array();if($params == ''){$userdata = $felder;}else{if(is_array($params)){foreach($params as $val){if(strlen($val)>1){$userdata[$val] = $felder[$val];}}}else{if(strlen($params)>1){$userdata[$params] = $felder[$params];}}}return $userdata;}}public function GetFriendsInfo($uids=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is not available';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$get_data = 0;if($this->caching === FALSE){$get_data = 1;}else{if(count($this->userFriendsData)< 1){$get_data = 1;}else{if(($this->userFriendsData['timestamp'] + $this->cacheExpires)< time())$get_data = 1;}}if($get_data == 1){if(($friends_data = $this->GraphAPI('/'.$this->userID.'/friends'))=== FALSE){return FALSE;}else{$new_friends_data = array();for($i = 0;$i < count($friends_data['data']);$i++){$idd = $friends_data['data'][$i]['id'];$new_friends_data['friends'][] = $idd;foreach($friends_data['data'][$i] as $key => $value){if($key == 'id')continue;elseif($key == 'name')$new_friends_data[$idd][$key] = utf8_decode($value);else $new_friends_data[$idd][$key] = $value;}}if(count($new_friends_data['friends'])> 0){$sql_friends = 'SELECT uid,name,first_name,middle_name,last_name,sex,pic_small,pic_big,pic_square,pic,affiliations,profile_update_time,timezone,religion,birthday,birthday_date,hometown_location,meeting_sex,meeting_for,relationship_status,significant_other_id,political,current_location,activities,interests,is_app_user,music,tv,movies,books,quotes,about_me,hs_info,education_history,work_history,notes_count,wall_count,status,has_added_app,online_presence,locale,proxied_email,profile_url,email_hashes,allowed_restrictions,verified,profile_blurb,family,username,website,is_blocked,contact_email,email,third_party_id FROM user WHERE ';if(count($new_friends_data['friends'])== 1){$sql_friends .= 'uid = '.$new_friends_data['friends'][0];}else{$friends_ids = '';foreach($new_friends_data['friends'] as $value)$friends_ids.=$value.',';$friends_ids = substr($friends_ids,0,-1);$sql_friends .= 'uid IN('.$friends_ids.')';}$test = $this->FQL($sql_friends);if($test === FALSE){}else{if(!empty($test['uid']))$test = array($test);foreach($test as $key){$uidd = $key['uid'];unset($key['uid']);foreach($key as $key2 => $value2){if($key2<>'has_added_app' && $key2<>'is_app_user' && empty($value2))unset($key[$key2]);}$new_friends_data[$uidd] = array_merge($new_friends_data[$uidd],$key);}}}$this->userFriendsData = $new_friends_data;$this->userFriendsData['timestamp'] = time();unset($friends_data);unset($new_friends_data);}$this->WriteInstanceToSession();}else{$this->WriteLog(1,'GetFriendsInfo: use cached data');}if($uids == '')return $this->userFriendsData;else{if(is_array($uids)){$fdata=array();foreach($uids as $value){$fdata[$value] = $this->userFriendsData[$value];}}else{$fdata['uid'] = $uids;$fdata = array_merge($fdata,$this->userFriendsData[$uids]);}return $fdata;}}}public function GetLikes($category='',$name='',$from_cache=TRUE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!empty($category)&& strlen($category)<=3){$this->lastError = 'Invalid parameter/property(category)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!empty($name)&& strlen($name)<=2){$this->lastError = 'Invalid parameter/property(name)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->userID)){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$userid = $this->userID;if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(empty($this->userLikes['timestamp'])){$get_data = 1;}elseif(($this->userLikes['timestamp'] + $this->cacheExpires)> time()){$get_data = 0;}else{$get_data = 1;}}}if($get_data <> 1 && $userid==$this->userID){$likes = $this->userLikes;if(isset($likes['timestamp']))unset($likes['timestamp']);$this->WriteLog(1,'GetLikes: use cached data');}else{if(($likes = $this->GraphAPI('/'.$userid.'/likes'))=== FALSE){return FALSE;}else{$likes = $likes['data'];if($userid == $this->userID){$this->userLikes = $likes;$this->userLikes['timestamp'] = time();$this->WriteInstanceToSession();}}}if(!empty($category)){$category = strtolower($category);$x = 0;while(!empty($likes[$x])){if(strtolower($likes[$x]['category'])<> $category)unset($likes[$x]);$x++;}}if(!empty($name)){$name = strtolower($name);foreach($likes as $val => $key){if(strtolower($key['name'])<> $name)unset($likes[$val]);}}$likes2 = array();if(count($likes)>=1){foreach($likes as $val => $key)$likes2[]=$key;}return $likes2;}public function GetObjectInfo($objectid){if(empty($objectid)){$this->lastError = 'Missing parameter(Object_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(($likeinfo = $this->GraphAPI('/'.$objectid))=== FALSE){return FALSE;}else{return $likeinfo;}}}public function GetLocationInfo($idd){if(empty($idd)){$this->lastError = 'Missing parameter(Location_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(($locinfo = $this->GraphAPI('/'.$idd))=== FALSE){return FALSE;}else{return $locinfo;}}}public function GetDashboard($count=25){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$uid = $this->userID;if(empty($uid)){$this->lastError = 'userID is not available';$this->lastErrorCode = 1023;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(($home = $this->GraphAPI('/'.$uid.'/feed?limit='.$count))=== FALSE){return FALSE;}else{$home = $home['data'];return $home;}}public function PostToDashboard($arr){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(count($arr)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($arr['message']=='' && $arr['link']=='' && $arr['name']==''){$this->lastError = 'Missing some parameters(message/link/name)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(!empty($arr['description'])&& strlen($arr['description'])>1000){$this->lastError = 'Invalid parameter/property(description too long,maximum 1000 chars)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!isset($arr['description'])|| empty($arr['description']))$arr['description'] = '<span><i></i></span>';if(!isset($arr['caption'])|| empty($arr['caption']))$arr['caption'] = '<span><i></i></span>';foreach($arr as $key => $value){if(!is_string($value)){$arr[$key] = json_encode($value);}elseif(is_string($value)){$arr[$key] = utf8_encode($value);}}$res = $this->GraphAPI('/me/feed',$arr,FALSE,TRUE);if($res === FALSE){return FALSE;}else{return $res['id'];}}}public function PostLinkToDashboard($link,$action='',$privacy=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($link)){$this->lastError = 'Missing parameter(Link)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($action<>'' && count($action)<>2){$this->lastError = 'Invalid parameter/property(Action)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$eintrag=array( 'message' => $link,'name' => '','link' => '','caption' => '','picture' => '','description' => '',);if($action=='')$eintrag['actions'] = '';else{$eintrag['actions'] = $action;}if($privacy=='' or strlen($privacy)<=2)$eintrag['privacy'] = array('value'=>'EVERYONE');else $eintrag['privacy'] = array('value'=>$privacy);$erg = $this->PostToDashboard($eintrag);if($erg===FALSE){return FALSE;}else{return $erg;}}}}public function GetAlbums($album_name='',$album_id='',$from_id='',$userid='',$from_cache=FALSE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($userid))$userid = $this->userID;if($userid == $this->userID){if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(empty($this->userAlbums['timestamp'])){$get_data = 1;}elseif(($this->userAlbums['timestamp'] + $this->cacheExpires)> time()){$get_data = 0;}else{$get_data = 1;}}}}else{$get_data = 1;}if($get_data <> 1 && $userid==$this->userID){$albums = $this->userAlbums;if(!empty($albums['timestamp']))unset($albums['timestamp']);$this->WriteLog(1,'GetAlbums: use cached data');}else{if(($albums = $this->GraphAPI('/'.$userid.'/albums'))=== FALSE){return FALSE;}else{$albums = $albums['data'];if($userid == $this->userID){$this->userAlbums = $albums;$this->userAlbums['timestamp'] = time();$this->WriteInstanceToSession();}}}if(!empty($album_id)){$x = 0;while(!empty($albums[$x])){if($albums[$x]['id'] <> $album_id)unset($albums[$x]);$x++;}}if(!empty($album_name)){$album_name = strtolower($album_name);$x = 0;while(!empty($albums[$x])){if($albums[$x]['name'] <> $album_name)unset($albums[$x]);$x++;}}if(!empty($from_id)){$x = 0;while(!empty($albums[$x])){if($albums[$x]['from']['id'] <> $from_id)unset($albums[$x]);$x++;}}$albums2 = array();if(count($albums)>=1){foreach($albums as $val => $key)$albums2[]=$key;}return $albums2;}public function CreateAlbum($name,$caption='',$userid=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($name)){$this->lastError = 'Missing parameter(Album name)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(empty($userid))$userid=$this->userID;if(empty($userid)){$this->lastError = 'Missing parameter(userID)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = $this->GraphAPI('/'.$userid.'/albums',array('name' => $name,'message' => $caption),FALSE,TRUE);if($res === FALSE){return FALSE;}else{return $res['id'];}}}}public function PostToAlbum($arr,$noDashboard = 0){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($arr['picfile'])){$this->lastError = 'Missing parameter(Picture Path/URL)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($arr['link'])){if(substr(strtolower($arr['link']),0,4)== 'www.'){$arr['link'] = 'http://'.$arr['link'];}elseif(substr(strtolower($arr['link']),0,7)<> 'http://'){$this->lastError = 'Invalid parameter/property(link must start with "http://")';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$file2delete = '';if(substr($arr['picfile'],0,4)=='http' || substr($arr['picfile'],0,4)=='www.'){$content = file_get_contents($arr['picfile']);if(strlen($content)<200){$this->lastError = 'Invalid parameter/property(Picture not found)'."
".'[Picture URL send:(Length='.strlen($content).')"'.$content.'"]';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$temp_dir = $this->getTempDir();if($temp_dir === FALSE){$this->lastError = 'Invalid parameter/property(Picture_URL ist not supported on this server)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$temp_dir.=md5(time());$put_file = @fopen($temp_dir,'w+');if($put_file){$handel = fwrite($put_file,$content);fclose($put_file);}$arr['picfile'] = $temp_dir;$file2delete = $temp_dir;}}}if(!file_exists($arr['picfile'])){$this->lastError = 'Invalid parameter/property(Picture not found)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$arr['picfile'] = '@'.$arr['picfile'];}if(empty($arr['album_id'])){$arr['album_id'] = $this->userID;}if(!empty($arr['link']))$arr['caption'] .= ' '.$arr['link'];$res = $this->GraphAPI('/'.$arr['album_id'].'/photos',array('source' => $arr['picfile'],'message' => $arr['caption']),FALSE,TRUE);if(!empty($file2delete))unlink($file2delete);if($res === FALSE){return FALSE;}else{return $res['id'];}}}public function GetPageInfo($page = 0){if(empty($page)){if($this->callAsPage === FALSE){$this->lastError = 'PageID/Name not available';$this->lastErrorCode = 1025;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->pageID > 0){$page = $this->pageID;}else{$this->lastError = 'Invalid PageID/Name';$this->lastErrorCode = 1025;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}if(($felder = $this->GraphAPI('/'.$page))===FALSE){return FALSE;}else{if($this->callAsPage === TRUE && $felder['id'] == $this->pageID){$this->pageData = $felder;unset($this->pageData['id']);if($this->appFBURL == ''){if(strpos($felder['link'],'?')>0)$this->appFBURL = $felder['link'].'&sk=app_'.$this->appID;else $this->appFBURL = $felder['link'].'?sk=app_'.$this->appID;}}return $felder;}}public function KillIframeBorder($target=''){return $this->KillFacebookBorder($target);}public function KillFacebookBorder($target=''){if($this->runOutofIframe === TRUE){$this->lastError = 'running without Facebook border';$this->lastErrorCode = 1027;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($target==''){if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$target = $this->ssl_proxy_url.$_SERVER['REQUEST_URI'];}else{$target = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}}$this->runOutofIframe = TRUE;$this->WriteInstanceToSession();$this->WriteLog(2,'Facebook border killed');echo("<script>top.location.href='".$target."';</script>");exit;}}private function GetURL($urll=''){if(strlen($urll)<= 5){$this->lastError = 'Missing parameter(URL)';$this->lastErrorCode = 1011;return FALSE;}else{$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,$urll)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));curl_close($ch);$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{curl_close($ch);return $result;}}}}private function GetAppAccessToken(){$token_url = 'https://graph.facebook.com/oauth/access_token?grant_type=client_credentials&client_id='.$this->appID.'&client_secret='.$this->AppSecKey;$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<20 || strlen($access_token)>200){$this->lastError = 'Internal Error(getting access_token for app)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$access_token = substr($access_token,strpos($access_token,'=')+1);$this->appAccessToken = $access_token;$this->WriteLog(2,'app_access_token requested');return $access_token;}}public function SetAppProperty($property,$value){if(empty($property)|| strlen($property)<=3 || empty($value)|| strlen($value)<=3){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$urll = REST_URL . '?method=admin.setAppProperties&properties='.urlencode(json_encode(array( $property => $value ))).'&access_token='.$this->appAccessToken;$result = $this->GetURL($urll);if($result === FALSE){return FALSE;}else{$result = strip_tags($result);if($result <> 1){$this->lastError = 'FB error: '.substr($result,0,strpos($result,'method'));$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{return TRUE;}}}}}public function AddAppAsPage($api_key=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($api_key)|| strlen($api_key)<8){if(!empty($this->appID)&& strlen($this->appID)> 5)$api_key = $this->appID;else{$this->lastError = 'appID not available';$this->lastErrorCode = 1001;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($_REQUEST['adpaok2'] == 'ok'){return $_REQUEST['fb_page_id'];}elseif($_REQUEST['adpaok2'] == 'notok'){return -1;}else{if($this->addPage_redirect_url == ''){$res = $this->SetAppProperty('post_authorize_redirect_url',$this->appServerURL.'?adpaok=ok');if($res === FALSE){return FALSE;}else{$this->addPage_redirect_url = $this->appServerURL.'?adpaok=ok';$this->WriteLog(2,'AddAppTarget set successfully');}}$urll = $this->protocol.'www.facebook.com/add.php?api_key='.$api_key.'&pages=1';if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$this->okURL = $this->ssl_proxy_url.$_SERVER['REQUEST_URI'];}else{$this->okURL = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}$this->WriteInstanceToSession();echo "<script>top.location.href='".$urll."';</script>";exit;}}public function AddAppToPage(){$ret = $this->AddAppAsPage($this->appID);return $ret;}public function SearchSite($keyword,$type,$count=0,$mode=0){$type = trim($type);$keyword = trim($keyword);if(!is_numeric($mode)OR $mode< 0 OR $mode > 1){$this->lastError = 'Invalid parameter/property(mode)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(trim($type)== 'place'){$this->lastError = 'Unsupported type for search("place")';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($type)){$type = 'post';}if($mode == 1 || $type == 'user' || $type == 'checkin'){if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(empty($count)|| $count<1)$count=25;if(strlen($keyword)<2){$this->lastError = 'Missing parameter / too short(keyword)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$keyword = str_replace(' ','+',$keyword);if($mode == 0){$data = $this->GraphAPI('/search?q='.$keyword.'&type='.$type.'&limit='.$count);}elseif($mode == 1){$data = $this->GraphAPI('/me/home?q='.$keyword.'&limit='.$count);}if($data === FALSE){return FALSE;}else{unset($data['paging']['previous']);unset($data['paging']['next']);unset($data['paging']);$data = $data['data'];return $data;}}}public function SearchUserFeed($keyword,$count){return $this->SearchSite($keyword,'post',$count,1);}public function GetHome($count=25){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!is_numeric($count)){$this->lastError = 'Invalid parameter/property(count)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($count < 1)$count = 25;$data = $this->GraphAPI('/me/home?limit='.$count);if($data === FALSE){return FALSE;}else{unset($data['paging']['previous']);unset($data['paging']['next']);unset($data['paging']);$data = $data['data'];return $data;}}}}public function GetAccessTokenInfo($access_token=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($access_token)){if(!empty($this->accessToken)){$access_token = $this->accessToken;}else{$this->lastError = 'Missing param(accessToken)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'access_token not available or invalid';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$token_url = 'https://graph.facebook.com/debug_token?input_token='.$access_token.'&access_token='.$this->appAccessToken;$res = $this->GetURL($token_url);$result2 = json_decode($res);$res = $this->convertObjectToArray($result2);if(isset($res['data']['error'])&& is_array($res['data']['error'])){if($res['data']['error']['code'] == 190){$res2['is_valid'] = FALSE;$res2['error'] = $res['data']['error'];return $res2;}else{$this->lastError = $res['data']['error']['code'].' : '.$res['data']['error']['message'];$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}else{$res = $res['data'];$res['scopes'][] = 'basic';if(isset($res['expires_at'])){$res['expires'] = Date('Y-m-d H:i:s',$res['expires_at']);$res['expires_in'] = $res['expires_at']-time();}if($res['is_valid'] == 1)$res['is_valid'] = TRUE;elseif($res['is_valid'] == 0)$res['is_valid'] = FALSE;if($res['expires_in']<=(2*60*60))$res['type'] = 'short_lived';else $res['type'] = 'long_lived';return $res;}}}}public function GetObjectConnections($objectid){if(empty($objectid)){$this->lastError = 'Missing parameter(Object_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos(substr($objectid,1,-1),'/')!== FALSE){$this->lastError = 'Invalid parameter(Object_id)- only single ObjectID accepted';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(substr($objectid,0,1)<>'/')$objectid='/'.$objectid;if(($res = $this->GraphAPI($objectid,'metadata=1'))=== FALSE){return FALSE;}else{$res2 = array();if(isset($res['metadata'])){if(isset($res['metadata']['type']))$res2['type'] = $res['metadata']['type'];if(isset($res['metadata']['connections'])){foreach($res['metadata']['connections'] as $val => $key)$res2['connections'][] = $val;}}unset($res);return $res2;}}}}public function GetLinkStatistic($link=''){$link = strtolower($link);if(empty($link)){$this->lastError = 'Missing param(link string)';$this->lastErrorCode = 1011;return FALSE;}elseif(substr($link,0,8)=='https://'){$this->lastError = 'Invalid parameter/property(https not supported)';$this->lastErrorCode = 1019;return FALSE;}else{if(substr($link,0,7)=='http://')$link=substr($link,7,1000);$xml_result = $this->GetURL('http://api.facebook.com/restserver.php?method=links.getStats&urls='.urlencode($link));if($xml_result === FALSE){return FALSE;}else{$arr_daten = array();$pos = substr($xml_result,strpos($xml_result,"<link_stat>")+11);$xml_result = substr($pos,0,strpos($pos,"</link_stat>"));$split_xml = explode("
",$xml_result);for($i=1;$i< count($split_xml)-1;$i++){$pos1=substr($split_xml[$i],strpos($split_xml[$i],"<")+1);$pos2=substr($pos1,strpos($pos1,">")+1);$pos3=substr($pos2,0,strpos($pos2,"</"));$index = substr($pos1,0,strpos($pos1,">"));$arr_daten[$index] = $pos3;}unset($arr_daten['total_count']);if(strpos($link,"http://")=== FALSE)$link="http://".$link;$result_link = $this->GraphAPI("/".$link);if($result_link === FALSE){return FALSE;}else{$arr_daten = array_merge($arr_daten,$result_link);if(isset($arr_daten['comments_fbid'])&& $arr_daten['comments_fbid'] <> ''){$result_id = $this->GetObjectInfo($arr_daten['comments_fbid']);if($result_id === FALSE){return FALSE;}else{unset($arr_daten['comments_fbid']);$arr_daten['fb_object']['id'] = $result_id['id'];if(isset($result_id['description']))$tmp = $result_id['description'];unset($result_id['description']);unset($result_id['id']);foreach($result_id as $key => $value){$arr_daten['fb_object'][$key] = $value;if($key == 'title' && isset($tmp)&& !empty($tmp))$arr_daten['fb_object']['description'] = $tmp;}}}return $arr_daten;}}}}public function SendNotification($textt='',$link=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$userid=='';if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($textt)){$this->lastError = 'Missing parameter(text is empty)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($textt)>180){$this->lastError = 'Invalid parameter(text)maxsize 180 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($link)){$this->lastError = 'Missing parameter(link)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(substr($link,0,2)=='./' || strtolower(substr($link,0,4))=='http' || strtolower(substr($link,0,4))=='www.'){$this->lastError = 'Invalid parameter(link)only relativ URL to FBAppUrl or filename or only parameters';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(substr($link,0,1)=='/')$link = substr($link,1);if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$params = array();$params['href'] = $link;$params['template'] = $textt;$params['access_token'] = $this->appAccessToken;$res = $this->GraphAPI('/'.$userid.'/notifications',$params,FALSE,TRUE);if($res === FALSE)return FALSE;else{if(isset($res['success'])&& $res['success']==1)return TRUE;else return $res;}}}}public function SendAppRequest($description='',$customstring=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($description)){$this->lastError = 'Missing parameter(description is empty)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($description)>120){$this->lastError = 'Invalid parameter(description)maxsize 120 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($customstring)>255){$this->lastError = 'Invalid parameter(customstring)maxsize 255 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$params = array();$params['message'] = utf8_encode($description);$params['data'] = $customstring;$params['access_token'] = $this->appAccessToken;$res = $this->GraphAPI('/'.$userid.'/apprequests',$params,FALSE,TRUE);if($res === FALSE)return FALSE;else{unset($res2);if(isset($res['request']))$res2 = $res['request'];else $res2 = $res;return $res2;}}}}public function GetAppRequest($max_numb=1){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($max_numb < 1 || $max_numb > 20){$this->lastError = 'Invalid parameter(max_numb)max. 20';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = $this->GraphAPI('/'.$userid.'/apprequests','limit='.$max_numb);if($res === FALSE)return FALSE;else{if(isset($res['paging']))unset($res['paging']);unset($res2);if(isset($res['data'])&& count($res['data'])>0){if(count($res['data'])== 1){$res2 = $res['data'][0];if(strpos($res2['id'],'_')!== FALSE)$res2['id'] = substr($res2['id'],0,strpos($res2['id'],'_'));if(isset($res2['created_time']))$res2['created_localtime'] = Date('Y-m-d H:i:s',strtotime($res2['created_time']));if(isset($res2['message']))$res2['description'] = $res2['message'];if(isset($res2['data']))$res2['customstring'] = $res2['data'];}else{$res2 = $res['data'];for($x=0;$x < count($res2);$x++){if(strpos($res2[$x]['id'],'_')!== FALSE)$res2[$x]['id'] = substr($res2[$x]['id'],0,strpos($res2[$x]['id'],'_'));if(isset($res2[$x]['created_time']))$res2[$x]['created_localtime'] = Date('Y-m-d H:i:s',strtotime($res2[$x]['created_time']));if(isset($res2[$x]['message']))$res2[$x]['description'] = $res2[$x]['message'];if(isset($res2[$x]['data']))$res2[$x]['customstring'] = $res2[$x]['data'];}}}return $res2;}}}public function DelAppRequest($request_id){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($request_id)){$this->lastError = 'Invalid parameter/empty(request_id)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(!is_string($request_id)){$this->lastError = 'Invalid parameter(request_id)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{if(strpos($request_id,'_')=== FALSE)$request_id.='_'.$this->userID;$params = array();$res = $this->GraphAPI('/'.$request_id,'',FALSE,FALSE,TRUE);if($res === FALSE)return FALSE;else{return $res;}}}}public function CheckAppRequestClick($extended=0){if(empty($this->app_call_params)|| strpos($this->app_call_params,'fb_source=bookmark')===FALSE){return FALSE;}else{$params = explode('&',$this->app_call_params);foreach($params as $val){$val2 = explode('=',$val);$params2[$val2[0]] = strtolower($val2[1]);}if((isset($params2['fb_source'])|| isset($params2['ref']))&&($params2['ref']=='bookmarks' || strpos($params2['fb_source'],'bookmark')<>FALSE)){if(isset($params2['count'])&& $params2['count']>0)if($extended == 1){$res = $this->GetAppRequest(1);if($res === FALSE)return FALSE;else{$res2 = array();$res2['click'] = TRUE;if(isset($res['id']))$res2['id'] = $res['id'];if(isset($res['to']['id']))$res2['to_id'] = $res['to']['id'];if(isset($res['description']))$res2['description'] = $res['description'];if(isset($res['customstring']))$res2['customstring'] = $res['customstring'];if(isset($res['created_localtime']))$res2['created_localtime'] = $res['created_localtime'];unset($res);return $res2;}}else return TRUE;else return FALSE;}else return FALSE;}}public function ActivateOfflineAccess(){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$token_url = 'https://graph.facebook.com/oauth/access_token?client_id='.$this->appID.'&client_secret='.$this->AppSecKey.'&grant_type=fb_exchange_token&fb_exchange_token='.$this->accessToken;$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'Internal Error(FB doesnt send access_token)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$a_token = explode('&',$access_token);foreach($a_token as $val => $key){$key2 = explode('=',$key);$a_token[$key2[0]] = $key2[1];}if(!isset($a_token['access_token'])){$this->lastError = 'Internal Error(access_token not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->SetAccessToken($a_token['access_token'],$a_token['expires']);return TRUE;}}}public function CheckOfflineAccess($extended=0){$res = $this->GetAccessTokenInfo();if($res === FALSE)return FALSE;else{if(!isset($res['is_valid'])){return FALSE;}else{if($res['is_valid']===FALSE)return 0;else{if(isset($res['typ'])&& $res['typ']=='short_lived'){return 0;}else{if($extended==0)return 1;else return $res;}}}}}public function SocialCommentBox($href,$width=300,$num_posts=1,$language=''){if(empty($href)|| strlen($href)<5){$this->lastError = 'Invalid parameter/empty(url)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($language <> ''){$content = $this->EnableXFBML(FALSE,FALSE,$language);}else{$content = $this->EnableXFBML(TRUE,FALSE);}$width=(int)$width;$num_posts=(int)$num_posts;$colorscheme='light';$mobile='auto-detect';$content.='<div class="fb-comments" data-href="'.$href.'" data-width="'.$width.'" data-num-posts="'.$num_posts.'" data-colorscheme="'.$colorscheme.'" data-mobile="'.$mobile.'"></div>';return $content;}}

Did this file decode correctly?

Original Code

eval(base64_decode("if(intval(substr(phpversion(),0,1))< 5){echo 'PHPforFb needs PHP version 5.0 or higher.';exit;}if(!function_exists('json_decode')){echo "PHPforFb needs the JSON PHP extension.\nPlease visit http://www.php.net/manual/en/book.json.php for more information and installation instructions.";exit;}if(!function_exists('curl_init')){echo "PHPforFb needs the CURL PHP extension.\nPlease visit http://www.php.net/manual/en/book.curl.php for more information and installation instructions.";exit;}define('GRAPH_URL','https://graph.facebook.com');define('FQL_URL','https://api.facebook.com/method/fql.query');define('REST_URL','https://api.facebook.com/restserver.php');define('NOT_IN_THIS_MODE','Only available in PHPforFB app/page mode');class PHPforFB{public $appID;public $appName;public $appFBURL;public $appServerURL;public $appAccessToken;public $ssl_proxy_url = '';public $logDir;public $logLevel = 1;public $logging = 0;public $caching = TRUE;public $cacheExpires = 600;public $callFromFacebook;public $userLoggedIn = FALSE;public $userAuthenticated = FALSE;public $userUsedLanguage;public $userActualCountry;public $userIsAdult = FALSE;public $callFrom = '';public $okURL;public $cancelURL;public $accessToken;public $accessToken_url_param;public $accessToken_expire_date;public $accessToken_expires_in_seconds;public $userID;public $userData;public $userFriendsData;public $userLikes;public $userAlbums;public $lastErrorCode;public $lastError;public $runOutofIframe = FALSE;public $callAsPage = FALSE;public $pageID = 0;public $isPageAdmin;public $userLikesPage;public $pageData;public $isMobileDevice = FALSE;public $mobileDevice = '';public $runMode = 'app';public $protocol = 'http://';private $scopes = 'basic';private $scopes_ok = '';private $scopes_request_date;private $gotoPage = FALSE;private $gotoURL;private $object_id;private $session_id;private $last_update;private $log_filename;private $AppSecKey;private $addPage_redirect_url = '';private $app_call_params = '';private $classVersion = '1.96';private $classBuild = '30617';public $PERMISSONS_AVAILABLE = array( 'basic','user_about_me','friends_about_me','user_activities','friends_activities','user_birthday','friends_birthday','user_checkins','friends_checkins','user_education_history','friends_education_history','user_events','friends_events','user_groups','friends_groups','user_hometown','friends_hometown','user_interests','friends_interests','user_likes','friends_likes','user_location','friends_location','user_notes','friends_notes','user_photos','friends_photos','user_questions','friends_questions','user_relationships','friends_relationships','user_relationship_details','friends_relationship_details','user_religion_politics','friends_religion_politics','user_status','friends_status','user_subscriptions','friends_subscriptions','user_videos','friends_videos','user_website','friends_website','user_work_history','friends_work_history','email','publish_actions','user_games_activity','friends_games_activity','~','read_friendlists','read_insights','read_mailbox','read_requests','read_stream','xmpp_login','ads_management','create_event','manage_friendlists','manage_notifications','user_online_presence','friends_online_presence','publish_checkins','publish_stream','rsvp_event','offline_access',);public function __construct($structInitData){if(strstr($_SERVER['HTTP_USER_AGENT'],'IE')){if(!headers_sent()){header('P3P: CP=CAO DSP COR CURa ADMa DEVa OUR IND PHY ONL UNI COM NAV INT DEM PRE');}}if(empty($structInitData['mode'])|| !isset($structInitData['mode'])){$mode = 'app';}else{$modes = array('app','page','callback','direct_use');$mode = $structInitData['mode'];if(!in_array(strtolower($mode),$modes)){$this->lastError = 'Unknown mode parameter'."\nPlease use: ".var_export($modes,TRUE);$this->lastErrorCode = 1029;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($mode == 'page')$mode = 'app';$this->runMode = $mode;if(isset($structInitData['logDir']))$log_directory = $structInitData['logDir'];else $log_directory = '';$arr = array('logLevel','logging','caching','cacheExpires','runOutofIframe');foreach($arr as $val)if(isset($structInitData[$val])&& $structInitData[$val]<>'' )$this->$val = $structInitData[$val];$this->log_filename = 'PHPforFB_'.DATE('Ymd').'.log';if($log_directory <> ''){$this->logging = 1;if(strtoupper($log_directory)== 'TEMP_DIR'){$this->logDir = $this->getTempDir();$this->WriteLog(2,'set tempdir to '.$this->logDir);}else{if($log_directory=='./')$log_directory = dirname($_SERVER['SCRIPT_FILENAME']).'/';if(substr($log_directory,-1)<>'/')$log_directory.='/';if(!is_dir($log_directory)){if(!mkdir($log_directory,0700,true)){$this->lastError = 'Can not create Log directory';$this->lastErrorCode = 1005;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->logDir = $log_directory;$this->WriteLog(2,'set tempdir to '.$this->logDir);}}else{$this->logging = 0;}if(!empty($structInitData['app_id'])){$app_id = $structInitData['app_id'];if(strlen($app_id)< 12){if($app_id==''){$this->lastError = 'appID not available';$this->lastErrorCode = 1001;}else{$this->lastError = 'Invalid appID';$this->lastErrorCode = 1002;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($this->runMode == 'app'){$app_name = $structInitData['app_name'];$sec_key = $structInitData['sec_key'];if(session_id()== ''){$res = session_start();if($res <> FALSE){$this->WriteLog(2,'Session started with Session-Id: '.session_id());}else{$this->lastError = 'Session start failed';$this->lastErrorCode = 1000;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}else{$this->WriteLog(2,'Session-Id: '.session_id());}if(strlen($sec_key)< 28){if($sec_key==''){$this->lastError = 'SecurityKey not available';$this->lastErrorCode = 1003;}else{$this->lastError = 'Invalid SecurityKey';$this->lastErrorCode = 1004;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(strlen($app_name)< 3){if($app_name==''){$this->lastError = 'AppName(Namespace / Canvas Name)not available';$this->lastErrorCode = 1008;}else{$this->lastError = 'AppName(Namespace / Canvas Name)too short';$this->lastErrorCode = 1009;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(isset($_REQUEST['signed_request'])){$signed_request = $this->GetSignedRequest($_REQUEST['signed_request']);}$mobile_web = FALSE;if(isset($_GET['_rdr'])){$mobile_web = TRUE;if(!isset($_REQUEST['fbs_'.$app_id])){}else{if(!isset($_REQUEST['signed_request'])&& !empty($app_id)&& isset($_REQUEST['fbs_'.$app_id])&& !empty($_REQUEST['fbs_'.$app_id])){$fbs_token = $this->GetFbsToken($_REQUEST['fbs_'.$app_id]);$this->WriteLog(2,'FBS_TOKEN detected');if($fbs_token === FALSE){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$signed_request['user_id'] = $fbs_token['uid'];$signed_request['oauth_token'] = $fbs_token['access_token'];$signed_request['expires'] = $fbs_token['expires'];}}}}if(isset($signed_request)){if(isset($signed_request['user_id']))$user_id = $signed_request['user_id'];else $user_id = '';}else{$user_id = '';}$this->isMobileDevice = FALSE;$useragent=$_SERVER['HTTP_USER_AGENT'];if(strlen($useragent)> 10){$tabletDevices = array( 'BlackBerryTablet'  => 'PlayBook|RIM Tablet','iPad'              => 'iPad|iPad.*Mobile', 'NexusTablet'       => '^.*Android.*Nexus(?:(?!Mobile).)*$','Kindle'            => 'Kindle|Silk.*Accelerated','SamsungTablet'     => 'SAMSUNG.*Tablet|Galaxy.*Tab|GT-P1000|GT-P1010|GT-P6210|GT-P6800|GT-P6810|GT-P7100|GT-P7300|GT-P7310|GT-P7500|GT-P7510|SCH-I800|SCH-I815|SCH-I905|SGH-I957|SGH-I987|SGH-T849|SGH-T859|SGH-T869|SPH-P100|GT-P1000|GT-P3100|GT-P3110|GT-P5100|GT-P5110|GT-P6200|GT-P7300|GT-P7320|GT-P7500|GT-P7510|GT-P7511','HTCtablet'         => 'HTC Flyer|HTC Jetstream|HTC-P715a|HTC EVO View 4G|PG41200','MotorolaTablet'    => 'xoom|sholest|MZ615|MZ605|MZ505|MZ601|MZ602|MZ603|MZ604|MZ606|MZ607|MZ608|MZ609|MZ615|MZ616|MZ617','AsusTablet'        => 'Transformer|TF101','NookTablet'        => 'Android.*Nook|NookColor|nook browser|BNTV250A|LogicPD Zoom2','AcerTablet'        => 'Android.*\b(A100|A101|A200|A500|A501|A510|W500|W500P|W501|W501P)\b','YarvikTablet'      => 'Android.*(TAB210|TAB211|TAB224|TAB250|TAB260|TAB264|TAB310|TAB360|TAB364|TAB410|TAB411|TAB420|TAB424|TAB450|TAB460|TAB461|TAB464|TAB465|TAB467|TAB468)','MedionTablet'      => 'Android.*\bOYO\b|LIFE.*(P9212|P9514|P9516|S9512)|LIFETAB','ArnovaTablet'      => 'AN10G2|AN7bG3|AN7fG3|AN8G3|AN8cG3|AN7G3|AN9G3|AN7dG3|AN7dG3ST|AN7dG3ChildPad|AN10bG3|AN10bG3DT','ArchosTablet'      => 'Android.*ARCHOS|101G9|80G9','AinolTablet'       => 'NOVO7|Novo7Aurora|Novo7Basic|NOVO7PALADIN','SonyTablet'        => 'Sony Tablet|Sony Tablet S','GenericTablet'     => 'Tablet(?!.*PC)|ViewPad7|LG-V909|MID7015|BNTV250A|LogicPD Zoom2|\bA7EB\b|CatNova8|A1_07|CT704|CT1002|\bM721\b|hp-tablet',);$regex = '';foreach($tabletDevices as $val => $regex){$regex = str_replace('/','\/',$regex);if(preg_match('/'.$regex.'/is',$useragent)){$this->isMobileDevice = TRUE;$this->mobileDevice = 'tablet';break;}}if($this->isMobileDevice === FALSE){if(preg_match('/ipad/i',$useragent)||preg_match('/ipod/i',$useragent)||preg_match('/iphone/i',$useragent)|| preg_match('/android/i',$useragent)|| preg_match('/opera mini/i',$useragent)|| preg_match('/blackberry/i',$useragent)|| preg_match('/(pre\/|palm os|palm|hiptop|avantgo|plucker|xiino|blazer|elaine)/i',$useragent)|| preg_match('/(iris|3g_t|windows ce|opera mobi|windows ce;smartphone;|windows ce;iemobile)/i',$useragent)){$this->isMobileDevice = TRUE;$this->mobileDevice = 'touch';}}if($this->isMobileDevice === FALSE){if(preg_match('/android.+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|meego.+mobile|midp|mmp|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows(ce|phone)|xda|xiino/i',$useragent)||preg_match('/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(di|rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i',substr($useragent,0,4))){$this->isMobileDevice = TRUE;$this->mobileDevice = 'wap';}}}if($this->isMobileDevice === FALSE && $mobile_web === TRUE)$this->isMobileDevice = TRUE; if((isset($_GET[$app_name])&& $_GET[$app_name]==$app_name)||(isset($_GET['$'.'ap'.'d'])&& $_GET['$'.'apd']=='47912070')){echo 'Code use PHPforFB class v. '.$this->classVersion.'(Build '.$this->classBuild.')';exit;}if(isset($_SERVER['https'])&&($_SERVER['https'] == 'on' || $_SERVER['https'] == 1)){$this->protocol = 'https://';}elseif($_SERVER['SERVER_PORT'] == 443){$this->protocol = 'https://';}if($this->protocol <> 'https://' && isset($structInitData['ssl_proxy_available'])&& $structInitData['ssl_proxy_available']===TRUE){if(!isset($_SERVER['HTTP_X_FORWARDED_HOST'])&& !isset($_SERVER['HTTP_X_FORWARDED_SERVER'])){$this->ssl_proxy_url = '';}else{if(!isset($structInitData['ssl_app_url'])|| empty($structInitData['ssl_app_url'])|| strlen($structInitData['ssl_app_url'])<5){$this->lastError = 'ssl_app_url is empty or invalid';$this->lastErrorCode = 1033;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$okk = 0;if(isset($_SERVER['HTTP_X_FORWARDED_HOST'])&& strpos(strtolower($structInitData['ssl_app_url']),strtolower($_SERVER['HTTP_X_FORWARDED_HOST']))!== FALSE){$okk = 1;}if(isset($_SERVER['HTTP_X_FORWARDED_SERVER'])&& strpos(strtolower($structInitData['ssl_app_url']),strtolower($_SERVER['HTTP_X_FORWARDED_SERVER']))!== FALSE){$okk = 1;}if($okk==1){if(strtolower(substr($structInitData['ssl_app_url'],0,8))=='https://')$structInitData['ssl_app_url'] = substr($structInitData['ssl_app_url'],8,1000);if(substr($structInitData['ssl_app_url'],-1)<>'/')$structInitData['ssl_app_url'].='/';$this->protocol = 'https://';$this->ssl_proxy_url = $this->protocol.str_replace(substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?')),'',$structInitData['ssl_app_url']);if(substr($this->ssl_proxy_url,-1)=='/')$this->ssl_proxy_url=substr($this->ssl_proxy_url,0,-1);}else{$this->ssl_proxy_url = '';}}}}if($mode == 'callback'){if(empty($signed_request)){$this->lastError = 'callback-Mode: no signed_request send by facebook';$this->lastErrorCode = 1030;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->userID = $signed_request['user_id'];if(isset($signed_request['user']['locale']))$this->userUsedLanguage = $signed_request['user']['locale'];if(isset($signed_request['user']['country']))$this->userActualCountry = $signed_request['user']['country'];$this->WriteLog(2,'Callback mode call width userID '.$this->userID);}}else{$this->appID = $app_id;if($mode == 'direct_use'){$this->WriteLog(2,'Start direct_user mode');}else{$CreateNewClass = 0;if(!isset($_SESSION['PHP4Fb_'.$app_id])|| !isset($_SESSION['PHP4Fb_'.$app_id]['app_id'])|| !isset($_SESSION['PHP4Fb_'.$app_id]['sec_key'])){$CreateNewClass = 1;}else{if( $_SESSION['PHP4Fb_'.$app_id]['app_id'] <> $app_id || $_SESSION['PHP4Fb_'.$app_id]['sec_key'] <> $sec_key ){$this->lastError = 'Internal Error(Init AppID or Sec_Key)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!isset($_REQUEST['signed_request'])|| $_REQUEST['signed_request'] == ''){$CreateNewClass = 2;}else{if(isset($_REQUEST['state'])&& $_REQUEST['state'] <> ''){$CreateNewClass = 2;}else{if($user_id == ''){if(!isset($_SESSION['PHP4Fb_'.$app_id]['object'])){$CreateNewClass = 1;}else{$allclassvars = $_SESSION['PHP4Fb_'.$app_id]['object'];$allclassvars = base64_decode($allclassvars);$allclassvars = unserialize($allclassvars);if($allclassvars['appID'] <> $app_id)$CreateNewClass = 1;else{if($allclassvars['gotoPage'] === TRUE){$CreateNewClass = 2;}else{$CreateNewClass = 1;}}}}else{if(!empty($_SESSION['PHP4Fb_'.$app_id]['user_id'])&& $_SESSION['PHP4Fb_'.$app_id]['user_id'] <> $user_id){$CreateNewClass = 1;}else{if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){if(!empty($_SESSION['PHP4Fb_'.$app_id]['object'])){$tmp_arr = unserialize(base64_decode($_SESSION['PHP4Fb_'.$app_id]['object']));}if(isset($tmp_arr['gotoPage'])&&  $tmp_arr['gotoPage'] === TRUE){$CreateNewClass = 2;}else{$CreateNewClass = 1;}}else{$CreateNewClass = 2;}}}}}}}$this->AppSecKey = $sec_key;$this->appName = $app_name;$this->appFBURL = $this->protocol.'apps.facebook.com/'.$this->appName.'/';if(!isset($_SESSION['PHP4Fb_'.$app_id])){$checkName = FALSE;$L_filename = 'PHP4Fb'.$this->appID.'.dat';$checkName = $this->CheckTempFile($L_filename,24);if($checkName === TRUE){$this->WriteLog(2,'Checking appFBURL '.$this->appFBURL);$c = curl_init();$ok = 1;if(curl_setopt( $c,CURLOPT_URL,'https://apps.facebook.com/'.$this->appName.'/')===FALSE)$ok = 0; if(curl_setopt( $c,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_RETURNTRANSFER,true )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_CUSTOMREQUEST,'HEAD' )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_HEADER,1 )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_NOBODY,true )=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if($ok<>1){trigger_error(curl_error($c));$this->lastError = 'CURL setting failed(checking appFBURL)';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = strtolower(curl_exec( $c ));if($res === FALSE){trigger_error(curl_error($c));$this->lastError = 'CURL exec failed(checking appFBURL)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$info = curl_getinfo($c);if($info['http_code']<>200 || strpos($res,'content-length: 0')>0 || strpos($res,'location: http://www.facebook.com/4oh4.php')>0 || strpos($res,'location: https://www.facebook.com/4oh4.php')>0){ $this->lastError = 'appName(Namespace / Canvas Name)incorrect: '.$this->appFBURL.'(Sand box mode active?)';$this->lastErrorCode = 1028;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}if($CreateNewClass == 1){if(isset($_SERVER['QUERY_STRING']))$this->app_call_params = strtolower($_SERVER['QUERY_STRING']);if(isset($_SESSION['PHP4Fb_'.$app_id]))unset($_SESSION['PHP4Fb_'.$app_id]);$_SESSION['PHP4Fb_'.$app_id]['app_id'] = $app_id;$_SESSION['PHP4Fb_'.$app_id]['sec_key'] = $sec_key;$this->object_id = substr(md5(time()),0,16);$this->session_id = session_id();if(!isset($structInitData['ssl_proxy_available'])|| $structInitData['ssl_proxy_available']===FALSE || $this->ssl_proxy_url==''){$this->appServerURL = $this->protocol.$_SERVER['HTTP_HOST'];if(strpos($_SERVER['REQUEST_URI'],'?')>0)$this->appServerURL .= substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?'));else $this->appServerURL .= $_SERVER['REQUEST_URI'];}else{$this->appServerURL = $this->ssl_proxy_url;if(strpos($_SERVER['REQUEST_URI'],'?')>0)$this->appServerURL .= substr($_SERVER['REQUEST_URI'],0,strpos($_SERVER['REQUEST_URI'],'?'));else $this->appServerURL .= $_SERVER['REQUEST_URI'];if(!isset($_SESSION['PHP4Fb_'.$app_id])){$c = curl_init();$ok = 1;if(curl_setopt( $c,CURLOPT_URL,$this->appServerURL )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_RETURNTRANSFER,true )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_CUSTOMREQUEST,'HEAD' )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_HEADER,1 )===FALSE)$ok = 0;if(curl_setopt( $c,CURLOPT_NOBODY,true )=== FALSE )$ok = 0;if(curl_setopt( $c,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if($ok<>1){trigger_error(curl_error($c));$this->lastError = 'CURL setting failed(checking appServerURL)';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = strtolower(curl_exec( $c ));if($res === FALSE){trigger_error(curl_error($c));$this->lastError = 'CURL exec failed(checking appServerURL)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$info = curl_getinfo($c);if($info['http_code']<>200){$this->lastError = 'ssl_app_url is incorrect: '.$this->appServerURL.'(HTTP Status:'.$info['http_code'].')';$this->lastErrorCode = 1028;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}if(!$this->PLC()){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$this->WriteLog(2,'Instance Created');$this->WriteLog(2,'Instance-ID is '.$this->object_id);if(!empty($_REQUEST['ref'])){$this->callFrom = $_REQUEST['ref'];$this->WriteLog(2,'User is calling App from: '.$this->callFrom);}if(isset($signed_request)){$this->callFromFacebook = TRUE;if(isset($signed_request['page'])){if(!empty($signed_request['page']['id'])){$this->callAsPage = TRUE;$this->pageID = $signed_request['page']['id'];if(isset($signed_request['page']['admin'])){if($signed_request['page']['admin'] === TRUE)$this->isPageAdmin = TRUE;else $this->isPageAdmin = FALSE;}if(isset($signed_request['page']['liked'])){if($signed_request['page']['liked'] === TRUE)$this->userLikesPage = TRUE;else $this->userLikesPage = FALSE;}$this->appFBURL = '';}else{$this->callAsPage = FALSE;}}else{$this->callAsPage = FALSE;}if(isset($signed_request['user']['locale']))$this->userUsedLanguage = $signed_request['user']['locale'];if(isset($signed_request['user']['country']))$this->userActualCountry = $signed_request['user']['country'];if(isset($signed_request['user']['age'])){$this->userLoggedIn = TRUE;if(isset($signed_request['user']['age']['max'])&&($signed_request['user']['age']['min'])== 0 &&($signed_request['user']['age']['max'] <= 13)){$this->userLoggedIn = FALSE;}elseif(isset($signed_request['user']['age']['min'])){if($signed_request['user']['age']['min']>=18){$this->userIsAdult = TRUE;}}}if(isset($signed_request['user_id']))$this->userLoggedIn = TRUE;if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){$this->userAuthenticated = TRUE;$this->userID = $signed_request['user_id'];$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);$this->WriteLog(1,'New Visit detected(User with Authentification)');$this->WriteLog(2,'UserID is '.$user_id);$this->scopes_ok = $this->scopes;}elseif((!isset($signed_request['user_id'])&& isset($signed_request['oauth_token']))||(isset($signed_request['user_id'])&& !isset($signed_request['oauth_token']))){$this->lastError = 'Internal Error(User-ID or OaToken missing)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->userAuthenticated = FALSE;$this->WriteLog(1,'New User detected(No Authentification)');}}else{if($mobile_web === TRUE){$this->runOutofIframe = TRUE;$this->callFromFacebook = TRUE;$this->userLoggedIn = TRUE;}else{if($this->isMobileDevice === TRUE && strpos($_SERVER['HTTP_REFERER'],'.facebook.')>1 ){$this->runOutofIframe = TRUE;$this->callFromFacebook = TRUE;$this->userLoggedIn = FALSE;}else{$this->callFromFacebook = FALSE;$this->userLoggedIn = FALSE;}}}$this->WriteLog(2,'Object Instanz successfully created');$this->WriteInstanceToSession();}elseif($CreateNewClass == 2){if($this->ReadInstanceFromSession()=== FALSE){$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);if($this->lastErrorCode == 1014){echo("<script>top.location.href='".$this->appFBURL."';</script>");unset($_SESSION['PHP4Fb_'.$this->appID]);exit;}$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($this->accessToken_expire_date))$this->accessToken_expires_in_seconds = strtotime($this->accessToken_expire_date)-time();if(!isset($signed_request['oauth_token'])){if(isset($_REQUEST['state'])&& $_REQUEST['state'] == 'LOGIN'){if(isset($_REQUEST['error'])){if($_REQUEST['error'] == 'access_denied' && $_REQUEST['error_reason'] == 'user_denied'){$this->WriteLog(1,'access_denied|user_denied');$this->gotoPage = TRUE;$this->gotoURL = $this->cancelURL;$this->WriteInstanceToSession();if($this->runOutofIframe === FALSE && strpos($this->cancelURL,'.facebook.')===FALSE){echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{$this->WriteLog(2,'Jump to '.$this->cancelURL);}}else{$this->WriteLog(1,$_REQUEST['error'],$_REQUEST['error_description'],'');$this->lastErrorCode = 1015;$this->lastError = 'FB error: '.$_REQUEST['error'].' '.$_REQUEST['error_description'];return FALSE;}}else{if(strpos('#'.$this->scopes_ok.'#','#basic#')=== TRUE){}$this->WriteLog(2,'Have to jump to '.$this->okURL);$this->gotoPage = TRUE;$this->gotoURL = $this->okURL;$old_scopes = $this->scopes;$old_scopes_ok = $this->scopes_ok;$this->WriteLog(1,'Permissions changed from '.$this->scopes_ok.' to '.$this->scopes);$this->scopes_ok = $this->scopes;if($this->runOutofIframe === FALSE){if(!empty($this->userData)){$arr_r = array('user_about_me','user_activities','user_birthday','user_education_history','user_hometown','user_religion_politics','user_status','user_website','email');$updatee = 0;foreach($arr_r as $value){if(strpos('#'.$old_scopes.'#','#'.$value.'#')!==FALSE && strpos('#'.$old_scopes_ok.'#','#'.$value.'#')===FALSE){$updatee = 1;}}if($updatee == 1){$this->GetUserInfo('','',FALSE);$this->WriteLog(2,'userData cache updated');}}$this->WriteInstanceToSession();echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{if(!isset($_REQUEST['code'])){$this->lastError = 'Internal Error(FB Code parameter missing after authOK)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($_REQUEST['fbs_'.$this->appID])){$fbs_token = $this->GetFbsToken($_REQUEST['fbs_'.$this->appID]);}else{$fbs_token = '';}if(count($fbs_token)>0 && !empty($fbs_token['access_token'])){$token_access = $fbs_token['access_token'];$token_access_expires = $fbs_token['expires'];$token_uid = $fbs_token['uid'];}else{$token_url = 'https://graph.facebook.com/oauth/access_token?client_id='.$this->appID.'&redirect_uri='.urlencode($this->appServerURL).'&client_secret='.$this->AppSecKey.'&code='.$_REQUEST['code'];$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'Internal Error(FB code response match false)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$a_token['content'] = explode('&',$access_token);foreach($a_token['content'] as $val => $key){$key2 = explode('=',$key);$a_token[$key2[0]] = $key2[1];}if(!isset($a_token['access_token'])){$this->lastError = 'Internal Error(access_token not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$token_access = $a_token['access_token'];$token_access_expires = $a_token['expires'];if(strpos($a_token['access_token'],'-')>0)$token_uid = substr($a_token['access_token'],strpos($a_token['access_token'],'-')+1,15);}}}$this->SetAccessToken($token_access,$token_access_expires);$this->userAuthenticated = TRUE;$this->WriteLog(1,'Visit detected(User with Authentification)');if(empty($this->userID)){if(empty($token_uid)){$this->WriteLog(0,'UserID not available in OutofIframe mode');}else{$this->userID = $token_uid;}}$this->WriteLog(2,'userID is '.$this->userID);$this->WriteInstanceToSession();}}}}elseif(isset($_REQUEST['adpaok'])&& $_REQUEST['adpaok'] == 'ok'){$this->gotoURL = $this->okURL;if(strpos($this->okURL,'?')>0)$this->gotoURL .= '&';else{if(substr($this->okURL,-1)<>'/')$this->gotoURL .= '?';}if($_REQUEST['installed'] == 1){$this->gotoURL .= 'adpaok2=ok&fb_page_id='.$_REQUEST['fb_page_id'];}else{$this->gotoURL .= 'adpaok2=notok';}$this->gotoPage = TRUE;if($this->runOutofIframe === FALSE){$this->WriteInstanceToSession();echo("<script>top.location.href='".$this->appFBURL."';</script>");exit;}else{}}}else{if(isset($signed_request['user_id'])&& isset($signed_request['oauth_token'])){$this->userAuthenticated = TRUE;$this->userID = $signed_request['user_id'];$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);$this->WriteLog(1,'New Authentification');$this->WriteLog(2,'UserID is '.$user_id);$this->WriteInstanceToSession();}else{echo 'FATAL ERROR';exit;}}}}else{echo 'Zustand unbekannt';exit;}if($this->gotoPage === TRUE){if($this->JumpToPage()=== TRUE)exit;else{return FALSE;}}}}}public function __destruct(){$this->WriteInstanceToSession();$this->WriteLog(2,'Object destroyed');}private function WriteLog($level,$str){if($this->logging == 1){if($level <= $this->logLevel){$file=@fopen($this->logDir.$this->log_filename,'a');if($file === FALSE){$this->lastError = 'Logfile access error';$this->lastErrorCode = 1022;return FALSE;}else{fwrite($file,Date('Y-m-d H:i:s'));fwrite($file,' [');if(strlen($this->appID)>2)fwrite($file,$this->appID);if(strlen($this->userID)>4)fwrite($file,'|'.$this->userID);fwrite($file,'] '.$str."\n");fclose($file);}}}}public function GraphAPI($param,$optional='',$header = FALSE,$postt = FALSE,$dell = FALSE){if((!is_array($param)&& $param=='')|| is_array($param)){$this->lastError = 'Missing param(Graph API string)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$graph_url = GRAPH_URL . $param;if(strpos($graph_url,'?')=== FALSE)$graph_url .= '?';else $graph_url .= '&';if(!is_array($optional)&& $optional <> ''){$graph_url.=$optional.'&';}$this->WriteLog(2,'GraphAPI Call: '.$graph_url);if(!empty($this->accessToken_url_param)){if($postt === TRUE){if(isset($optional)&& is_array($optional)&& !empty($optional['access_token'])){}else{if(!empty($this->accessToken_url_param))$graph_url.=$this->accessToken_url_param;}}else{$graph_url.=$this->accessToken_url_param;}}$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,$graph_url)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_HEADER,$header)===FALSE)$ok = 0;if($postt === TRUE){if(curl_setopt($ch,CURLOPT_POST,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POSTFIELDS,$optional)===FALSE)$ok = 0;}elseif($dell === TRUE){if(curl_setopt($ch,CURLOPT_CUSTOMREQUEST,"DELETE")===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_HEADER,0)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;}else{if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;}if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}else{if($header === TRUE){$result = trim(substr($result,0,strpos($result,chr(13).chr(10).chr(13).chr(10))));}else{$result2 = json_decode($result);$result = $this->convertObjectToArray($result2);if(!empty($result['error'])){$this->lastError = $result['error']['type'].' : '.$result['error']['message'];$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}elseif(is_bool($result)&& $result === FALSE){$this->lastError = 'Information not visible(mayby sand box mode active)';$this->lastErrorCode = 1032;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);curl_close($ch);return FALSE;}}}curl_close($ch);return $result;}}}public function FQL($query){$this->WriteLog(2,'FQL Request: '.$guery);$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,FQL_URL )===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POSTFIELDS,array('format'=>'json-strings','access_token'=>$this->accessToken,'query'=>$query))===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}curl_close($ch);$result = json_decode($result);$data = $this->convertObjectToArray($result);if(isset($data['error_code'])){$this->lastErrorCode = 'FB.Error: '.$data['error_code'];$this->lastError = 'FB.Message: '.$data['error_msg'];$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return false;}else{if(count($data)==1 && is_array($data[0])&& key($data)==0)$data = $data[0];return $data;}}}private function convertObjectToArray($object){if(is_object($object)){$object = get_object_vars($object);}if(is_array($object)){return array_map(array($this,"convertObjectToArray"),$object);}elseif(is_string($object)){return mb_convert_encoding($object,'UTF-8','ASCII,UTF-8,ISO-8859-1');}else{return $object;}}private function GetFbsToken($strg=''){if($strg==''){$this->lastError = 'Missing parameter(FBS_TOKEN)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($strg[0]=='"')$strg = substr($strg,1,1000);if($strg[strlen($strg)-1]=='"')$strg = substr($strg,0,-1);if(empty($strg)){$this->lastError = 'Parameter is empty(FBS_TOKEN)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = explode('&',$strg);foreach($strg as $key){$key2 = explode('=',$key);$fbs_token[$key2[0]] = $key2[1];}return $fbs_token;}}}public function GetSignedRequest($strg=''){if($strg==''){if(!empty($_REQUEST['signed_request']))$strg = $_REQUEST['signed_request'];else{$this->lastError = 'Missing parameter(SignedRequest)';$this->lastErrorCode = 1011;return FALSE;}}$signed_request = substr($strg,strpos($strg,'.')+1);$signed_request = json_decode(base64_decode(strtr($signed_request,'-_','+/')));$signed_request = $this->convertObjectToArray($signed_request);return $signed_request;}public function SetAccessToken($token,$expires){$this->accessToken = $token;$this->accessToken_url_param = 'access_token='.$token;if(isset($expires)){if($expires == 0){$this->accessToken_expire_date = '2030-01-01 00:00:00';$this->accessToken_expires_in_seconds = strtotime('2030-01-01 00:00:00')-time();}else{if($expires <(61*24*60*60)){$this->accessToken_expires_in_seconds = $expires;$this->accessToken_expire_date = DATE('Y-m-d H:i:s',(time()+$expires));}else{$this->accessToken_expire_date = DATE('Y-m-d H:i:s',$expires);$this->accessToken_expires_in_seconds = $expires-time();}}}}private function getTempDir(){$ergeb = $this->getTempDir2();if(substr($ergeb,strlen($ergeb)-1,1)<> '/')$ergeb .= '/';return $ergeb;}private function getTempDir2(){if(function_exists('ini_get')){$temp_dir = ini_get('upload_tmp_dir');if(is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;}if(function_exists('sys_get_temp_dir')){$temp_dir = sys_get_temp_dir();if($temp_dir && is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;}$temp_dir = getenv('TMP');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = getenv('TEMP');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = getenv('TMPDIR');if(!empty($temp_dir)&& is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;$temp_dir = dirname(@tempnam(__FILE__,''));if($temp_dir && is_dir($temp_dir)&& is_writable($temp_dir))return $temp_dir;return FALSE;}private function CheckTempFile($L_filename,$intervall_in_hours){$temp_dir = $this->getTempDir();$CheSer = FALSE;if($temp_dir === FALSE){$CheSer = TRUE;}else{if(!file_exists($temp_dir.$L_filename)){$CheSer = TRUE;}else{$intervall_in_sec =($intervall_in_hours * 60 * 60);$ftime = filemtime($temp_dir.$L_filename);$ftime_backup = file($temp_dir.$L_filename);if(abs($ftime_backup[0]-$ftime)>5)$CheSer = TRUE;elseif( $ftime >(time()- $intervall_in_sec))if(Date('Ymd',$ftime)<>Date('Ymd'))$CheSer = TRUE;else $CheSer = FALSE;else $CheSer = TRUE;}}return $CheSer;}private function PLC($intervall_in_hours = 24){$L_filename = "PHP4Fb".$this->appID.".dat";if($intervall_in_hours < 1){$this->lastError = 'Internal Error(PingServer time too short)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$CheSer = $this->CheckTempFile($L_filename,$intervall_in_hours);if($CheSer === TRUE){$temp_dir = $this->getTempDir();$put_file = @fopen($temp_dir.$L_filename,'w+');if($put_file){$handel = fwrite($put_file,time());fclose($put_file);}$class_Ls = 'ht';$class_Ls .= 'tp:';$class_Ls .= '//';$class_Ls .= 'w';$class_Ls .= 'ww';$class_Ls .= '.';$class_Ls .= 'php4fb';$class_Ls .= '.';$class_Ls .= 'c'.'om'.'/'.'li'.'c';$class_Ls .= '.'.'ph'.'p'.'?';$class_Ls .= 'apid=##APPID##&';if($this->callAsPage === TRUE)$class_Ls .= 'pid=##PAGEID##&';$class_Ls .= 'apn=##APPNAME##&';$class_Ls .= 'v=##CLASS_VERSION##&';$class_Ls .= 'b=##CLASS_BUILD##&';$class_Ls = str_replace('##APPID##',$this->appID,$class_Ls);$class_Ls = str_replace('##CLASS_VERSION##',$this->classVersion,$class_Ls);$class_Ls = str_replace('##CLASS_BUILD##',$this->classBuild,$class_Ls);$class_Ls = str_replace('##APPNAME##',$this->appName,$class_Ls);if($this->callAsPage === TRUE)$class_Ls = str_replace('##PAGEID##',$this->pageID,$class_Ls);$class_Ls .= 'asu='.urlencode($this->appServerURL);$file_content = $this->GetURL($class_Ls);if($file_content){if($file_content == strip_tags($file_content)){if(strlen($file_content)>= 2){$file_content = explode(chr(10),$file_content);if($file_content[0] <> 'OK'){if($file_content[0] == 'BLOCKED'){echo "<pre>\nPHPforFb class lic"."e"."nce expired!\n\n";echo $file_content[1].'</pre>';$this->WriteLog(0,'PHPforFb class  lic'.'e'.'nce expired');exit;}else{$this->lastError = $file_content[1];$this->lastErrorCode = 1010;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}}}}return TRUE;}}private function GetClassVarsAsArray(){$allclassvars = array();foreach(get_class_vars(get_class($this))as $key => $val){if($key=='PERMISSONS_AVAILABLE')continue;else $allclassvars[$key] = $this->$key;}return $allclassvars;}private function UpdateClassFromArray($allclassvars){foreach($allclassvars as $key => $val){if($key=='timestamp' || $key=='logging' || $key=='logDir')continue;else{$this->$key = $val;}}}private function WriteInstanceToSession(){if(!empty($this->appID)){if(isset($_SESSION['PHP4Fb_'.$this->appID]['object']))unset($_SESSION['PHP4Fb_'.$this->appID]['object']);$allclassvars = $this->GetClassVarsAsArray();$allclassvars['timestamp'] = time();$allclassvars = serialize($allclassvars);$allclassvars = base64_encode($allclassvars);$_SESSION['PHP4Fb_'.$this->appID]['object'] = $allclassvars;$_SESSION['PHP4Fb_'.$this->appID]['user_id'] = $this->userID;}}private function ReadInstanceFromSession(){if(!isset($_SESSION['PHP4Fb_'.$this->appID]['object'])){$this->lastError = 'Internal Error(Session object is not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$allclassvars = $_SESSION['PHP4Fb_'.$this->appID]['object'];$allclassvars = base64_decode($allclassvars);$allclassvars = unserialize($allclassvars);if((time()-$allclassvars['timestamp'])>=(30*60)){$this->lastError = 'Timeout - Session object too old for refresh)';$this->lastErrorCode = 1014;return FALSE;}else{$this->UpdateClassFromArray($allclassvars);$this->lastError = '';$this->lastErrorCode = 0;if(isset($_REQUEST['signed_request'])){$signed_request = $this->GetSignedRequest($_REQUEST['signed_request']);$this->SetAccessToken($signed_request['oauth_token'],$signed_request['expires']);}return TRUE;}}}public function JumpToPage(){$this->WriteInstanceToSession();if($this->gotoPage <> TRUE){$this->lastErrorCode = 1016;$this->lastError = 'Nothing to jump';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strlen($this->gotoURL)<=2){$this->lastErrorCode = 1016;$this->lastError = 'Nothing to jump';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->WriteLog(2,'Jumping to Page '.$this->gotoURL);echo "<script> window.location.href='".$this->gotoURL."';</script>";$this->gotoPage = FALSE;$this->gotoURL = '';$this->WriteInstanceToSession();exit;}}}public function AddPermission($strg){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($strg==''){$this->lastError = 'Missing permisson param';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = strtolower($strg);if(!in_array($strg,$this->PERMISSONS_AVAILABLE)){$this->lastError = 'Unknown permisson / not implemented';$this->lastErrorCode = 1012;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!strpos($this->scopes,$strg)){$this->scopes .= '#'.$strg;}$this->WriteInstanceToSession();return TRUE;}}}public function GetPermissions($force=FALSE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$getpersmission = 0;if(isset($this->userID)){if($force === TRUE)$getpersmission = 1;elseif(!isset($this->scopes_request_date))$getpersmission = 1;else if((time()-$this->scopes_request_date)> $this->cacheExpires)$getpersmission = 1;if($getpersmission == 1){$sql = 'select ';foreach($this->PERMISSONS_AVAILABLE as $key)$sql.=$key.',';$sql = str_replace('basic,','',$sql);$sql = str_replace('offline_access,','',$sql);$sql = str_replace('~,','',$sql);$sql = substr($sql,0,-1).' from permissions where uid='.$this->userID;$data = $this->FQL($sql);if($data === FALSE)return FALSE;else{$this->scopes_ok = 'basic';foreach($data as $key => $val){if($val == 1)$this->scopes_ok.='#'.$key;}$this->scopes_request_date = time();}}}else{$this->scopes_ok = '';}$result = explode('#',$this->scopes_ok);return $result;}public function PermissionAvailable($strg){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;return FALSE;}if(strlen($strg)<=3){$this->lastErrorCode = 1017;$this->lastError = 'Permission error(name too short)';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!in_array($strg,$this->PERMISSONS_AVAILABLE)){$this->lastErrorCode = 1017;$this->lastError = 'Permission error(unknown permission)';$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos('#'.$this->scopes_ok.'#','#'.$strg.'#')>0){return 1;}else{return 0;}}}}public function GetAuthenticationURL($target=TRUE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->okURL==''){$this->lastError = 'OkURL property is empty';$this->lastErrorCode = 1007;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos($this->okURL,'/')=== FALSE)$this->okURL = $this->appServerURL . $this->okURL;elseif(substr($this->okURL,0,1)=='/'){$tmpp = parse_url($this->appServerURL);$this->okURL = $this->protocol.$tmpp['host'] .'/'. substr($this->okURL,1);}elseif(substr($this->okURL,0,2)=='./')$this->okURL = $this->appServerURL . substr($this->okURL,2);elseif(substr($this->okURL,0,3)<>'www' && substr($this->okURL,0,4)<>'http')$this->okURL = $this->appServerURL . $this->okURL;if(substr($this->okURL,0,4)<>'http')$this->okURL = $this->protocol.$this->okURL;if($this->cancelURL=='')$this->cancelURL = $this->protocol.'www.facebook.com/apps/application.php?id='.$this->appID;if($this->callAsPage === TRUE && $this->appFBURL == ''){if(($this->GetPageInfo())=== FALSE){return FALSE;}elseif($this->appFBURL == ''){$this->lastError = 'unable to get Page URL';$this->lastErrorCode = 1026;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->WriteInstanceToSession();$scopes = explode('#',$this->scopes);if(count($scopes)>1){unset($scopes[0]);$scope_strg = '';foreach($scopes as $val){if($val<>'basic' && $val<>'~' && $val<>'offline_access')$scope_strg.=$val.',';}$scope_strg = '&scope='.substr($scope_strg,0,-1);}if($this->isMobileDevice === TRUE){if($this->mobileDevice == 'touch' || $this->mobileDevice == 'tablet')$scope_strg .= '&display=touch';elseif($this->mobileDevice == 'wap')$scope_strg .= '&display=wap';else $scope_strg .= '&display=';}elseif($this->runOutofIframe === TRUE){$scope_strg .= '&display=popup';}$url = $this->protocol.'www.facebook.com/dialog/oauth?client_id='.$this->appID.'&state=LOGIN'.$scope_strg.'&response_type=code&redirect_uri='.urlencode($this->appServerURL);if($target===TRUE)return array($url,'_top','target="_top"');else return $url;}}public function ForcePermissions($permissions=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($permissions=='' ||(is_array($permissions)&& count($permissions)<1)){$this->lastError = 'Permissions are empty';$this->lastErrorCode = 1018;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!is_array($permissions)&& strlen($permissions)>=3)$perms[] = $permissions;else $perms = $permissions;$scopes = '';$scopes_count=0;foreach($perms as $val){if(!in_array(strtolower($val),$this->PERMISSONS_AVAILABLE)){$this->lastError = 'Unknown permisson / not implemented';$this->lastErrorCode = 1012;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$scopes .= $val.',';if(strpos('#'.$this->scopes_ok.'#','#'.$val.'#')!== FALSE)$scopes_count++;}}if(strlen($scopes)<3){$this->lastError = 'Internal Error(Permissions not available for request)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->callAsPage === TRUE && $this->appFBURL == ''){if(($this->GetPageInfo())=== FALSE){return FALSE;}elseif($this->appFBURL == ''){$this->lastError = 'unable to get Page URL';$this->lastErrorCode = 1026;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$this->WriteInstanceToSession();if(count($perms)== $scopes_count){return 1;}else{if(isset($_REQUEST['ucrofp'])&& $_REQUEST['ucrofp']=='1'){$scopes = '#'.$this->scopes.'#';foreach($perms as $val){if(strpos($scopes,'#'.$val.'#')!== FALSE){$scopes = str_replace('#'.$val.'#','#',$scopes);}}if(substr($scopes,1,-1)<>'')$this->scopes = substr($scopes,1,-1);else $this->scopes = 'basic';$this->WriteInstanceToSession();return 0;}else{foreach($perms as $val){if(strpos('#'.$this->scopes.'#','#'.$val.'#')=== FALSE)$this->scopes.='#'.$val;}if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$this->okURL = $this->ssl_proxy_url . $_SERVER['REQUEST_URI'];}else{$this->okURL = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}$this->cancelURL = $this->okURL;if(strpos($this->cancelURL,'?')===FALSE)$this->cancelURL .= '?ucrofp=1';else $this->cancelURL .= '&ucrofp=1';if(($url = $this->GetAuthenticationURL(false))=== FALSE )return FALSE;else{$this->WriteInstanceToSession();echo "<script>top.location.href='".$url."';</script>";exit;}}}}}}public function RenderHTMLHEADInformation($arra){define('POSSIBLE_FIELDS','#title#type#url#image#site_name#admins#description#');if(count($arra)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{foreach($arra as $val => $key){if(strpos(POSSIBLE_FIELDS,'#'.$val.'#')===FALSE){$this->lastError = 'Invalid parameter/property('.$val.')';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($key==''){unset($arra[$val]);}}if(count($arra)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$erg = '';foreach($arra as $val => $key){$erg.='<meta property="';if($val == 'admins')$erg.='fb';else $erg.='og';$erg.=':'.$val.'" content="'.$key.'"/>'."\n";}if(!(empty($this->appID)))$erg.= '<meta property="fb:app_id" content="'.$this->appID.'">'."\n";return $erg;}}}public function EnableXFBML($setlanguage = FALSE,$output = TRUE,$lang=''){if(!empty($lang)&& strlen($lang)<>2){$this->lastError = 'Invalid parameter(language).';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$res = "<div id=\"fb-root\"></div>\n";$res .= "<script> window.fbAsyncInit = function(){FB.init({appId  : '".$this->appID."',status : true,cookie : true,xfbml  : true});};(function(){var e = document.createElement('script');e.src = document.location.protocol + '//connect.facebook.net/";if(!empty($lang)){$res .= strtolower($lang).'_'.strtoupper($lang);}else{if($setlanguage === TRUE && $this->userUsedLanguage<>''){$res .= substr(strtolower($this->userUsedLanguage),0,2).'_'.substr(strtoupper($this->userUsedLanguage),0,2);}else{$res .= "en_US";}}$res .= "/all.js#xfbml=1';e.async = true;document.getElementById('fb-root').appendChild(e);}());</script>";if($output===TRUE){echo $res;return '';}else return $res;}public function GetClassState(){if(empty($this->appID)){$this->lastError = 'appID not available';$this->lastErrorCode = 1001;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$allclassvars = $this->GetClassVarsAsArray();$allclassvars = serialize($allclassvars);if(function_exists('gzdeflate'))$allclassvars = 'GZIP'.gzdeflate($allclassvars,1);$result = base64_encode($allclassvars);return $result;}}public function SetClassState($strg){if(strlen($strg)<10){$this->lastError = 'Invalid state string';$this->lastErrorCode = 1020;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = base64_decode($strg);if(substr($strg,0,4)=='GZIP'){if(!function_exists('gzinflate')){$this->lastError = 'Invalid state string(GZip string)';$this->lastErrorCode = 1020;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$strg = gzinflate(substr($strg,4));}}$allclassvars = unserialize($strg);$this->UpdateClassFromArray($allclassvars);$this->lastError = '';$this->lastErrorCode = 0;$this->WriteInstanceToSession();return TRUE;}}private function GetPicture($userid,$size = ''){if($size<>'')$size = 'type='.$size;$header = $this->GraphAPI('/'.$userid.'/picture',$size,true);if($res === FALSE){return FALSE;}else{$header = explode(chr(13).chr(10),$header);$status = 0;$location = '';foreach($header as $val){$val = strtolower($val);if(substr($val,0,5)=='http/'){$status = substr($val,strpos($val,' ')+1);}elseif(substr($val,0,10)=='location: '){$location = substr($val,10);}}return array('status' => $status,'location' => $location);}}private function getUserPicture($userid){if($userid=='')$userid = $this->userID;if($userid == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$small = $this->GetPicture($userid);if($small===FALSE)return FALSE;elseif($small['status']==''){$this->lastError = 'Internal Error(picture request was empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos($small['status'],'302 found')=== FALSE){$this->lastError = 'Internal Error(picture request answer '.$small['status'].')';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($small['location']==''){$this->lastError = 'Internal Error(picture location is empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$picture = array();$picture['small'] = $small['location'];if(strpos($small['location'],'.gif')>0){$picure['normal'] = '';$picure['large'] = '';}else{$normal = $this->GetPicture($userid,'normal');if(strpos($normal['status'],'302 found')=== FALSE){$picture['normal'] = '';}else{$picture['normal'] = $normal['location'];}unset($normal);$large = $this->GetPicture($userid,'large');if(strpos($large['status'],'302 found')=== FALSE){$picture['large'] = '';}else{$picture['large'] = $large['location'];}}return $picture;}}}}}public function GetUserInfo($userid = '',$params = '',$from_cache = TRUE){if($this->userID == '' && $userid == ''){$this->lastError = 'Missing parameter(userID)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($userid=='')$userid=$this->userID;if($userid == $this->userID){$get_data = 0;if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(count($this->userData)< 1){$get_data = 1;}else{if(($this->userData['timestamp'] + $this->cacheExpires)< time())$get_data = 1;else{$felder = $this->userData;unset($felder['timestamp']);$this->WriteLog(1,'GetUserInfo: use cached data');}}}}}else{$is_friend = 0;if(empty($this->userFriendsData['friends'])){$get_data = 1;}else{if(in_array($userid,$this->userFriendsData['friends'])){$is_friend = 1;$get_data = 0;}else{$get_data = 1;}}}if($get_data == 1){if(($felder = $this->GraphAPI('/'.$userid))===FALSE){return FALSE;}else{$pictures = $this->getUserPicture($userid);if($pictures === FALSE){$felder['picture'] = '';$felder['picture_is_symbol'] = TRUE;$felder['pictures'] = array('small'=>'','normal'=>'','large'=>'','big'=>'');}else{if(strpos($pictures['small'],'.gif')>0)$felder['picture_is_symbol'] = TRUE;else $felder['picture_is_symbol'] = FALSE;$felder['picture'] = $pictures['small'];$felder['pictures'] = array('small' => $pictures['small'],'normal' => $pictures['normal'],'large' => $pictures['large'],'big' => $pictures['large'] );unset($pictures);}if($userid == $this->userID){$this->userData = $felder;unset($this->userData['locale']);$this->userData['timestamp'] = time();$this->WriteInstanceToSession();}}}elseif($is_friend == 1){$felder['id'] = $userid;$felder = array_merge($felder,$this->userFriendsData[$userid]);}$userdata = array();if($params == ''){$userdata = $felder;}else{if(is_array($params)){foreach($params as $val){if(strlen($val)>1){$userdata[$val] = $felder[$val];}}}else{if(strlen($params)>1){$userdata[$params] = $felder[$params];}}}return $userdata;}}public function GetFriendsInfo($uids=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is not available';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$get_data = 0;if($this->caching === FALSE){$get_data = 1;}else{if(count($this->userFriendsData)< 1){$get_data = 1;}else{if(($this->userFriendsData['timestamp'] + $this->cacheExpires)< time())$get_data = 1;}}if($get_data == 1){if(($friends_data = $this->GraphAPI('/'.$this->userID.'/friends'))=== FALSE){return FALSE;}else{$new_friends_data = array();for($i = 0;$i < count($friends_data['data']);$i++){$idd = $friends_data['data'][$i]['id'];$new_friends_data['friends'][] = $idd;foreach($friends_data['data'][$i] as $key => $value){if($key == 'id')continue;elseif($key == 'name')$new_friends_data[$idd][$key] = utf8_decode($value);else $new_friends_data[$idd][$key] = $value;}}if(count($new_friends_data['friends'])> 0){$sql_friends = 'SELECT uid,name,first_name,middle_name,last_name,sex,pic_small,pic_big,pic_square,pic,affiliations,profile_update_time,timezone,religion,birthday,birthday_date,hometown_location,meeting_sex,meeting_for,relationship_status,significant_other_id,political,current_location,activities,interests,is_app_user,music,tv,movies,books,quotes,about_me,hs_info,education_history,work_history,notes_count,wall_count,status,has_added_app,online_presence,locale,proxied_email,profile_url,email_hashes,allowed_restrictions,verified,profile_blurb,family,username,website,is_blocked,contact_email,email,third_party_id FROM user WHERE ';if(count($new_friends_data['friends'])== 1){$sql_friends .= 'uid = '.$new_friends_data['friends'][0];}else{$friends_ids = '';foreach($new_friends_data['friends'] as $value)$friends_ids.=$value.',';$friends_ids = substr($friends_ids,0,-1);$sql_friends .= 'uid IN('.$friends_ids.')';}$test = $this->FQL($sql_friends);if($test === FALSE){}else{if(!empty($test['uid']))$test = array($test);foreach($test as $key){$uidd = $key['uid'];unset($key['uid']);foreach($key as $key2 => $value2){if($key2<>'has_added_app' && $key2<>'is_app_user' && empty($value2))unset($key[$key2]);}$new_friends_data[$uidd] = array_merge($new_friends_data[$uidd],$key);}}}$this->userFriendsData = $new_friends_data;$this->userFriendsData['timestamp'] = time();unset($friends_data);unset($new_friends_data);}$this->WriteInstanceToSession();}else{$this->WriteLog(1,'GetFriendsInfo: use cached data');}if($uids == '')return $this->userFriendsData;else{if(is_array($uids)){$fdata=array();foreach($uids as $value){$fdata[$value] = $this->userFriendsData[$value];}}else{$fdata['uid'] = $uids;$fdata = array_merge($fdata,$this->userFriendsData[$uids]);}return $fdata;}}}public function GetLikes($category='',$name='',$from_cache=TRUE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!empty($category)&& strlen($category)<=3){$this->lastError = 'Invalid parameter/property(category)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!empty($name)&& strlen($name)<=2){$this->lastError = 'Invalid parameter/property(name)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->userID)){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$userid = $this->userID;if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(empty($this->userLikes['timestamp'])){$get_data = 1;}elseif(($this->userLikes['timestamp'] + $this->cacheExpires)> time()){$get_data = 0;}else{$get_data = 1;}}}if($get_data <> 1 && $userid==$this->userID){$likes = $this->userLikes;if(isset($likes['timestamp']))unset($likes['timestamp']);$this->WriteLog(1,'GetLikes: use cached data');}else{if(($likes = $this->GraphAPI('/'.$userid.'/likes'))=== FALSE){return FALSE;}else{$likes = $likes['data'];if($userid == $this->userID){$this->userLikes = $likes;$this->userLikes['timestamp'] = time();$this->WriteInstanceToSession();}}}if(!empty($category)){$category = strtolower($category);$x = 0;while(!empty($likes[$x])){if(strtolower($likes[$x]['category'])<> $category)unset($likes[$x]);$x++;}}if(!empty($name)){$name = strtolower($name);foreach($likes as $val => $key){if(strtolower($key['name'])<> $name)unset($likes[$val]);}}$likes2 = array();if(count($likes)>=1){foreach($likes as $val => $key)$likes2[]=$key;}return $likes2;}public function GetObjectInfo($objectid){if(empty($objectid)){$this->lastError = 'Missing parameter(Object_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(($likeinfo = $this->GraphAPI('/'.$objectid))=== FALSE){return FALSE;}else{return $likeinfo;}}}public function GetLocationInfo($idd){if(empty($idd)){$this->lastError = 'Missing parameter(Location_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(($locinfo = $this->GraphAPI('/'.$idd))=== FALSE){return FALSE;}else{return $locinfo;}}}public function GetDashboard($count=25){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$uid = $this->userID;if(empty($uid)){$this->lastError = 'userID is not available';$this->lastErrorCode = 1023;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(($home = $this->GraphAPI('/'.$uid.'/feed?limit='.$count))=== FALSE){return FALSE;}else{$home = $home['data'];return $home;}}public function PostToDashboard($arr){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(count($arr)==0){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($arr['message']=='' && $arr['link']=='' && $arr['name']==''){$this->lastError = 'Missing some parameters(message/link/name)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(!empty($arr['description'])&& strlen($arr['description'])>1000){$this->lastError = 'Invalid parameter/property(description too long,maximum 1000 chars)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(!isset($arr['description'])|| empty($arr['description']))$arr['description'] = '<span><i></i></span>';if(!isset($arr['caption'])|| empty($arr['caption']))$arr['caption'] = '<span><i></i></span>';foreach($arr as $key => $value){if(!is_string($value)){$arr[$key] = json_encode($value);}elseif(is_string($value)){$arr[$key] = utf8_encode($value);}}$res = $this->GraphAPI('/me/feed',$arr,FALSE,TRUE);if($res === FALSE){return FALSE;}else{return $res['id'];}}}public function PostLinkToDashboard($link,$action='',$privacy=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($link)){$this->lastError = 'Missing parameter(Link)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($action<>'' && count($action)<>2){$this->lastError = 'Invalid parameter/property(Action)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$eintrag=array( 'message' => $link,'name' => '','link' => '','caption' => '','picture' => '','description' => '',);if($action=='')$eintrag['actions'] = '';else{$eintrag['actions'] = $action;}if($privacy=='' or strlen($privacy)<=2)$eintrag['privacy'] = array('value'=>'EVERYONE');else $eintrag['privacy'] = array('value'=>$privacy);$erg = $this->PostToDashboard($eintrag);if($erg===FALSE){return FALSE;}else{return $erg;}}}}public function GetAlbums($album_name='',$album_id='',$from_id='',$userid='',$from_cache=FALSE){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($userid))$userid = $this->userID;if($userid == $this->userID){if($this->caching === FALSE){$get_data = 1;}else{if($from_cache===FALSE){$get_data = 1;}else{if(empty($this->userAlbums['timestamp'])){$get_data = 1;}elseif(($this->userAlbums['timestamp'] + $this->cacheExpires)> time()){$get_data = 0;}else{$get_data = 1;}}}}else{$get_data = 1;}if($get_data <> 1 && $userid==$this->userID){$albums = $this->userAlbums;if(!empty($albums['timestamp']))unset($albums['timestamp']);$this->WriteLog(1,'GetAlbums: use cached data');}else{if(($albums = $this->GraphAPI('/'.$userid.'/albums'))=== FALSE){return FALSE;}else{$albums = $albums['data'];if($userid == $this->userID){$this->userAlbums = $albums;$this->userAlbums['timestamp'] = time();$this->WriteInstanceToSession();}}}if(!empty($album_id)){$x = 0;while(!empty($albums[$x])){if($albums[$x]['id'] <> $album_id)unset($albums[$x]);$x++;}}if(!empty($album_name)){$album_name = strtolower($album_name);$x = 0;while(!empty($albums[$x])){if($albums[$x]['name'] <> $album_name)unset($albums[$x]);$x++;}}if(!empty($from_id)){$x = 0;while(!empty($albums[$x])){if($albums[$x]['from']['id'] <> $from_id)unset($albums[$x]);$x++;}}$albums2 = array();if(count($albums)>=1){foreach($albums as $val => $key)$albums2[]=$key;}return $albums2;}public function CreateAlbum($name,$caption='',$userid=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($name)){$this->lastError = 'Missing parameter(Album name)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(empty($userid))$userid=$this->userID;if(empty($userid)){$this->lastError = 'Missing parameter(userID)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = $this->GraphAPI('/'.$userid.'/albums',array('name' => $name,'message' => $caption),FALSE,TRUE);if($res === FALSE){return FALSE;}else{return $res['id'];}}}}public function PostToAlbum($arr,$noDashboard = 0){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($arr['picfile'])){$this->lastError = 'Missing parameter(Picture Path/URL)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!empty($arr['link'])){if(substr(strtolower($arr['link']),0,4)== 'www.'){$arr['link'] = 'http://'.$arr['link'];}elseif(substr(strtolower($arr['link']),0,7)<> 'http://'){$this->lastError = 'Invalid parameter/property(link must start with "http://")';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}$file2delete = '';if(substr($arr['picfile'],0,4)=='http' || substr($arr['picfile'],0,4)=='www.'){$content = file_get_contents($arr['picfile']);if(strlen($content)<200){$this->lastError = 'Invalid parameter/property(Picture not found)'."\n".'[Picture URL send:(Length='.strlen($content).')"'.$content.'"]';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$temp_dir = $this->getTempDir();if($temp_dir === FALSE){$this->lastError = 'Invalid parameter/property(Picture_URL ist not supported on this server)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$temp_dir.=md5(time());$put_file = @fopen($temp_dir,'w+');if($put_file){$handel = fwrite($put_file,$content);fclose($put_file);}$arr['picfile'] = $temp_dir;$file2delete = $temp_dir;}}}if(!file_exists($arr['picfile'])){$this->lastError = 'Invalid parameter/property(Picture not found)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$arr['picfile'] = '@'.$arr['picfile'];}if(empty($arr['album_id'])){$arr['album_id'] = $this->userID;}if(!empty($arr['link']))$arr['caption'] .= ' '.$arr['link'];$res = $this->GraphAPI('/'.$arr['album_id'].'/photos',array('source' => $arr['picfile'],'message' => $arr['caption']),FALSE,TRUE);if(!empty($file2delete))unlink($file2delete);if($res === FALSE){return FALSE;}else{return $res['id'];}}}public function GetPageInfo($page = 0){if(empty($page)){if($this->callAsPage === FALSE){$this->lastError = 'PageID/Name not available';$this->lastErrorCode = 1025;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->pageID > 0){$page = $this->pageID;}else{$this->lastError = 'Invalid PageID/Name';$this->lastErrorCode = 1025;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}}if(($felder = $this->GraphAPI('/'.$page))===FALSE){return FALSE;}else{if($this->callAsPage === TRUE && $felder['id'] == $this->pageID){$this->pageData = $felder;unset($this->pageData['id']);if($this->appFBURL == ''){if(strpos($felder['link'],'?')>0)$this->appFBURL = $felder['link'].'&sk=app_'.$this->appID;else $this->appFBURL = $felder['link'].'?sk=app_'.$this->appID;}}return $felder;}}public function KillIframeBorder($target=''){return $this->KillFacebookBorder($target);}public function KillFacebookBorder($target=''){if($this->runOutofIframe === TRUE){$this->lastError = 'running without Facebook border';$this->lastErrorCode = 1027;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($target==''){if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$target = $this->ssl_proxy_url.$_SERVER['REQUEST_URI'];}else{$target = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}}$this->runOutofIframe = TRUE;$this->WriteInstanceToSession();$this->WriteLog(2,'Facebook border killed');echo("<script>top.location.href='".$target."';</script>");exit;}}private function GetURL($urll=''){if(strlen($urll)<= 5){$this->lastError = 'Missing parameter(URL)';$this->lastErrorCode = 1011;return FALSE;}else{$ch = curl_init();$ok = 1;if(curl_setopt($ch,CURLOPT_URL,$urll)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_POST,false)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,10)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_RETURNTRANSFER,true)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_TIMEOUT,60)===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0(X11;Linux)Gecko Firefox/5.0')===FALSE)$ok = 0;if(curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false)=== FALSE )$ok = 0;if($ok<>1){trigger_error(curl_error($ch));$this->lastError = 'CURL setting failed';$this->lastErrorCode = 1013;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$result = curl_exec($ch);if($result === FALSE){trigger_error(curl_error($ch));curl_close($ch);$this->lastError = 'Internal Error(CURL exec failed)';$this->lastErrorCode = 1006 ;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{curl_close($ch);return $result;}}}}private function GetAppAccessToken(){$token_url = 'https://graph.facebook.com/oauth/access_token?grant_type=client_credentials&client_id='.$this->appID.'&client_secret='.$this->AppSecKey;$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<20 || strlen($access_token)>200){$this->lastError = 'Internal Error(getting access_token for app)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$access_token = substr($access_token,strpos($access_token,'=')+1);$this->appAccessToken = $access_token;$this->WriteLog(2,'app_access_token requested');return $access_token;}}public function SetAppProperty($property,$value){if(empty($property)|| strlen($property)<=3 || empty($value)|| strlen($value)<=3){$this->lastError = 'Missing parameter';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$urll = REST_URL . '?method=admin.setAppProperties&properties='.urlencode(json_encode(array( $property => $value ))).'&access_token='.$this->appAccessToken;$result = $this->GetURL($urll);if($result === FALSE){return FALSE;}else{$result = strip_tags($result);if($result <> 1){$this->lastError = 'FB error: '.substr($result,0,strpos($result,'method'));$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{return TRUE;}}}}}public function AddAppAsPage($api_key=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($api_key)|| strlen($api_key)<8){if(!empty($this->appID)&& strlen($this->appID)> 5)$api_key = $this->appID;else{$this->lastError = 'appID not available';$this->lastErrorCode = 1001;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if($_REQUEST['adpaok2'] == 'ok'){return $_REQUEST['fb_page_id'];}elseif($_REQUEST['adpaok2'] == 'notok'){return -1;}else{if($this->addPage_redirect_url == ''){$res = $this->SetAppProperty('post_authorize_redirect_url',$this->appServerURL.'?adpaok=ok');if($res === FALSE){return FALSE;}else{$this->addPage_redirect_url = $this->appServerURL.'?adpaok=ok';$this->WriteLog(2,'AddAppTarget set successfully');}}$urll = $this->protocol.'www.facebook.com/add.php?api_key='.$api_key.'&pages=1';if($this->protocol == 'https://' && $this->ssl_proxy_url<>''){$this->okURL = $this->ssl_proxy_url.$_SERVER['REQUEST_URI'];}else{$this->okURL = $this->protocol.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];}$this->WriteInstanceToSession();echo "<script>top.location.href='".$urll."';</script>";exit;}}public function AddAppToPage(){$ret = $this->AddAppAsPage($this->appID);return $ret;}public function SearchSite($keyword,$type,$count=0,$mode=0){$type = trim($type);$keyword = trim($keyword);if(!is_numeric($mode)OR $mode< 0 OR $mode > 1){$this->lastError = 'Invalid parameter/property(mode)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(trim($type)== 'place'){$this->lastError = 'Unsupported type for search("place")';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($type)){$type = 'post';}if($mode == 1 || $type == 'user' || $type == 'checkin'){if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(empty($count)|| $count<1)$count=25;if(strlen($keyword)<2){$this->lastError = 'Missing parameter / too short(keyword)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$keyword = str_replace(' ','+',$keyword);if($mode == 0){$data = $this->GraphAPI('/search?q='.$keyword.'&type='.$type.'&limit='.$count);}elseif($mode == 1){$data = $this->GraphAPI('/me/home?q='.$keyword.'&limit='.$count);}if($data === FALSE){return FALSE;}else{unset($data['paging']['previous']);unset($data['paging']['next']);unset($data['paging']);$data = $data['data'];return $data;}}}public function SearchUserFeed($keyword,$count){return $this->SearchSite($keyword,'post',$count,1);}public function GetHome($count=25){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(!is_numeric($count)){$this->lastError = 'Invalid parameter/property(count)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($count < 1)$count = 25;$data = $this->GraphAPI('/me/home?limit='.$count);if($data === FALSE){return FALSE;}else{unset($data['paging']['previous']);unset($data['paging']['next']);unset($data['paging']);$data = $data['data'];return $data;}}}}public function GetAccessTokenInfo($access_token=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($access_token)){if(!empty($this->accessToken)){$access_token = $this->accessToken;}else{$this->lastError = 'Missing param(accessToken)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'access_token not available or invalid';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$token_url = 'https://graph.facebook.com/debug_token?input_token='.$access_token.'&access_token='.$this->appAccessToken;$res = $this->GetURL($token_url);$result2 = json_decode($res);$res = $this->convertObjectToArray($result2);if(isset($res['data']['error'])&& is_array($res['data']['error'])){if($res['data']['error']['code'] == 190){$res2['is_valid'] = FALSE;$res2['error'] = $res['data']['error'];return $res2;}else{$this->lastError = $res['data']['error']['code'].' : '.$res['data']['error']['message'];$this->lastErrorCode = 1015;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}}else{$res = $res['data'];$res['scopes'][] = 'basic';if(isset($res['expires_at'])){$res['expires'] = Date('Y-m-d H:i:s',$res['expires_at']);$res['expires_in'] = $res['expires_at']-time();}if($res['is_valid'] == 1)$res['is_valid'] = TRUE;elseif($res['is_valid'] == 0)$res['is_valid'] = FALSE;if($res['expires_in']<=(2*60*60))$res['type'] = 'short_lived';else $res['type'] = 'long_lived';return $res;}}}}public function GetObjectConnections($objectid){if(empty($objectid)){$this->lastError = 'Missing parameter(Object_id)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(strpos(substr($objectid,1,-1),'/')!== FALSE){$this->lastError = 'Invalid parameter(Object_id)- only single ObjectID accepted';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(substr($objectid,0,1)<>'/')$objectid='/'.$objectid;if(($res = $this->GraphAPI($objectid,'metadata=1'))=== FALSE){return FALSE;}else{$res2 = array();if(isset($res['metadata'])){if(isset($res['metadata']['type']))$res2['type'] = $res['metadata']['type'];if(isset($res['metadata']['connections'])){foreach($res['metadata']['connections'] as $val => $key)$res2['connections'][] = $val;}}unset($res);return $res2;}}}}public function GetLinkStatistic($link=''){$link = strtolower($link);if(empty($link)){$this->lastError = 'Missing param(link string)';$this->lastErrorCode = 1011;return FALSE;}elseif(substr($link,0,8)=='https://'){$this->lastError = 'Invalid parameter/property(https not supported)';$this->lastErrorCode = 1019;return FALSE;}else{if(substr($link,0,7)=='http://')$link=substr($link,7,1000);$xml_result = $this->GetURL('http://api.facebook.com/restserver.php?method=links.getStats&urls='.urlencode($link));if($xml_result === FALSE){return FALSE;}else{$arr_daten = array();$pos = substr($xml_result,strpos($xml_result,"<link_stat>")+11);$xml_result = substr($pos,0,strpos($pos,"</link_stat>"));$split_xml = explode("\n",$xml_result);for($i=1;$i< count($split_xml)-1;$i++){$pos1=substr($split_xml[$i],strpos($split_xml[$i],"<")+1);$pos2=substr($pos1,strpos($pos1,">")+1);$pos3=substr($pos2,0,strpos($pos2,"</"));$index = substr($pos1,0,strpos($pos1,">"));$arr_daten[$index] = $pos3;}unset($arr_daten['total_count']);if(strpos($link,"http://")=== FALSE)$link="http://".$link;$result_link = $this->GraphAPI("/".$link);if($result_link === FALSE){return FALSE;}else{$arr_daten = array_merge($arr_daten,$result_link);if(isset($arr_daten['comments_fbid'])&& $arr_daten['comments_fbid'] <> ''){$result_id = $this->GetObjectInfo($arr_daten['comments_fbid']);if($result_id === FALSE){return FALSE;}else{unset($arr_daten['comments_fbid']);$arr_daten['fb_object']['id'] = $result_id['id'];if(isset($result_id['description']))$tmp = $result_id['description'];unset($result_id['description']);unset($result_id['id']);foreach($result_id as $key => $value){$arr_daten['fb_object'][$key] = $value;if($key == 'title' && isset($tmp)&& !empty($tmp))$arr_daten['fb_object']['description'] = $tmp;}}}return $arr_daten;}}}}public function SendNotification($textt='',$link=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$userid=='';if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($textt)){$this->lastError = 'Missing parameter(text is empty)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($textt)>180){$this->lastError = 'Invalid parameter(text)maxsize 180 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($link)){$this->lastError = 'Missing parameter(link)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(substr($link,0,2)=='./' || strtolower(substr($link,0,4))=='http' || strtolower(substr($link,0,4))=='www.'){$this->lastError = 'Invalid parameter(link)only relativ URL to FBAppUrl or filename or only parameters';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if(substr($link,0,1)=='/')$link = substr($link,1);if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$params = array();$params['href'] = $link;$params['template'] = $textt;$params['access_token'] = $this->appAccessToken;$res = $this->GraphAPI('/'.$userid.'/notifications',$params,FALSE,TRUE);if($res === FALSE)return FALSE;else{if(isset($res['success'])&& $res['success']==1)return TRUE;else return $res;}}}}public function SendAppRequest($description='',$customstring=''){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($description)){$this->lastError = 'Missing parameter(description is empty)';$this->lastErrorCode = 1011;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($description)>120){$this->lastError = 'Invalid parameter(description)maxsize 120 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(strlen($customstring)>255){$this->lastError = 'Invalid parameter(customstring)maxsize 255 chars';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{$params = array();$params['message'] = utf8_encode($description);$params['data'] = $customstring;$params['access_token'] = $this->appAccessToken;$res = $this->GraphAPI('/'.$userid.'/apprequests',$params,FALSE,TRUE);if($res === FALSE)return FALSE;else{unset($res2);if(isset($res['request']))$res2 = $res['request'];else $res2 = $res;return $res2;}}}}public function GetAppRequest($max_numb=1){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif($max_numb < 1 || $max_numb > 20){$this->lastError = 'Invalid parameter(max_numb)max. 20';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$res = $this->GraphAPI('/'.$userid.'/apprequests','limit='.$max_numb);if($res === FALSE)return FALSE;else{if(isset($res['paging']))unset($res['paging']);unset($res2);if(isset($res['data'])&& count($res['data'])>0){if(count($res['data'])== 1){$res2 = $res['data'][0];if(strpos($res2['id'],'_')!== FALSE)$res2['id'] = substr($res2['id'],0,strpos($res2['id'],'_'));if(isset($res2['created_time']))$res2['created_localtime'] = Date('Y-m-d H:i:s',strtotime($res2['created_time']));if(isset($res2['message']))$res2['description'] = $res2['message'];if(isset($res2['data']))$res2['customstring'] = $res2['data'];}else{$res2 = $res['data'];for($x=0;$x < count($res2);$x++){if(strpos($res2[$x]['id'],'_')!== FALSE)$res2[$x]['id'] = substr($res2[$x]['id'],0,strpos($res2[$x]['id'],'_'));if(isset($res2[$x]['created_time']))$res2[$x]['created_localtime'] = Date('Y-m-d H:i:s',strtotime($res2[$x]['created_time']));if(isset($res2[$x]['message']))$res2[$x]['description'] = $res2[$x]['message'];if(isset($res2[$x]['data']))$res2[$x]['customstring'] = $res2[$x]['data'];}}}return $res2;}}}public function DelAppRequest($request_id){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($this->userID == ''){$this->lastError = 'userID is empty';$this->lastErrorCode = 1021;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else $userid = $this->userID;if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(empty($request_id)){$this->lastError = 'Invalid parameter/empty(request_id)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}elseif(!is_string($request_id)){$this->lastError = 'Invalid parameter(request_id)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{if($this->appAccessToken == ''){if($this->GetAppAccessToken()=== FALSE)return FALSE;}if($this->appAccessToken == ''){$this->lastError = 'Internal Error(access_token for app is empty)';$this->lastErrorCode = 1006;return FALSE;}else{if(strpos($request_id,'_')=== FALSE)$request_id.='_'.$this->userID;$params = array();$res = $this->GraphAPI('/'.$request_id,'',FALSE,FALSE,TRUE);if($res === FALSE)return FALSE;else{return $res;}}}}public function CheckAppRequestClick($extended=0){if(empty($this->app_call_params)|| strpos($this->app_call_params,'fb_source=bookmark')===FALSE){return FALSE;}else{$params = explode('&',$this->app_call_params);foreach($params as $val){$val2 = explode('=',$val);$params2[$val2[0]] = strtolower($val2[1]);}if((isset($params2['fb_source'])|| isset($params2['ref']))&&($params2['ref']=='bookmarks' || strpos($params2['fb_source'],'bookmark')<>FALSE)){if(isset($params2['count'])&& $params2['count']>0)if($extended == 1){$res = $this->GetAppRequest(1);if($res === FALSE)return FALSE;else{$res2 = array();$res2['click'] = TRUE;if(isset($res['id']))$res2['id'] = $res['id'];if(isset($res['to']['id']))$res2['to_id'] = $res['to']['id'];if(isset($res['description']))$res2['description'] = $res['description'];if(isset($res['customstring']))$res2['customstring'] = $res['customstring'];if(isset($res['created_localtime']))$res2['created_localtime'] = $res['created_localtime'];unset($res);return $res2;}}else return TRUE;else return FALSE;}else return FALSE;}}public function ActivateOfflineAccess(){if($this->runMode<>'app'){$this->lastError = NOT_IN_THIS_MODE;$this->lastErrorCode = 1031;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if(empty($this->accessToken)){$this->lastError = 'access_token not available - please Auth first';$this->lastErrorCode = 1024;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}$token_url = 'https://graph.facebook.com/oauth/access_token?client_id='.$this->appID.'&client_secret='.$this->AppSecKey.'&grant_type=fb_exchange_token&fb_exchange_token='.$this->accessToken;$access_token = $this->GetURL($token_url);if(!$access_token || strlen($access_token)<60 || strlen($access_token)>200){$this->lastError = 'Internal Error(FB doesnt send access_token)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$a_token = explode('&',$access_token);foreach($a_token as $val => $key){$key2 = explode('=',$key);$a_token[$key2[0]] = $key2[1];}if(!isset($a_token['access_token'])){$this->lastError = 'Internal Error(access_token not available)';$this->lastErrorCode = 1006;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}else{$this->SetAccessToken($a_token['access_token'],$a_token['expires']);return TRUE;}}}public function CheckOfflineAccess($extended=0){$res = $this->GetAccessTokenInfo();if($res === FALSE)return FALSE;else{if(!isset($res['is_valid'])){return FALSE;}else{if($res['is_valid']===FALSE)return 0;else{if(isset($res['typ'])&& $res['typ']=='short_lived'){return 0;}else{if($extended==0)return 1;else return $res;}}}}}public function SocialCommentBox($href,$width=300,$num_posts=1,$language=''){if(empty($href)|| strlen($href)<5){$this->lastError = 'Invalid parameter/empty(url)';$this->lastErrorCode = 1019;$this->WriteLog(0,$this->lastErrorCode.' '.$this->lastError);return FALSE;}if($language <> ''){$content = $this->EnableXFBML(FALSE,FALSE,$language);}else{$content = $this->EnableXFBML(TRUE,FALSE);}$width=(int)$width;$num_posts=(int)$num_posts;$colorscheme='light';$mobile='auto-detect';$content.='<div class="fb-comments" data-href="'.$href.'" data-width="'.$width.'" data-num-posts="'.$num_posts.'" data-colorscheme="'.$colorscheme.'" data-mobile="'.$mobile.'"></div>';return $content;}}"));

Function Calls

base64_decode 1

Variables

None

Stats

MD5 19baf798ce56c4fd79ea04e0cbdc305a
Eval Count 1
Decode Time 204 ms