Hi, I'm currently trying to integrate the lastest Facebook php sdk into a Phalcon project but I'm not having much luck. I can get the SDK to work in a standalone project but the exact same code fails when integrated into a Phalcon project (either as a service or directly in a Controller). This issue seems to be that the facebook redirect helper creates a "state" property which is appended to a loginUrl and then stored in a session. When a user is redirected back to my site after signing in, it checks this property against a querystring value. The state property is only generated and stored whenever you display the login url. Somehow, when I integrate this in Phalcon the session variable and the $_GET parameter never seem to match up. The simple example which works is as follows
         // lots of requires
         Facebook\FacebookSession::setDefaultApplication($appId,$secret);
         $helper = new Facebook\FacebookRedirectLoginHelper('https://'.$_SERVER['HTTP_HOST'] .'/');
         // see if a existing session exists
         if ( isset( $_SESSION ) && isset( $_SESSION['fb_token'] ) ) {
          // create new session from saved access_token
              $session = new FacebookSession( $_SESSION['fb_token'] );
          // validate the access_token to make sure it's still valid
          try {
                 if ( !$session->validate() ) {
                 $session = null;
           }
          } catch ( Exception $e ) {
            // catch any exceptions
                $session = null;
            }
           }  // end if isset($_SESSION)
         if ( !isset( $session ) || $session === null ) {
          // no session exists
          try {
                  $session = $helper->getSessionFromRedirect();
           } catch( FacebookRequestException $ex ) {
            // When Facebook returns an error
             // handle this better in production code
              print_r( $ex );
            } catch( Exception $ex ) {
            // When validation fails or other local issues
             // handle this better in production code
               print_r( $ex );
                  }
               }
           // see if we have a session
           if ( isset( $session ) ) {
            // save the session
             $_SESSION['fb_token'] = $session->getToken();
             // create a session using saved token or the new one we generated at login
               $session = new FacebookSession( $session->getToken() );
                // graph api request for user data
                $request = new FacebookRequest( $session, 'GET', '/me' );
                 $response = $request->execute();
                  // get response
                $graphObject = $response->getGraphObject()->asArray();
                 // print profile data
                    echo '<pre>' . print_r( $graphObject, 1 ) . '</pre>';
                      // print logout url using session and redirect_uri (logout.php page should destroy the session)
                       echo '<a href="' . $helper->getLogoutUrl( $session, 'https://yourwebsite.com/app/logout.php' ) . '">Logout</a>';
              } else {
            // show login url
              echo '<a href="' . $helper->getLoginUrl( array( 'email', 'user_friends' ) ) . '">Login</a>'; // this line would generate a new state
             }When I try using this exact same code in a controller in a phalcon project, the state check always fails even though I'm not generateing a new login url. The only other difference is that in the simple project I require all the facebook files using require_once but in the Phalcon project I use
      $loader->registerNamespaces(
    array(
       "Facebook"    => __DIR__ . '/../../vendor/facebook/php-sdk-v4/src/Facebook/'
    )
   );Anyone got any clues?
P.S on a side note, do you think the "Help" link on these create post pages could be made to open a new window. It's frustrating typing out a message, tapping help to get some formatting hints and then lose all you've written. I know I can r-click and open in a new tab, but I can't be the 1st one to make this mistake first time round