https://www.npmjs.com/package/simple-koa-shopify-auth
⚠️ This package should be considered DEPRECATED, due to improvements with how apps are installed and authenticated that will make it unnecessary in the future.
See https://shopify.dev/docs/apps/auth/installation and https://shopify.dev/docs/apps/auth/get-access-tokens/token-exchange for more information.
⚠️ Also, this package only works with @shopify/shopify-api
v5, and there are no plans to support v6+ currently.
See #14.
A better, simplified version of the (no longer supported) @Shopify/koa-shopify-auth middleware library. It removes the use of cookies for sessions (which greatly smooths the auth process by requiring fewer redirects in some cases), replaces a deprecated API call, and supports v5 of the official @shopify/shopify-api package.
npm i simple-koa-shopify-auth
This package assumes you have @shopify/shopify-api
v5 already installed. If you are on a lower version you will need to upgrade to version 5 with npm i @shopify/shopify-api@5.3.0
.
Please check the changelog to see all the changes, and update your code accordingly.
The usage is very similar to @Shopify/koa-shopify-auth (which you should check for more examples), but there are a few differences, so it isn't a drop-in replacement.
import { createShopifyAuth, verifyRequest } from "simple-koa-shopify-auth";
Importing differs slightly from the official library in that the createShopifyAuth
function is not a default import here, and has been renamed.
If the session is invalid it will return a 401 Unauthorized
status code, that you can handle on the client side. This is a breaking change from the official library, which returns 403 Forbidden
.
For requests, create the middleware like this:
// For API requests from the frontend, we want to return headers, so we can check if we need to reauthenticate on the client side.
// NOTE: Now this isn't needed as often since we use the token exchange endpoint to get the online token.
const verifyApiRequest = verifyRequest({ returnHeader: true });
const verifyPageRequest = verifyRequest();
The verifyRequest
middleware function only accepts the following parameters (default values shown):
NOTE: These parameters differ from the ones in the official library.
{
accessMode: "online", // The access mode of the token to check
authRoute: "/auth", // Where to redirect if the session is invalid
returnHeader: false, // If true, set headers instead of redirecting if session is invalid
}
For more help on how to use the middleware functions, check the examples from the official library.
The createShopifyAuth
middleware function only accepts the following parameters (default values shown):
NOTE: These parameters differ from the ones in the official library.
{
accessMode: "online", // What kind of token we want to fetch
authPath: "/auth", // The path to handle the request on
async afterAuth(ctx) { } // Callback function after auth is completed (the token is available at ctx.state.shopify)
}
This is a simple example that you can use to help understand how to implement it.
const server = new Koa();
// Installation route (get offline, permanent access token)
server.use(
createShopifyAuth({
accessMode: "offline",
authPath: "/install/auth",
async afterAuth(ctx) {
const { shop, accessToken } = ctx.state.shopify;
const { host } = ctx.query;
if (!accessToken) {
// This can happen if the browser interferes with the auth flow
ctx.response.status = 500;
ctx.response.body = "Failed to get access token! Please try again.";
return;
}
// Redirect to user auth endpoint, to get user's online token
ctx.redirect(`/auth?shop=${shop}&host=${host}`);
},
})
);
// User auth route (get online session token)
server.use(
createShopifyAuth({
accessMode: "online",
authPath: "/auth",
async afterAuth(ctx) {
const { shop } = ctx.state.shopify;
const { host } = ctx.query;
// Check if the app is installed
// NOTE: You can replace with your own function to check if the shop is installed, or you can just remove it, but this is an extra check that can help prevent auth issues
if (isShopActive(shop)) {
// Redirect to app
ctx.redirect(`/?shop=${shop}&host=${host}`);
} else {
// Redirect to installation endpoint to get permanent access token
ctx.redirect(`/install/auth/?shop=${shop}&host=${host}`);
}
},
})
);