User Data Migration
Once your user accounts have been migrated over to SuperTokens, additional information like metadata, roles and permissions can be associated with the user.
User Metadata Migration#
SuperTokens allows you to store arbitary data that is JSON serializable against a userId.
In this example we want to store the following metadata against our user:
{    "someKey": "someValue" }curl --location --request PUT '/recipe/user/metadata' \--header 'api-key: ' \--header 'Content-Type: application/json' \--data-raw '{  "userId": "5acb2dbc-04f0-4c80-822a-7f06cd658f6f",  "metadataUpdate": {    "someKey": "someValue"  }}'User Roles Migration#
SuperTokens allows you to assign roles and permissions to a userId.
In this example we will be assigning the admin role to a user:
curl --location --request PUT '/recipe/user/role' \--header 'api-key: ' \--header 'Content-Type: application/json' \--data-raw '{  "role": "admin",  "userId": "5acb2dbc-04f0-4c80-822a-7f06cd658f6f"
}'important
Roles and permissions must be created before they can be assigned to a user. You can follow this guide on creating roles and permissions in SuperTokens.