Authorizations
Cryptographically signed (stamped) request to be passed in as a header. For more info, see
here.
Body
Enum options: ACTIVITY_TYPE_UPDATE_USER_EMAIL
Timestamp (in milliseconds) of the request, used to verify liveness of user requests.
Unique identifier for a given Organization.
The parameters object containing the specific intent data for this activity.
Unique identifier for a given User.
The user’s email address. Setting this to an empty string will remove the user’s email.
parameters.verificationToken
Signed JWT containing a unique id, expiry, verification type, contact
Response
A successful response returns the following fields:
The activity object containing type, intent, and result
Unique identifier for a given Activity object.
Unique identifier for a given Organization.
The intent of the activity
activity.intent.updateUserEmailIntent
The updateUserEmailIntent objectShow updateUserEmailIntent details
activity.intent.updateUserEmailIntent.userId
Unique identifier for a given User.
activity.intent.updateUserEmailIntent.userEmail
The user’s email address. Setting this to an empty string will remove the user’s email.
activity.intent.updateUserEmailIntent.verificationToken
Signed JWT containing a unique id, expiry, verification type, contact
The result of the activity
activity.result.updateUserEmailResult
The updateUserEmailResult objectShow updateUserEmailResult details
activity.result.updateUserEmailResult.userId
Unique identifier of the User whose email was updated.
A list of objects representing a particular User’s approval or rejection of a Consensus request, including all relevant metadata.
An artifact verifying a User’s action.
Whether the activity can be approved.
Whether the activity can be rejected.
The last update timestamp.
curl --request POST \
--url https://api.turnkey.com/public/v1/submit/update_user_email \
--header 'Accept: application/json' \
--header 'Content-Type: application/json' \
--header "X-Stamp: <string> (see Authorizations)" \
--data '{
"type": "ACTIVITY_TYPE_UPDATE_USER_EMAIL",
"timestampMs": "<string> (e.g. 1746736509954)",
"organizationId": "<string> (Your Organization ID)",
"parameters": {
"userId": "<string>",
"userEmail": "<string>",
"verificationToken": "<string>"
}
}'
{
"activity": {
"id": "<activity-id>",
"status": "ACTIVITY_STATUS_COMPLETED",
"type": "ACTIVITY_TYPE_UPDATE_USER_EMAIL",
"organizationId": "<organization-id>",
"timestampMs": "<timestamp> (e.g. 1746736509954)",
"result": {
"activity": {
"id": "<string>",
"organizationId": "<string>",
"status": "<string>",
"type": "<string>",
"intent": {
"updateUserEmailIntent": {
"userId": "<string>",
"userEmail": "<string>",
"verificationToken": "<string>"
}
},
"result": {
"updateUserEmailResult": {
"userId": "<string>"
}
},
"votes": "<array>",
"fingerprint": "<string>",
"canApprove": "<boolean>",
"canReject": "<boolean>",
"createdAt": "<string>",
"updatedAt": "<string>"
}
}
}
}