# Facebook\Helpers\FacebookJavaScriptHelper
If you're using the [JavaScript SDK](https://developers.facebook.com/docs/javascript) on your site, information on the logged in user is stored in a cookie. Use the `FacebookJavaScriptHelper` to obtain an access token or signed request from the cookie.
## Usage {#usage}
This helper will handle validating and decode the signed request from the cookie set by the JavaScript SDK.
~~~
$fb = new Facebook\Facebook([/* */]);
$jsHelper = $fb->getJavaScriptHelper();
$signedRequest = $jsHelper->getSignedRequest();
if ($signedRequest) {
$payload = $signedRequest->getPayload();
var_dump($payload);
}
~~~
If a user has already authenticated your app, you can also obtain an access token.
~~~
$fb = new Facebook\Facebook([/* */]);
$jsHelper = $fb->getJavaScriptHelper();
try {
$accessToken = $jsHelper->getAccessToken();
} catch(Facebook\Exceptions\FacebookResponseException $e) {
// When Graph returns an error
echo 'Graph returned an error: ' . $e->getMessage();
} catch(Facebook\Exceptions\FacebookSDKException $e) {
// When validation fails or other local issues
echo 'Facebook SDK returned an error: ' . $e->getMessage();
}
if (isset($accessToken)) {
// Logged in.
}
~~~
You will likely want to make an Ajax request when the login state changes in the Facebook SDK for JavaScript. Information about that here: [FB.event.subscribe](https://developers.facebook.com/docs/reference/javascript/FB.getLoginStatus/#events)
## Instance Methods {#instance-methods}
### __construct() {#construct}
~~~~
public FacebookJavaScriptHelper __construct(FacebookApp $app, FacebookClient $client, $graphVersion = null)
~~~~
Upon instantiation, `FacebookJavaScriptHelper` validates and decodes the signed request that exists in the cookie set by the JavaScript SDK if present.
### getAccessToken() {#get-access-token}
~~~
public Facebook\AccessToken|null getAccessToken( Facebook\FacebookClient $client )
~~~
Checks the signed request for authentication data and tries to obtain an access token access token.
### getUserId() {#get-user-id}
~~~
public string|null getUserId()
~~~
A convenience method for obtaining a user's ID from the signed request if present. This will only return the user's ID if a valid signed request can be obtained and decoded and the user has already authorized the app.
~~~
$userId = $jsHelper->getUserId();
if ($userId) {
// User is logged in
}
~~~
This is equivalent to accessing the user ID from the signed request entity.
~~~
$signedRequest = $jsHelper->getSignedRequest();
if ($signedRequest) {
$userId = $signedRequest->getUserId();
// OR
$userId = $signedRequest->get('user_id');
}
~~~
### getSignedRequest() {#get-signed-request}
~~~
public Facebook\SignedRequest|null getSignedRequest()
~~~
Returns the signed request as a [`Facebook\SignedRequest`](/docs/php/SignedRequest) entity if present.
### getRawSignedRequest() {#get-raw-signed-request}
~~~
public string|null getRawSignedRequest()
~~~
Returns the raw encoded signed request as a `string` or `null`.