Skip to content

Latest commit

 

History

History
64 lines (48 loc) · 4.66 KB

oauth.md

File metadata and controls

64 lines (48 loc) · 4.66 KB

Performing OAuth

Once the library is set up for your project, you'll be able to use it to start adding functionality to your app. The first thing your app will need to do is to obtain an access token to the Admin API by performing the OAuth process. You can read our OAuth tutorial to learn more about the process.

Once you've implemented these actions in your app, please make sure to read our notes on session handling.

Begin OAuth

Create a route for starting the OAuth method such as /login. In this route, the Shopify\Auth\OAuth::begin method will be used. The begin method returns a URL that will be used for redirecting the user to the Shopify Authentication screen. It takes in the following arguments:

Parameter Type Required? Default Value Notes
shop string Yes - A Shopify domain name or hostname that will be converted to the form exampleshop.myshopify.com.
redirectPath string Yes - The redirect path used for callback with an optional leading / (e.g. both auth/callback and /auth/callback are acceptable). The route should be allowed under the app settings.
isOnline bool Yes - true if the session is online and false otherwise.
setCookieFunction callable No - An override function to set cookies in the HTTP request. In order to be framework-agnostic, the built-in setcookie method is applied. If that method does not work for your chosen framework, a function that sets cookies can be passed in.

An example of the custom set cookie function with Yii. Similar functions can be created for any frameworks that do not rely on the PHP setcookie function, but we strongly recommend storing secure and signed cookies in your app to help prevent session hijacking.

function () use (Shopify\Auth\OAuthCookie $cookie) {
    $cookies = Yii::$app->response->cookies;
    $cookies->add(new \yii\web\Cookie([
        'name' => $cookie->getName(),
        'value' => $cookie->getValue(),
        'expire' => $cookie->getExpire(),
        'secure' => $cookie->isSecure(),
        'httpOnly' => $cookie->isSecure(),
    ]));

    return true;
}

OAuth callback

To complete the OAuth process, your app needs to validate the callback request made by Shopify after the merchant authorizes your app to access their store data.

To do that, you can call the Shopify\Auth\OAuth::callback method in the endpoint defined in the redirectPath argument of the begin method, which takes in the following arguments:

Parameter Type Required? Default Value Notes
cookies array Yes - HTTP request cookies, from which the OAuth session will be loaded. This must be a hash of cookie name => value pairs. The value will be cast to string so they may be objects that implement toString.
query array Yes - The HTTP request URL query values.
setCookieFunction callable No - An override function to set cookies in the HTTP request. In order to be framework-agnostic, the built-in setcookie method is applied. If that method does not work for your chosen framework, a function that sets cookies can be passed in.

If successful, this method will return a Session object, which is described below. Once the session is created, you can use utility methods to fetch it.

The Session object

The OAuth process will create a new Session object and store it in your Context::$SESSION_STORAGE. This object is a collection of data that is needed to authenticate requests to Shopify, so you can access shop data using the Admin API.

The Session object provides the following methods to expose its data:

Method Return Type Returned data
getId string The id of the session.
getShop string The shop to which the session belongs.
getState string The state of the session. This is mainly used for OAuth.
getScope string | null The effective API scopes enabled for this session.
getExpires DateTime | null The expiration date of the session, or null if it is offline.
isOnline bool Whether the session is online or offline.
getAccessToken string | null The Admin API access token for the session.
getOnlineAccessInfo AccessTokenOnlineUserInfo | null The data for the user associated with this session. Only applies to online sessions.

Back to guide index