Add a membership
Add a single account membership with the API or from Swan's Web Banking interface.
To add new members, you must authenticate with a user access token associated with an existing account member with the permission canManageAccountMembership.
Only account members with the permission canManageAccountMembership can add account members.
Step 1: Add the account membership​
- Call the
addAccountMembershipmutation. - Add the account ID to which you're adding an invited account member (line 4).
- In the
restrictedToobject, add information about the invited account member (lines 6-9).- If you're only granting
canViewAccountpermissions, or you're not granting any permissions, the invited account member'sbirthDateisn't required. - Include a
+in front of the phone number.
- If you're only granting
- Choose
truefor the permissions you'd like to grant to the invited account member (lines 13-17). - Choose the account membership language (line 18). If no language is chosen, the membership inherits the account language.
- Add the success payload, including any information you'd like to review (line 20).
- Add the consent URL to the success payload (line 29):
statusInfo>AccountMembershipConsentPendingStatusInfo>consent>consentUrl. - Add rejections (not shown).
The CanManageCards permissions is technically optional.
However, it's recommended to choose true or false for this permission anyway.
If you don't include the CanManageCards permission in your API call, it inherits the same value as canManageAccountMembership.
🔎 Open the mutation in API Explorer
mutation AddMember {
addAccountMembership(
input: {
accountId: "$ACCOUNT_ID"
restrictedTo: {
firstName: "Jules"
lastName: "Fleury"
phoneNumber: "+33600000000"
birthDate: "yyyy-mm-dd"
}
consentRedirectUrl: "$REDIRECT_URL"
email: "jules.fleury@mybrand.io"
canInitiatePayments: true
canManageAccountMembership: true
canManageBeneficiaries: true
canManageCards: false
canViewAccount: true
language: en
}
) {
... on AddAccountMembershipSuccessPayload {
__typename
accountMembership {
id
statusInfo {
status
... on AccountMembershipConsentPendingStatusInfo {
__typename
consent {
consentUrl
status
}
status
}
}
}
}
}
}
Step 2: Get consent to add member​
- Get the
consentUrl, included in the payload (line 11). Remember, the payload only provides theconsentUrlif you added it in step 1.6. - Send the
consentUrlto the account holder, the account's legal representative, or the account member withcanManageAccountMembershippermissions. - As soon as consent is provided, they're redirected to your
consentRedirectUrldefined in the initial API call, which fetches an OAuth 2.0 authorization code and a user access token. - Store the invited account member's new
accountMembershipId. You'll need it to bind the membership.
{
"data": {
"addAccountMembership": {
"__typename": "AddAccountMembershipSuccessPayload",
"accountMembership": {
"id": "$NEW_ACCOUNT_MEMBERSHIP_ID",
"statusInfo": {
"status": "ConsentPending",
"__typename": "AccountMembershipConsentPendingStatusInfo",
"consent": {
"consentUrl": "https://identity.swan.io/consent?consentId=$CONSENT_ID&env=Sandbox",
"status": "Created"
}
}
}
}
}
}
Step 3: Bind the invited account member​
Bind the invited account member to their account membership.
- Ask the invited account member to log into Swan. They'll be asked to create a passcode.
- With the invited account member's user access token, call the
BindAccountMembershipmutation. - Add the
accountMembershipIdfor the invited account member. - Add as much information to the payload as you need. Consider including several rejections, including the unions for a binding error (line 15), consent status (line 29), and if the member is already bound (line 42).
- If the information provided by the invited account member matches what you provided, the account member's membership status changes to
Enabledand they can start using the account according to their permissions.
You can update the account membership language when binding the account member by including it in the accept-language header.
However, this isn't the recommended method.
It's best to choose the language when adding the membership (step 1 of this page), or to update the membership.
If the API returns a user binding error, please follow the guide to fix it.
🔎 Open the mutation in API Explorer
mutation BindMember {
bindAccountMembership(
input: { accountMembershipId: "$YOUR_MEMBERSHIP_ID" }
) {
... on BindAccountMembershipSuccessPayload {
__typename
accountMembership {
id
}
}
... on BadAccountStatusRejection {
id
}
... on AccountMembershipNotFoundRejection {
id
}
... on AccountMembershipNotReadyToBeBoundRejection {
id
}
... on IdentityAlreadyBindToAccountMembershipRejection {
__typename
}
... on RestrictedToUserRejection {
__typename
}
... on ValidationRejection {
__typename
}
}
}
{
"data": {
"bindAccountMembership": {
"__typename": "BindAccountMembershipSuccessPayload",
"accountMembership": {
"id": "$YOUR_MEMBERSHIP_ID"
}
}
}
}