Skip to content
This repository has been archived by the owner on Apr 11, 2024. It is now read-only.

Commit

Permalink
Merge pull request #1288 from Shopify/liz/update-session-for-user-info
Browse files Browse the repository at this point in the history
Update the Session to return all user information
  • Loading branch information
lizkenyon authored Mar 25, 2024
2 parents 84ddb5c + 84664fe commit fe78e75
Show file tree
Hide file tree
Showing 6 changed files with 533 additions and 56 deletions.
121 changes: 121 additions & 0 deletions .changeset/warm-hotels-allow.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
---
"@shopify/shopify-api": minor
---
Updates the Session class to handle the associated user information on the session object.

Updates the Session `fromPropertyArray` to handle all user info fields.

<details>

```ts
const sessionProperties = session.toPropertyArray(true);
/*
if sessionProperties has the following data...
[
['id', 'online_session_id'],
['shop', 'online-session-shop'],
['state', 'online-session-state'],
['isOnline', true],
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['userId', 1],
['first_name', 'online-session-first-name'],
['last_name', 'online-session-last-name'],
['email', 'online-session-email'],
['locale', 'online-session-locale'],
['email_verified', false]
['account_owner', true,]
['collaborator', false],
],
*/

const session = Session.fromPropertyArray(sessionProperties, true);
/*
... then session will have the following data...
{
id: 'online_session_id',
shop: 'online-session-shop',
state: 'online-session-state',
isOnline: true,
scope: 'online-session-scope',
accessToken: 'online-session-token',
expires: 2022-01-01T05:00:00.000Z, // Date object
onlineAccessInfo: {
associated_user: {
id: 1,
first_name: 'online-session-first-name'
last_name: 'online-session-last-name',
email: 'online-session-email',
locale: 'online-session-locale',
email_verified: false,
account_owner: true,
collaborator: false,
},
}
}
*/
```

</details>

Updates the Session `toPropertyArray` to handle all user info fields. New optional argument `returnUserData`, (defaulted to `false`), will return the user data as part of property array object. This will be defaulted to `true` in an upcoming version.

<details>

```ts
const {session, headers} = shopify.auth.callback({
rawRequest: req,
rawResponse: res,
});

/*
If session has the following data content...
{
id: 'online_session_id',
shop: 'online-session-shop',
state: 'online-session-state',
isOnline: true,
scope: 'online-session-scope',
accessToken: 'online-session-token',
expires: 2022-01-01T05:00:00.000Z, // Date object
onlineAccessInfo: {
expires_in: 1,
associated_user_scope: 'online-session-user-scope',
associated_user: {
id: 1,
first_name: 'online-session-first-name',
last_name: 'online-session-last-name',
email: 'online-session-email',
locale: 'online-session-locale',
email_verified: true,
account_owner: true,
collaborator: false,
},
}
}
*/

const sessionProperties = session.toPropertyArray();
/*
... then sessionProperties will have the following data...
[
['id', 'online_session_id'],
['shop', 'online-session-shop'],
['state', 'online-session-state'],
['isOnline', true],
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['userId', 1], // New returns the user id under the userId key instead of onlineAccessInfo
['first_name', 'online-session-first-name'],
['last_name', 'online-session-last-name'],
['email', 'online-session-email'],
['locale', 'online-session-locale'],
['email_verified', false]
['account_owner', true,]
['collaborator', false],
],
*/
```
</details>
123 changes: 115 additions & 8 deletions packages/shopify-api/docs/guides/session-storage.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,8 @@ Now that the app has a JavaScript object containing the data of a `Session`, it

The `Session` class also includes an instance method called `.toPropertyArray` that returns an array of key-value pairs, e.g.,

`toPropertyArray` has an optional parameter `returnUserData`, defaulted to false, when set to true it will return the associated user data as part of the property array object.

```ts
const {session, headers} = shopify.auth.callback({
rawRequest: req,
Expand Down Expand Up @@ -97,19 +99,74 @@ const {session, headers} = shopify.auth.callback({
}
*/

const sessionProperties = session.toPropertyArray();
const sessionProperties = session.toPropertyArray(true);
/*
... then sessionProperties will have the following data...
[
[
['id', 'online_session_id'],
['shop', 'online-session-shop'],
['state', 'online-session-state'],
['isOnline', true],
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['userId', 1],
['first_name', 'online-session-first-name'],
['last_name', 'online-session-last-name'],
['email', 'online-session-email'],
['locale', 'online-session-locale'],
['email_verified', false]
['account_owner', true,]
['collaborator', false],
],
*/
```

```ts
const {session, headers} = shopify.auth.callback({
rawRequest: req,
rawResponse: res,
});
/*
If session has the following data content...
{
id: 'online_session_id',
shop: 'online-session-shop',
state: 'online-session-state',
isOnline: true,
scope: 'online-session-scope',
accessToken: 'online-session-token',
expires: 2022-01-01T05:00:00.000Z, // Date object
onlineAccessInfo: {
expires_in: 1,
associated_user_scope: 'online-session-user-scope',
associated_user: {
id: 1,
first_name: 'online-session-first-name',
last_name: 'online-session-last-name',
email: 'online-session-email',
locale: 'online-session-locale',
email_verified: true,
account_owner: true,
collaborator: false,
},
}
}
*/

const sessionProperties = session.toPropertyArray(false);
/*
... then sessionProperties will have the following data...
[
['id', 'online_session_id'],
['shop', 'online-session-shop'],
['state', 'online-session-state'],
['isOnline', true],
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // number, milliseconds since Jan 1, 1970
['onlineAccessInfo', 1], // only the `id` property of the `associated_user` property is stored
]
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['onlineAccessInfo', 1], // The userID is returned under onlineAccessInfo
],
*/
```

Expand Down Expand Up @@ -144,7 +201,7 @@ Once the `Session` is found, the app must ensure that it converts it from the st
If the `.toPropertyArray` method was used to obtain the session data, the `Session` class has a `.fromPropertyArray` static method that can be used to convert the array data back into a session.

```ts
const sessionProperties = session.toPropertyArray();
const sessionProperties = session.toPropertyArray(true);
/*
if sessionProperties has the following data...
[
Expand All @@ -155,8 +212,58 @@ const sessionProperties = session.toPropertyArray();
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['onlineAccessInfo', 1], // only the `id` property of the `associated_user` property is stored
]
['userId', 1],
['first_name', 'online-session-first-name'],
['last_name', 'online-session-last-name'],
['email', 'online-session-email'],
['locale', 'online-session-locale'],
['email_verified', false]
['account_owner', true,]
['collaborator', false],
],
*/

const session = Session.fromPropertyArray(sessionProperties);
/*
... then session will have the following data...
{
id: 'online_session_id',
shop: 'online-session-shop',
state: 'online-session-state',
isOnline: true,
scope: 'online-session-scope',
accessToken: 'online-session-token',
expires: 2022-01-01T05:00:00.000Z, // Date object
onlineAccessInfo: {
associated_user: {
id: 1,
first_name: 'online-session-first-name'
last_name: 'online-session-last-name',
email: 'online-session-email',
locale: 'online-session-locale',
email_verified: false,
account_owner: true,
collaborator: false,
},
}
}
*/
```

```ts
const sessionProperties = session.toPropertyArray();
/*
if sessionProperties has the following data, without the user data
[
['id', 'online_session_id'],
['shop', 'online-session-shop'],
['state', 'online-session-state'],
['isOnline', true],
['scope', 'online-session-scope'],
['accessToken', 'online-session-token'],
['expires', 1641013200000], // example = January 1, 2022, as number of milliseconds since Jan 1, 1970
['onlineAccessInfo', 1],
],
*/

const session = Session.fromPropertyArray(sessionProperties);
Expand Down
70 changes: 36 additions & 34 deletions packages/shopify-api/lib/auth/oauth/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,40 +34,42 @@ export interface OnlineAccessInfo {
/**
* The user associated with the access token.
*/
associated_user: {
/**
* The user's ID.
*/
id: number;
/**
* The user's first name.
*/
first_name: string;
/**
* The user's last name.
*/
last_name: string;
/**
* The user's email address.
*/
email: string;
/**
* Whether the user has verified their email address.
*/
email_verified: boolean;
/**
* Whether the user is the account owner.
*/
account_owner: boolean;
/**
* The user's locale.
*/
locale: string;
/**
* Whether the user is a collaborator.
*/
collaborator: boolean;
};
associated_user: OnlineAccessUser;
}

export interface OnlineAccessUser {
/**
* The user's ID.
*/
id: number;
/**
* The user's first name.
*/
first_name: string;
/**
* The user's last name.
*/
last_name: string;
/**
* The user's email address.
*/
email: string;
/**
* Whether the user has verified their email address.
*/
email_verified: boolean;
/**
* Whether the user is the account owner.
*/
account_owner: boolean;
/**
* The user's locale.
*/
locale: string;
/**
* Whether the user is a collaborator.
*/
collaborator: boolean;
}

export interface OnlineAccessResponse
Expand Down
Loading

0 comments on commit fe78e75

Please sign in to comment.