PwlUser

Logs in a user by sending a magic link to the user's e-mail address. If the user does not exist, a new user is created (if the tenant allows user registration).

post
Body

Specifications of a User object.

tenantstring | nullableOptional

Name of the Tenant this user is associated to. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

userIDstring | nullableOptional

User ID. Unique and assigned by the system. Returned during Login and Get operations. Ignored in other cases.

userNamestring | nullableOptional

User name. Must be unique. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

eMailstring | nullableOptional

E-mail address. Required during Registration operations. Used during Update operations. May be used as an alternative to UserName during Login operations. Returned during Get operations. The address is checked via a verification code.

avatarURLstring | nullableOptional

URL of the avatar image representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLstring | nullableOptional

URL of the avatar 3D model representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLTypestring | nullableOptional

Additional information about the avatar 3D model URL, e.g. if it's a head-only, full-body avatar, custom model etc. Sample possible values are: readyplayerme: the avatar 3D URL points a half-body ReadyPlayerMe GLB model readyplayerme-full: the avatar 3D URL points a full-body ReadyPlayerMe GLB model customglb: the avatar 3D URL points to a custom GLB model

dontSendInvitationEmailboolean | nullableOptional

If True during a Creation operation, the automatic invitation e-mail is not sent, and the temporary password is returned as part of the operation response. Used during Creation operations. Ignored in other cases.

referralstring | nullableOptional

Optional referral URL from which the User reached the registration page.

couponCodestring | nullableOptional

Optional coupon code used by the User during Registration.

newsletterSubscribedboolean | nullableOptional

True if the e-mail address is subscribed to the newsletter. Used during Registration and Update operations. Returned during Get operations.

adminboolean | nullableOptional

True if the User is an administrator, i.e. can administer the tenant they are part of. Used during Creation and Update operations by a super administrator. Returned during Login and Get operations.

superAdminboolean | nullableOptional

True if the User is a super administrator, i.e. can administer all tenants. Returned during Login and Get operations. Ignored in other cases.

numMemoriinteger · int32 | nullableOptional

The current number of Memori objects belonging to this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxMemoriinteger · int32 | nullableOptional

Maximum number of Memori objects this User can create. If 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

monthSessionsinteger · int32 | nullableOptional

Number of sessions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User. Valid sessions are performed by a not Giver user with at least one request/response pair. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthDeepThoughtValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxFreeSessionsinteger · int32 | nullableOptional

Maximum number of free Memori sessions this User can open per month. if 0> it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

nonFreeSessionCostnumber · double | nullableOptional

The cost of each new session above the max free sessions threshold.

monthCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthDeepThoughtCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthImportedSizeinteger · int64 | nullableOptional

Number of characters imported in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

maxCompletionsinteger · int32 | nullableOptional

Maximum number of completions for this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

maxImportSizeinteger · int64 | nullableOptional

Maximum number of characters that can imported be by this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

payingboolean | nullableOptional

If True means this User has an actual payment contract in effect and non-free sessions (i.e. sessions above the max free session threshold) can be performed.

enableMemoriCreationboolean | nullableOptional

True if the User can create new Memori objects. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBoardOfExpertsboolean | nullableOptional

True if the User can access the Board of Experts feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDCMIntegrationboolean | nullableOptional

True if the User access the DCM integration feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBadgesboolean | nullableOptional

If True this User accepts DCM outcomes and consequently can receive badges in the Open Badge format. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDeepThoughtboolean | nullableOptional

True if the User can access the Deep Thought feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableVirtualSpacesboolean | nullableOptional

True if the User can access the Virtual Spaces feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

birthDatestring · date-time | nullableOptional

User date of birth. Necessary of age-restricted features, such as enabling completions or accessing NSFW content. Used during Registration and Update operations. Returned during Get operations.

ageinteger · int32Optional

Age computed from the birth date. Returned during Get operations. Ignored in other cases.

tnCAndPPAcceptedboolean | nullableOptional

Terms & Conditions and Privacy Policy acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False all operations that imply a change are blocked. Mandatory during Registration. Used during Update operations. Returned during Get operations.

tnCAndPPAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Terms & Conditions and Privacy Policy. Returned during Get operations. Ignored in other cases.

pAndCUAcceptedboolean | nullableOptional

Profiling & Commercial Use acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False features that require profiling and may imply commercial communication to the User (e.g. Deep Thought) are disabled. Used during Registration and Update operations. Returned during Get operations.

pAndCUAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Profiling & Commercial Use. Returned during Get operations. Ignored in other cases.

magicLinkURLstring | nullableOptional

Optional magic link URL. If not set a default one is used. The URL is invoked appending the Session ID at the end. Used during Login and Create operations. Ignored in other cases.

redirectTostring | nullableOptional

Optional RedirectTo. If set the user will be redirected to the specified page. Ignored in other cases.

creationTimestampstring · date-time | nullableOptional

Timestamp of creation. Returned during Get operations. Ignored in other cases.

lastChangeTimestampstring · date-time | nullableOptional

Timestamp of latest change. Returned during Get operations. Ignored in other cases.

Responses
200

Success

application/json
post
/api/v2/PwlLogin
POST /api/v2/PwlLogin HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 1125

{
  "tenant": "text",
  "userID": "text",
  "userName": "text",
  "eMail": "text",
  "avatarURL": "text",
  "avatar3DURL": "text",
  "avatar3DURLType": "text",
  "dontSendInvitationEmail": true,
  "referral": "text",
  "couponCode": "text",
  "newsletterSubscribed": true,
  "notificationPrefs": [
    {
      "chatLogExtractionPeriod": "text",
      "chatLogExtractionMinLines": 1,
      "memoriID": "text"
    }
  ],
  "admin": true,
  "superAdmin": true,
  "numMemori": 1,
  "maxMemori": 1,
  "monthSessions": 1,
  "monthValidSessions": 1,
  "monthDeepThoughtValidSessions": 1,
  "maxFreeSessions": 1,
  "nonFreeSessionCost": 1,
  "monthCompletions": 1,
  "monthDeepThoughtCompletions": 1,
  "monthImportedSize": 1,
  "maxCompletions": 1,
  "maxImportSize": 1,
  "paying": true,
  "enableMemoriCreation": true,
  "enableBoardOfExperts": true,
  "enableDCMIntegration": true,
  "enableBadges": true,
  "enableDeepThought": true,
  "enableVirtualSpaces": true,
  "birthDate": "2025-10-24T16:34:56.943Z",
  "age": 1,
  "tnCAndPPAccepted": true,
  "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "pAndCUAccepted": true,
  "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "magicLinkURL": "text",
  "redirectTo": "text",
  "creationTimestamp": "2025-10-24T16:34:56.943Z",
  "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
}
200

Success

{
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Logs in a user by a 4 digits verification code to the user's e-mail address. If the user does not exist, a new user is created (if the tenant allows user registration).

post
Body

Specifications of a User object.

tenantstring | nullableOptional

Name of the Tenant this user is associated to. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

userIDstring | nullableOptional

User ID. Unique and assigned by the system. Returned during Login and Get operations. Ignored in other cases.

userNamestring | nullableOptional

User name. Must be unique. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

eMailstring | nullableOptional

E-mail address. Required during Registration operations. Used during Update operations. May be used as an alternative to UserName during Login operations. Returned during Get operations. The address is checked via a verification code.

avatarURLstring | nullableOptional

URL of the avatar image representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLstring | nullableOptional

URL of the avatar 3D model representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLTypestring | nullableOptional

Additional information about the avatar 3D model URL, e.g. if it's a head-only, full-body avatar, custom model etc. Sample possible values are: readyplayerme: the avatar 3D URL points a half-body ReadyPlayerMe GLB model readyplayerme-full: the avatar 3D URL points a full-body ReadyPlayerMe GLB model customglb: the avatar 3D URL points to a custom GLB model

dontSendInvitationEmailboolean | nullableOptional

If True during a Creation operation, the automatic invitation e-mail is not sent, and the temporary password is returned as part of the operation response. Used during Creation operations. Ignored in other cases.

referralstring | nullableOptional

Optional referral URL from which the User reached the registration page.

couponCodestring | nullableOptional

Optional coupon code used by the User during Registration.

newsletterSubscribedboolean | nullableOptional

True if the e-mail address is subscribed to the newsletter. Used during Registration and Update operations. Returned during Get operations.

adminboolean | nullableOptional

True if the User is an administrator, i.e. can administer the tenant they are part of. Used during Creation and Update operations by a super administrator. Returned during Login and Get operations.

superAdminboolean | nullableOptional

True if the User is a super administrator, i.e. can administer all tenants. Returned during Login and Get operations. Ignored in other cases.

numMemoriinteger · int32 | nullableOptional

The current number of Memori objects belonging to this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxMemoriinteger · int32 | nullableOptional

Maximum number of Memori objects this User can create. If 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

monthSessionsinteger · int32 | nullableOptional

Number of sessions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User. Valid sessions are performed by a not Giver user with at least one request/response pair. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthDeepThoughtValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxFreeSessionsinteger · int32 | nullableOptional

Maximum number of free Memori sessions this User can open per month. if 0> it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

nonFreeSessionCostnumber · double | nullableOptional

The cost of each new session above the max free sessions threshold.

monthCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthDeepThoughtCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthImportedSizeinteger · int64 | nullableOptional

Number of characters imported in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

maxCompletionsinteger · int32 | nullableOptional

Maximum number of completions for this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

maxImportSizeinteger · int64 | nullableOptional

Maximum number of characters that can imported be by this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

payingboolean | nullableOptional

If True means this User has an actual payment contract in effect and non-free sessions (i.e. sessions above the max free session threshold) can be performed.

enableMemoriCreationboolean | nullableOptional

True if the User can create new Memori objects. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBoardOfExpertsboolean | nullableOptional

True if the User can access the Board of Experts feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDCMIntegrationboolean | nullableOptional

True if the User access the DCM integration feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBadgesboolean | nullableOptional

If True this User accepts DCM outcomes and consequently can receive badges in the Open Badge format. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDeepThoughtboolean | nullableOptional

True if the User can access the Deep Thought feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableVirtualSpacesboolean | nullableOptional

True if the User can access the Virtual Spaces feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

birthDatestring · date-time | nullableOptional

User date of birth. Necessary of age-restricted features, such as enabling completions or accessing NSFW content. Used during Registration and Update operations. Returned during Get operations.

ageinteger · int32Optional

Age computed from the birth date. Returned during Get operations. Ignored in other cases.

tnCAndPPAcceptedboolean | nullableOptional

Terms & Conditions and Privacy Policy acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False all operations that imply a change are blocked. Mandatory during Registration. Used during Update operations. Returned during Get operations.

tnCAndPPAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Terms & Conditions and Privacy Policy. Returned during Get operations. Ignored in other cases.

pAndCUAcceptedboolean | nullableOptional

Profiling & Commercial Use acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False features that require profiling and may imply commercial communication to the User (e.g. Deep Thought) are disabled. Used during Registration and Update operations. Returned during Get operations.

pAndCUAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Profiling & Commercial Use. Returned during Get operations. Ignored in other cases.

magicLinkURLstring | nullableOptional

Optional magic link URL. If not set a default one is used. The URL is invoked appending the Session ID at the end. Used during Login and Create operations. Ignored in other cases.

redirectTostring | nullableOptional

Optional RedirectTo. If set the user will be redirected to the specified page. Ignored in other cases.

creationTimestampstring · date-time | nullableOptional

Timestamp of creation. Returned during Get operations. Ignored in other cases.

lastChangeTimestampstring · date-time | nullableOptional

Timestamp of latest change. Returned during Get operations. Ignored in other cases.

Responses
200

Success

application/json
post
/api/v2/LoginWithOTP
POST /api/v2/LoginWithOTP HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 1125

{
  "tenant": "text",
  "userID": "text",
  "userName": "text",
  "eMail": "text",
  "avatarURL": "text",
  "avatar3DURL": "text",
  "avatar3DURLType": "text",
  "dontSendInvitationEmail": true,
  "referral": "text",
  "couponCode": "text",
  "newsletterSubscribed": true,
  "notificationPrefs": [
    {
      "chatLogExtractionPeriod": "text",
      "chatLogExtractionMinLines": 1,
      "memoriID": "text"
    }
  ],
  "admin": true,
  "superAdmin": true,
  "numMemori": 1,
  "maxMemori": 1,
  "monthSessions": 1,
  "monthValidSessions": 1,
  "monthDeepThoughtValidSessions": 1,
  "maxFreeSessions": 1,
  "nonFreeSessionCost": 1,
  "monthCompletions": 1,
  "monthDeepThoughtCompletions": 1,
  "monthImportedSize": 1,
  "maxCompletions": 1,
  "maxImportSize": 1,
  "paying": true,
  "enableMemoriCreation": true,
  "enableBoardOfExperts": true,
  "enableDCMIntegration": true,
  "enableBadges": true,
  "enableDeepThought": true,
  "enableVirtualSpaces": true,
  "birthDate": "2025-10-24T16:34:56.943Z",
  "age": 1,
  "tnCAndPPAccepted": true,
  "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "pAndCUAccepted": true,
  "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "magicLinkURL": "text",
  "redirectTo": "text",
  "creationTimestamp": "2025-10-24T16:34:56.943Z",
  "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
}
200

Success

{
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Refresh Temporary Session Token for a user just logged or created.

post
Body

Specifications to Refresh a Temporary Session.

sessionTokenstring | nullableOptional

SesisonToken. Unique and assigned by the system.

Responses
200

Success

application/json
post
/api/v2/RefreshTemporarySession
POST /api/v2/RefreshTemporarySession HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 23

{
  "sessionToken": "text"
}
200

Success

{
  "newSessionToken": "text",
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Validate OTP code for a user just logged or created.

post
Body

Specifications to Refresh a Temporary Session.

tenantstring | nullableOptional

The Tenant name. Required.

userNamestring | nullableOptional

The UserName. Required for already registered users when the Email is not provided.

eMailstring | nullableOptional

User EMail Required for new users and, for already registered users, when UserName is not provided.

otpCodestring | nullableOptional

OTP code to validate. Required.

Responses
200

Success

application/json
post
/api/v2/ValidateOTPCode
POST /api/v2/ValidateOTPCode HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 67

{
  "tenant": "text",
  "userName": "text",
  "eMail": "text",
  "otpCode": "text"
}
200

Success

{
  "newSessionToken": "text",
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Logs with a JWT token from a trusted application related to an already available user.

post
Body

Specifications for JWT-based login.

jwtTokenstring · min: 1Required

JWT token containing user information. Required for JWT login.

tenantstring · min: 1Required

Name of the Tenant to login to. Required for JWT login.

Responses
200

Success

application/json
post
/api/v2/LoginWithJWT
POST /api/v2/LoginWithJWT HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 35

{
  "jwtToken": "text",
  "tenant": "text"
}
200

Success

{
  "token": "text",
  "flowID": "text",
  "user": {
    "tenant": "text",
    "userID": "text",
    "userName": "text",
    "eMail": "text",
    "avatarURL": "text",
    "avatar3DURL": "text",
    "avatar3DURLType": "text",
    "dontSendInvitationEmail": true,
    "referral": "text",
    "couponCode": "text",
    "newsletterSubscribed": true,
    "notificationPrefs": [
      {
        "chatLogExtractionPeriod": "text",
        "chatLogExtractionMinLines": 1,
        "memoriID": "text"
      }
    ],
    "admin": true,
    "superAdmin": true,
    "numMemori": 1,
    "maxMemori": 1,
    "monthSessions": 1,
    "monthValidSessions": 1,
    "monthDeepThoughtValidSessions": 1,
    "maxFreeSessions": 1,
    "nonFreeSessionCost": 1,
    "monthCompletions": 1,
    "monthDeepThoughtCompletions": 1,
    "monthImportedSize": 1,
    "maxCompletions": 1,
    "maxImportSize": 1,
    "paying": true,
    "enableMemoriCreation": true,
    "enableBoardOfExperts": true,
    "enableDCMIntegration": true,
    "enableBadges": true,
    "enableDeepThought": true,
    "enableVirtualSpaces": true,
    "birthDate": "2025-10-24T16:34:56.943Z",
    "age": 1,
    "tnCAndPPAccepted": true,
    "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "pAndCUAccepted": true,
    "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "magicLinkURL": "text",
    "redirectTo": "text",
    "creationTimestamp": "2025-10-24T16:34:56.943Z",
    "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
  },
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Logs out the User.

post
Path parameters
strTokenstringRequired

The login token or API key

Responses
200

Success

application/json
post
/api/v2/PwlLogout/{strToken}
POST /api/v2/PwlLogout/{strToken} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Gets the details of the currently logged in User object.

get
Path parameters
strTokenstringRequired

The login token or API key

Responses
200

Success

application/json
get
/api/v2/PwlUser/{strToken}
GET /api/v2/PwlUser/{strToken} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "user": {
    "tenant": "text",
    "userID": "text",
    "userName": "text",
    "eMail": "text",
    "avatarURL": "text",
    "avatar3DURL": "text",
    "avatar3DURLType": "text",
    "dontSendInvitationEmail": true,
    "referral": "text",
    "couponCode": "text",
    "newsletterSubscribed": true,
    "notificationPrefs": [
      {
        "chatLogExtractionPeriod": "text",
        "chatLogExtractionMinLines": 1,
        "memoriID": "text"
      }
    ],
    "admin": true,
    "superAdmin": true,
    "numMemori": 1,
    "maxMemori": 1,
    "monthSessions": 1,
    "monthValidSessions": 1,
    "monthDeepThoughtValidSessions": 1,
    "maxFreeSessions": 1,
    "nonFreeSessionCost": 1,
    "monthCompletions": 1,
    "monthDeepThoughtCompletions": 1,
    "monthImportedSize": 1,
    "maxCompletions": 1,
    "maxImportSize": 1,
    "paying": true,
    "enableMemoriCreation": true,
    "enableBoardOfExperts": true,
    "enableDCMIntegration": true,
    "enableBadges": true,
    "enableDeepThought": true,
    "enableVirtualSpaces": true,
    "birthDate": "2025-10-24T16:34:56.943Z",
    "age": 1,
    "tnCAndPPAccepted": true,
    "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "pAndCUAccepted": true,
    "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "magicLinkURL": "text",
    "redirectTo": "text",
    "creationTimestamp": "2025-10-24T16:34:56.943Z",
    "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
  },
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Creates a new user.

post

Creation of User objects is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

Body

Specifications of a User object.

tenantstring | nullableOptional

Name of the Tenant this user is associated to. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

userIDstring | nullableOptional

User ID. Unique and assigned by the system. Returned during Login and Get operations. Ignored in other cases.

userNamestring | nullableOptional

User name. Must be unique. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

eMailstring | nullableOptional

E-mail address. Required during Registration operations. Used during Update operations. May be used as an alternative to UserName during Login operations. Returned during Get operations. The address is checked via a verification code.

avatarURLstring | nullableOptional

URL of the avatar image representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLstring | nullableOptional

URL of the avatar 3D model representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLTypestring | nullableOptional

Additional information about the avatar 3D model URL, e.g. if it's a head-only, full-body avatar, custom model etc. Sample possible values are: readyplayerme: the avatar 3D URL points a half-body ReadyPlayerMe GLB model readyplayerme-full: the avatar 3D URL points a full-body ReadyPlayerMe GLB model customglb: the avatar 3D URL points to a custom GLB model

dontSendInvitationEmailboolean | nullableOptional

If True during a Creation operation, the automatic invitation e-mail is not sent, and the temporary password is returned as part of the operation response. Used during Creation operations. Ignored in other cases.

referralstring | nullableOptional

Optional referral URL from which the User reached the registration page.

couponCodestring | nullableOptional

Optional coupon code used by the User during Registration.

newsletterSubscribedboolean | nullableOptional

True if the e-mail address is subscribed to the newsletter. Used during Registration and Update operations. Returned during Get operations.

adminboolean | nullableOptional

True if the User is an administrator, i.e. can administer the tenant they are part of. Used during Creation and Update operations by a super administrator. Returned during Login and Get operations.

superAdminboolean | nullableOptional

True if the User is a super administrator, i.e. can administer all tenants. Returned during Login and Get operations. Ignored in other cases.

numMemoriinteger · int32 | nullableOptional

The current number of Memori objects belonging to this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxMemoriinteger · int32 | nullableOptional

Maximum number of Memori objects this User can create. If 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

monthSessionsinteger · int32 | nullableOptional

Number of sessions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User. Valid sessions are performed by a not Giver user with at least one request/response pair. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthDeepThoughtValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxFreeSessionsinteger · int32 | nullableOptional

Maximum number of free Memori sessions this User can open per month. if 0> it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

nonFreeSessionCostnumber · double | nullableOptional

The cost of each new session above the max free sessions threshold.

monthCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthDeepThoughtCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthImportedSizeinteger · int64 | nullableOptional

Number of characters imported in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

maxCompletionsinteger · int32 | nullableOptional

Maximum number of completions for this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

maxImportSizeinteger · int64 | nullableOptional

Maximum number of characters that can imported be by this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

payingboolean | nullableOptional

If True means this User has an actual payment contract in effect and non-free sessions (i.e. sessions above the max free session threshold) can be performed.

enableMemoriCreationboolean | nullableOptional

True if the User can create new Memori objects. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBoardOfExpertsboolean | nullableOptional

True if the User can access the Board of Experts feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDCMIntegrationboolean | nullableOptional

True if the User access the DCM integration feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBadgesboolean | nullableOptional

If True this User accepts DCM outcomes and consequently can receive badges in the Open Badge format. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDeepThoughtboolean | nullableOptional

True if the User can access the Deep Thought feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableVirtualSpacesboolean | nullableOptional

True if the User can access the Virtual Spaces feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

birthDatestring · date-time | nullableOptional

User date of birth. Necessary of age-restricted features, such as enabling completions or accessing NSFW content. Used during Registration and Update operations. Returned during Get operations.

ageinteger · int32Optional

Age computed from the birth date. Returned during Get operations. Ignored in other cases.

tnCAndPPAcceptedboolean | nullableOptional

Terms & Conditions and Privacy Policy acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False all operations that imply a change are blocked. Mandatory during Registration. Used during Update operations. Returned during Get operations.

tnCAndPPAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Terms & Conditions and Privacy Policy. Returned during Get operations. Ignored in other cases.

pAndCUAcceptedboolean | nullableOptional

Profiling & Commercial Use acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False features that require profiling and may imply commercial communication to the User (e.g. Deep Thought) are disabled. Used during Registration and Update operations. Returned during Get operations.

pAndCUAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Profiling & Commercial Use. Returned during Get operations. Ignored in other cases.

magicLinkURLstring | nullableOptional

Optional magic link URL. If not set a default one is used. The URL is invoked appending the Session ID at the end. Used during Login and Create operations. Ignored in other cases.

redirectTostring | nullableOptional

Optional RedirectTo. If set the user will be redirected to the specified page. Ignored in other cases.

creationTimestampstring · date-time | nullableOptional

Timestamp of creation. Returned during Get operations. Ignored in other cases.

lastChangeTimestampstring · date-time | nullableOptional

Timestamp of latest change. Returned during Get operations. Ignored in other cases.

Responses
200

Success

application/json
post
/api/v2/PwlUser/{strToken}
POST /api/v2/PwlUser/{strToken} HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 1125

{
  "tenant": "text",
  "userID": "text",
  "userName": "text",
  "eMail": "text",
  "avatarURL": "text",
  "avatar3DURL": "text",
  "avatar3DURLType": "text",
  "dontSendInvitationEmail": true,
  "referral": "text",
  "couponCode": "text",
  "newsletterSubscribed": true,
  "notificationPrefs": [
    {
      "chatLogExtractionPeriod": "text",
      "chatLogExtractionMinLines": 1,
      "memoriID": "text"
    }
  ],
  "admin": true,
  "superAdmin": true,
  "numMemori": 1,
  "maxMemori": 1,
  "monthSessions": 1,
  "monthValidSessions": 1,
  "monthDeepThoughtValidSessions": 1,
  "maxFreeSessions": 1,
  "nonFreeSessionCost": 1,
  "monthCompletions": 1,
  "monthDeepThoughtCompletions": 1,
  "monthImportedSize": 1,
  "maxCompletions": 1,
  "maxImportSize": 1,
  "paying": true,
  "enableMemoriCreation": true,
  "enableBoardOfExperts": true,
  "enableDCMIntegration": true,
  "enableBadges": true,
  "enableDeepThought": true,
  "enableVirtualSpaces": true,
  "birthDate": "2025-10-24T16:34:56.943Z",
  "age": 1,
  "tnCAndPPAccepted": true,
  "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "pAndCUAccepted": true,
  "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "magicLinkURL": "text",
  "redirectTo": "text",
  "creationTimestamp": "2025-10-24T16:34:56.943Z",
  "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
}
200

Success

{
  "temporaryPassword": "text",
  "loginToken": "text",
  "user": {
    "tenant": "text",
    "userID": "text",
    "userName": "text",
    "eMail": "text",
    "avatarURL": "text",
    "avatar3DURL": "text",
    "avatar3DURLType": "text",
    "dontSendInvitationEmail": true,
    "referral": "text",
    "couponCode": "text",
    "newsletterSubscribed": true,
    "notificationPrefs": [
      {
        "chatLogExtractionPeriod": "text",
        "chatLogExtractionMinLines": 1,
        "memoriID": "text"
      }
    ],
    "admin": true,
    "superAdmin": true,
    "numMemori": 1,
    "maxMemori": 1,
    "monthSessions": 1,
    "monthValidSessions": 1,
    "monthDeepThoughtValidSessions": 1,
    "maxFreeSessions": 1,
    "nonFreeSessionCost": 1,
    "monthCompletions": 1,
    "monthDeepThoughtCompletions": 1,
    "monthImportedSize": 1,
    "maxCompletions": 1,
    "maxImportSize": 1,
    "paying": true,
    "enableMemoriCreation": true,
    "enableBoardOfExperts": true,
    "enableDCMIntegration": true,
    "enableBadges": true,
    "enableDeepThought": true,
    "enableVirtualSpaces": true,
    "birthDate": "2025-10-24T16:34:56.943Z",
    "age": 1,
    "tnCAndPPAccepted": true,
    "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "pAndCUAccepted": true,
    "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "magicLinkURL": "text",
    "redirectTo": "text",
    "creationTimestamp": "2025-10-24T16:34:56.943Z",
    "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
  },
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Gets the details of a User object.

get

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

strUserIDstringRequired

The User object ID

Responses
200

Success

application/json
get
/api/v2/PwlUser/{strToken}/{strUserID}
GET /api/v2/PwlUser/{strToken}/{strUserID} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "user": {
    "tenant": "text",
    "userID": "text",
    "userName": "text",
    "eMail": "text",
    "avatarURL": "text",
    "avatar3DURL": "text",
    "avatar3DURLType": "text",
    "dontSendInvitationEmail": true,
    "referral": "text",
    "couponCode": "text",
    "newsletterSubscribed": true,
    "notificationPrefs": [
      {
        "chatLogExtractionPeriod": "text",
        "chatLogExtractionMinLines": 1,
        "memoriID": "text"
      }
    ],
    "admin": true,
    "superAdmin": true,
    "numMemori": 1,
    "maxMemori": 1,
    "monthSessions": 1,
    "monthValidSessions": 1,
    "monthDeepThoughtValidSessions": 1,
    "maxFreeSessions": 1,
    "nonFreeSessionCost": 1,
    "monthCompletions": 1,
    "monthDeepThoughtCompletions": 1,
    "monthImportedSize": 1,
    "maxCompletions": 1,
    "maxImportSize": 1,
    "paying": true,
    "enableMemoriCreation": true,
    "enableBoardOfExperts": true,
    "enableDCMIntegration": true,
    "enableBadges": true,
    "enableDeepThought": true,
    "enableVirtualSpaces": true,
    "birthDate": "2025-10-24T16:34:56.943Z",
    "age": 1,
    "tnCAndPPAccepted": true,
    "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "pAndCUAccepted": true,
    "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "magicLinkURL": "text",
    "redirectTo": "text",
    "creationTimestamp": "2025-10-24T16:34:56.943Z",
    "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
  },
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Deletes a User object.

delete

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

strUserIDstringRequired

The User object ID

Responses
200

Success

application/json
delete
/api/v2/PwlUser/{strToken}/{strUserID}
DELETE /api/v2/PwlUser/{strToken}/{strUserID} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Updates the details of a User object (including its password).

patch

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

strUserIDstringRequired

The User object ID

Body

Specifications of a User object.

tenantstring | nullableOptional

Name of the Tenant this user is associated to. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

userIDstring | nullableOptional

User ID. Unique and assigned by the system. Returned during Login and Get operations. Ignored in other cases.

userNamestring | nullableOptional

User name. Must be unique. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

eMailstring | nullableOptional

E-mail address. Required during Registration operations. Used during Update operations. May be used as an alternative to UserName during Login operations. Returned during Get operations. The address is checked via a verification code.

avatarURLstring | nullableOptional

URL of the avatar image representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLstring | nullableOptional

URL of the avatar 3D model representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLTypestring | nullableOptional

Additional information about the avatar 3D model URL, e.g. if it's a head-only, full-body avatar, custom model etc. Sample possible values are: readyplayerme: the avatar 3D URL points a half-body ReadyPlayerMe GLB model readyplayerme-full: the avatar 3D URL points a full-body ReadyPlayerMe GLB model customglb: the avatar 3D URL points to a custom GLB model

dontSendInvitationEmailboolean | nullableOptional

If True during a Creation operation, the automatic invitation e-mail is not sent, and the temporary password is returned as part of the operation response. Used during Creation operations. Ignored in other cases.

referralstring | nullableOptional

Optional referral URL from which the User reached the registration page.

couponCodestring | nullableOptional

Optional coupon code used by the User during Registration.

newsletterSubscribedboolean | nullableOptional

True if the e-mail address is subscribed to the newsletter. Used during Registration and Update operations. Returned during Get operations.

adminboolean | nullableOptional

True if the User is an administrator, i.e. can administer the tenant they are part of. Used during Creation and Update operations by a super administrator. Returned during Login and Get operations.

superAdminboolean | nullableOptional

True if the User is a super administrator, i.e. can administer all tenants. Returned during Login and Get operations. Ignored in other cases.

numMemoriinteger · int32 | nullableOptional

The current number of Memori objects belonging to this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxMemoriinteger · int32 | nullableOptional

Maximum number of Memori objects this User can create. If 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

monthSessionsinteger · int32 | nullableOptional

Number of sessions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User. Valid sessions are performed by a not Giver user with at least one request/response pair. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthDeepThoughtValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxFreeSessionsinteger · int32 | nullableOptional

Maximum number of free Memori sessions this User can open per month. if 0> it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

nonFreeSessionCostnumber · double | nullableOptional

The cost of each new session above the max free sessions threshold.

monthCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthDeepThoughtCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthImportedSizeinteger · int64 | nullableOptional

Number of characters imported in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

maxCompletionsinteger · int32 | nullableOptional

Maximum number of completions for this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

maxImportSizeinteger · int64 | nullableOptional

Maximum number of characters that can imported be by this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

payingboolean | nullableOptional

If True means this User has an actual payment contract in effect and non-free sessions (i.e. sessions above the max free session threshold) can be performed.

enableMemoriCreationboolean | nullableOptional

True if the User can create new Memori objects. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBoardOfExpertsboolean | nullableOptional

True if the User can access the Board of Experts feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDCMIntegrationboolean | nullableOptional

True if the User access the DCM integration feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBadgesboolean | nullableOptional

If True this User accepts DCM outcomes and consequently can receive badges in the Open Badge format. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDeepThoughtboolean | nullableOptional

True if the User can access the Deep Thought feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableVirtualSpacesboolean | nullableOptional

True if the User can access the Virtual Spaces feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

birthDatestring · date-time | nullableOptional

User date of birth. Necessary of age-restricted features, such as enabling completions or accessing NSFW content. Used during Registration and Update operations. Returned during Get operations.

ageinteger · int32Optional

Age computed from the birth date. Returned during Get operations. Ignored in other cases.

tnCAndPPAcceptedboolean | nullableOptional

Terms & Conditions and Privacy Policy acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False all operations that imply a change are blocked. Mandatory during Registration. Used during Update operations. Returned during Get operations.

tnCAndPPAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Terms & Conditions and Privacy Policy. Returned during Get operations. Ignored in other cases.

pAndCUAcceptedboolean | nullableOptional

Profiling & Commercial Use acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False features that require profiling and may imply commercial communication to the User (e.g. Deep Thought) are disabled. Used during Registration and Update operations. Returned during Get operations.

pAndCUAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Profiling & Commercial Use. Returned during Get operations. Ignored in other cases.

magicLinkURLstring | nullableOptional

Optional magic link URL. If not set a default one is used. The URL is invoked appending the Session ID at the end. Used during Login and Create operations. Ignored in other cases.

redirectTostring | nullableOptional

Optional RedirectTo. If set the user will be redirected to the specified page. Ignored in other cases.

creationTimestampstring · date-time | nullableOptional

Timestamp of creation. Returned during Get operations. Ignored in other cases.

lastChangeTimestampstring · date-time | nullableOptional

Timestamp of latest change. Returned during Get operations. Ignored in other cases.

Responses
200

Success

application/json
patch
/api/v2/PwlUser/{strToken}/{strUserID}
PATCH /api/v2/PwlUser/{strToken}/{strUserID} HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 1125

{
  "tenant": "text",
  "userID": "text",
  "userName": "text",
  "eMail": "text",
  "avatarURL": "text",
  "avatar3DURL": "text",
  "avatar3DURLType": "text",
  "dontSendInvitationEmail": true,
  "referral": "text",
  "couponCode": "text",
  "newsletterSubscribed": true,
  "notificationPrefs": [
    {
      "chatLogExtractionPeriod": "text",
      "chatLogExtractionMinLines": 1,
      "memoriID": "text"
    }
  ],
  "admin": true,
  "superAdmin": true,
  "numMemori": 1,
  "maxMemori": 1,
  "monthSessions": 1,
  "monthValidSessions": 1,
  "monthDeepThoughtValidSessions": 1,
  "maxFreeSessions": 1,
  "nonFreeSessionCost": 1,
  "monthCompletions": 1,
  "monthDeepThoughtCompletions": 1,
  "monthImportedSize": 1,
  "maxCompletions": 1,
  "maxImportSize": 1,
  "paying": true,
  "enableMemoriCreation": true,
  "enableBoardOfExperts": true,
  "enableDCMIntegration": true,
  "enableBadges": true,
  "enableDeepThought": true,
  "enableVirtualSpaces": true,
  "birthDate": "2025-10-24T16:34:56.943Z",
  "age": 1,
  "tnCAndPPAccepted": true,
  "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "pAndCUAccepted": true,
  "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "magicLinkURL": "text",
  "redirectTo": "text",
  "creationTimestamp": "2025-10-24T16:34:56.943Z",
  "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
}
200

Success

{
  "user": {
    "tenant": "text",
    "userID": "text",
    "userName": "text",
    "eMail": "text",
    "avatarURL": "text",
    "avatar3DURL": "text",
    "avatar3DURLType": "text",
    "dontSendInvitationEmail": true,
    "referral": "text",
    "couponCode": "text",
    "newsletterSubscribed": true,
    "notificationPrefs": [
      {
        "chatLogExtractionPeriod": "text",
        "chatLogExtractionMinLines": 1,
        "memoriID": "text"
      }
    ],
    "admin": true,
    "superAdmin": true,
    "numMemori": 1,
    "maxMemori": 1,
    "monthSessions": 1,
    "monthValidSessions": 1,
    "monthDeepThoughtValidSessions": 1,
    "maxFreeSessions": 1,
    "nonFreeSessionCost": 1,
    "monthCompletions": 1,
    "monthDeepThoughtCompletions": 1,
    "monthImportedSize": 1,
    "maxCompletions": 1,
    "maxImportSize": 1,
    "paying": true,
    "enableMemoriCreation": true,
    "enableBoardOfExperts": true,
    "enableDCMIntegration": true,
    "enableBadges": true,
    "enableDeepThought": true,
    "enableVirtualSpaces": true,
    "birthDate": "2025-10-24T16:34:56.943Z",
    "age": 1,
    "tnCAndPPAccepted": true,
    "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "pAndCUAccepted": true,
    "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
    "magicLinkURL": "text",
    "redirectTo": "text",
    "creationTimestamp": "2025-10-24T16:34:56.943Z",
    "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
  },
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Gets a list of all the existing User objects.

get

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

Responses
200

Success

application/json
get
/api/v2/PwlUsers/{strToken}
GET /api/v2/PwlUsers/{strToken} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "users": [
    {
      "tenant": "text",
      "userID": "text",
      "userName": "text",
      "eMail": "text",
      "avatarURL": "text",
      "avatar3DURL": "text",
      "avatar3DURLType": "text",
      "dontSendInvitationEmail": true,
      "referral": "text",
      "couponCode": "text",
      "newsletterSubscribed": true,
      "notificationPrefs": [
        {
          "chatLogExtractionPeriod": "text",
          "chatLogExtractionMinLines": 1,
          "memoriID": "text"
        }
      ],
      "admin": true,
      "superAdmin": true,
      "numMemori": 1,
      "maxMemori": 1,
      "monthSessions": 1,
      "monthValidSessions": 1,
      "monthDeepThoughtValidSessions": 1,
      "maxFreeSessions": 1,
      "nonFreeSessionCost": 1,
      "monthCompletions": 1,
      "monthDeepThoughtCompletions": 1,
      "monthImportedSize": 1,
      "maxCompletions": 1,
      "maxImportSize": 1,
      "paying": true,
      "enableMemoriCreation": true,
      "enableBoardOfExperts": true,
      "enableDCMIntegration": true,
      "enableBadges": true,
      "enableDeepThought": true,
      "enableVirtualSpaces": true,
      "birthDate": "2025-10-24T16:34:56.943Z",
      "age": 1,
      "tnCAndPPAccepted": true,
      "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "pAndCUAccepted": true,
      "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "magicLinkURL": "text",
      "redirectTo": "text",
      "creationTimestamp": "2025-10-24T16:34:56.943Z",
      "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
    }
  ],
  "count": 1,
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Gets a paginated list of existing User objects.

get

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

frominteger · int32Required

The index of the starting user to get

howManyinteger · int32Required

How many users to get

Responses
200

Success

application/json
get
/api/v2/PwlUsers/{strToken}/{from}/{howMany}
GET /api/v2/PwlUsers/{strToken}/{from}/{howMany} HTTP/1.1
Host: 
Accept: */*
200

Success

{
  "users": [
    {
      "tenant": "text",
      "userID": "text",
      "userName": "text",
      "eMail": "text",
      "avatarURL": "text",
      "avatar3DURL": "text",
      "avatar3DURLType": "text",
      "dontSendInvitationEmail": true,
      "referral": "text",
      "couponCode": "text",
      "newsletterSubscribed": true,
      "notificationPrefs": [
        {
          "chatLogExtractionPeriod": "text",
          "chatLogExtractionMinLines": 1,
          "memoriID": "text"
        }
      ],
      "admin": true,
      "superAdmin": true,
      "numMemori": 1,
      "maxMemori": 1,
      "monthSessions": 1,
      "monthValidSessions": 1,
      "monthDeepThoughtValidSessions": 1,
      "maxFreeSessions": 1,
      "nonFreeSessionCost": 1,
      "monthCompletions": 1,
      "monthDeepThoughtCompletions": 1,
      "monthImportedSize": 1,
      "maxCompletions": 1,
      "maxImportSize": 1,
      "paying": true,
      "enableMemoriCreation": true,
      "enableBoardOfExperts": true,
      "enableDCMIntegration": true,
      "enableBadges": true,
      "enableDeepThought": true,
      "enableVirtualSpaces": true,
      "birthDate": "2025-10-24T16:34:56.943Z",
      "age": 1,
      "tnCAndPPAccepted": true,
      "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "pAndCUAccepted": true,
      "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "magicLinkURL": "text",
      "redirectTo": "text",
      "creationTimestamp": "2025-10-24T16:34:56.943Z",
      "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
    }
  ],
  "count": 1,
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Gets a filtered list of existing User objects.

post

Access to User objects different than the current logged in user is granted only to administrative users.

Path parameters
strTokenstringRequired

The login token or API key

Body
periodFromstring · date-time | nullableOptional

The starting date of the filter

periodTostring · date-time | nullableOptional

The end date of the filter

tenantNamestring | nullableOptional

The tenant name to filter the users.

textstring | nullableOptional

A search query to filter the users

numberOfResultsinteger · int32 | nullableOptional

Optional number of results. If omitted defaults to 5.

startFrominteger · int32 | nullableOptional

Optional initial result index, 0-based. If omitted defaults to 0. Used for Search, Filter Memories and Memory Hints. Ignored for Random picking.

orderBystring | nullableOptional

Optional order by field. If omitted defaults to CreationDate. Can be one of the following: CreationDateAscending: the results are ordered by creation date in ascending order. CreationDateDescending: the results are ordered by creation date in descending order. MemoriCountAscending: the results are ordered by Memori count in ascending order. MemoriCountDescending: the results are ordered by Memori count in descending order. MonthCompletionsAscending: the results are ordered by month completions in ascending order. MonthCompletionsDescending: the results are ordered by month completions in descending order. MonthImportSizeAscending: the results are ordered by month import size in ascending order. MonthImportSizeDescending: the results are ordered by month import size in descending order.

Responses
200

Success

application/json
post
/api/v2/FilterPwlUsers/{strToken}
POST /api/v2/FilterPwlUsers/{strToken} HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 164

{
  "periodFrom": "2025-10-24T16:34:56.943Z",
  "periodTo": "2025-10-24T16:34:56.943Z",
  "tenantName": "text",
  "text": "text",
  "numberOfResults": 1,
  "startFrom": 1,
  "orderBy": "text"
}
200

Success

{
  "users": [
    {
      "tenant": "text",
      "userID": "text",
      "userName": "text",
      "eMail": "text",
      "avatarURL": "text",
      "avatar3DURL": "text",
      "avatar3DURLType": "text",
      "dontSendInvitationEmail": true,
      "referral": "text",
      "couponCode": "text",
      "newsletterSubscribed": true,
      "notificationPrefs": [
        {
          "chatLogExtractionPeriod": "text",
          "chatLogExtractionMinLines": 1,
          "memoriID": "text"
        }
      ],
      "admin": true,
      "superAdmin": true,
      "numMemori": 1,
      "maxMemori": 1,
      "monthSessions": 1,
      "monthValidSessions": 1,
      "monthDeepThoughtValidSessions": 1,
      "maxFreeSessions": 1,
      "nonFreeSessionCost": 1,
      "monthCompletions": 1,
      "monthDeepThoughtCompletions": 1,
      "monthImportedSize": 1,
      "maxCompletions": 1,
      "maxImportSize": 1,
      "paying": true,
      "enableMemoriCreation": true,
      "enableBoardOfExperts": true,
      "enableDCMIntegration": true,
      "enableBadges": true,
      "enableDeepThought": true,
      "enableVirtualSpaces": true,
      "birthDate": "2025-10-24T16:34:56.943Z",
      "age": 1,
      "tnCAndPPAccepted": true,
      "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "pAndCUAccepted": true,
      "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
      "magicLinkURL": "text",
      "redirectTo": "text",
      "creationTimestamp": "2025-10-24T16:34:56.943Z",
      "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
    }
  ],
  "count": 1,
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Recovers a User's name and sends it to their configured e-mail.

post
Body

Specifications of a User object.

tenantstring | nullableOptional

Name of the Tenant this user is associated to. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

userIDstring | nullableOptional

User ID. Unique and assigned by the system. Returned during Login and Get operations. Ignored in other cases.

userNamestring | nullableOptional

User name. Must be unique. Required during Login and Registration operations. Returned during Get operations. Ignored in other cases.

eMailstring | nullableOptional

E-mail address. Required during Registration operations. Used during Update operations. May be used as an alternative to UserName during Login operations. Returned during Get operations. The address is checked via a verification code.

avatarURLstring | nullableOptional

URL of the avatar image representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLstring | nullableOptional

URL of the avatar 3D model representing the User. May be provided during Registration and Update operations. Returned during Login and Get operations.

avatar3DURLTypestring | nullableOptional

Additional information about the avatar 3D model URL, e.g. if it's a head-only, full-body avatar, custom model etc. Sample possible values are: readyplayerme: the avatar 3D URL points a half-body ReadyPlayerMe GLB model readyplayerme-full: the avatar 3D URL points a full-body ReadyPlayerMe GLB model customglb: the avatar 3D URL points to a custom GLB model

dontSendInvitationEmailboolean | nullableOptional

If True during a Creation operation, the automatic invitation e-mail is not sent, and the temporary password is returned as part of the operation response. Used during Creation operations. Ignored in other cases.

referralstring | nullableOptional

Optional referral URL from which the User reached the registration page.

couponCodestring | nullableOptional

Optional coupon code used by the User during Registration.

newsletterSubscribedboolean | nullableOptional

True if the e-mail address is subscribed to the newsletter. Used during Registration and Update operations. Returned during Get operations.

adminboolean | nullableOptional

True if the User is an administrator, i.e. can administer the tenant they are part of. Used during Creation and Update operations by a super administrator. Returned during Login and Get operations.

superAdminboolean | nullableOptional

True if the User is a super administrator, i.e. can administer all tenants. Returned during Login and Get operations. Ignored in other cases.

numMemoriinteger · int32 | nullableOptional

The current number of Memori objects belonging to this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxMemoriinteger · int32 | nullableOptional

Maximum number of Memori objects this User can create. If 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

monthSessionsinteger · int32 | nullableOptional

Number of sessions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User. Valid sessions are performed by a not Giver user with at least one request/response pair. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

monthDeepThoughtValidSessionsinteger · int32 | nullableOptional

Number of valid sessions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user themself.

maxFreeSessionsinteger · int32 | nullableOptional

Maximum number of free Memori sessions this User can open per month. if 0> it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

nonFreeSessionCostnumber · double | nullableOptional

The cost of each new session above the max free sessions threshold.

monthCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthDeepThoughtCompletionsinteger · int32 | nullableOptional

Number of completions in the current month for this User, with Deep Thought enabled. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

monthImportedSizeinteger · int64 | nullableOptional

Number of characters imported in the current month for this User. Returned during Get and Login operations. Ignored in other cases. Visible only to administrators and the user itself.

maxCompletionsinteger · int32 | nullableOptional

Maximum number of completions for this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

maxImportSizeinteger · int64 | nullableOptional

Maximum number of characters that can imported be by this User per month. if 0 it means unlimited. Used during Creation and Update operations by a super administrator. Returned during Get and Login operations.

payingboolean | nullableOptional

If True means this User has an actual payment contract in effect and non-free sessions (i.e. sessions above the max free session threshold) can be performed.

enableMemoriCreationboolean | nullableOptional

True if the User can create new Memori objects. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBoardOfExpertsboolean | nullableOptional

True if the User can access the Board of Experts feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDCMIntegrationboolean | nullableOptional

True if the User access the DCM integration feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableBadgesboolean | nullableOptional

If True this User accepts DCM outcomes and consequently can receive badges in the Open Badge format. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableDeepThoughtboolean | nullableOptional

True if the User can access the Deep Thought feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

enableVirtualSpacesboolean | nullableOptional

True if the User can access the Virtual Spaces feature. Used during Creation and Update operations by an administrator. Returned during Get and Login operations.

birthDatestring · date-time | nullableOptional

User date of birth. Necessary of age-restricted features, such as enabling completions or accessing NSFW content. Used during Registration and Update operations. Returned during Get operations.

ageinteger · int32Optional

Age computed from the birth date. Returned during Get operations. Ignored in other cases.

tnCAndPPAcceptedboolean | nullableOptional

Terms & Conditions and Privacy Policy acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False all operations that imply a change are blocked. Mandatory during Registration. Used during Update operations. Returned during Get operations.

tnCAndPPAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Terms & Conditions and Privacy Policy. Returned during Get operations. Ignored in other cases.

pAndCUAcceptedboolean | nullableOptional

Profiling & Commercial Use acceptance flag. May be reset to False in case of T. & C. and/or P. P. change. When False features that require profiling and may imply commercial communication to the User (e.g. Deep Thought) are disabled. Used during Registration and Update operations. Returned during Get operations.

pAndCUAcceptanceDatestring · date-time | nullableOptional

Date of acceptance of Profiling & Commercial Use. Returned during Get operations. Ignored in other cases.

magicLinkURLstring | nullableOptional

Optional magic link URL. If not set a default one is used. The URL is invoked appending the Session ID at the end. Used during Login and Create operations. Ignored in other cases.

redirectTostring | nullableOptional

Optional RedirectTo. If set the user will be redirected to the specified page. Ignored in other cases.

creationTimestampstring · date-time | nullableOptional

Timestamp of creation. Returned during Get operations. Ignored in other cases.

lastChangeTimestampstring · date-time | nullableOptional

Timestamp of latest change. Returned during Get operations. Ignored in other cases.

Responses
200

Success

application/json
post
/api/v2/RecoverPwlUserName
POST /api/v2/RecoverPwlUserName HTTP/1.1
Host: 
Content-Type: application/json
Accept: */*
Content-Length: 1125

{
  "tenant": "text",
  "userID": "text",
  "userName": "text",
  "eMail": "text",
  "avatarURL": "text",
  "avatar3DURL": "text",
  "avatar3DURLType": "text",
  "dontSendInvitationEmail": true,
  "referral": "text",
  "couponCode": "text",
  "newsletterSubscribed": true,
  "notificationPrefs": [
    {
      "chatLogExtractionPeriod": "text",
      "chatLogExtractionMinLines": 1,
      "memoriID": "text"
    }
  ],
  "admin": true,
  "superAdmin": true,
  "numMemori": 1,
  "maxMemori": 1,
  "monthSessions": 1,
  "monthValidSessions": 1,
  "monthDeepThoughtValidSessions": 1,
  "maxFreeSessions": 1,
  "nonFreeSessionCost": 1,
  "monthCompletions": 1,
  "monthDeepThoughtCompletions": 1,
  "monthImportedSize": 1,
  "maxCompletions": 1,
  "maxImportSize": 1,
  "paying": true,
  "enableMemoriCreation": true,
  "enableBoardOfExperts": true,
  "enableDCMIntegration": true,
  "enableBadges": true,
  "enableDeepThought": true,
  "enableVirtualSpaces": true,
  "birthDate": "2025-10-24T16:34:56.943Z",
  "age": 1,
  "tnCAndPPAccepted": true,
  "tnCAndPPAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "pAndCUAccepted": true,
  "pAndCUAcceptanceDate": "2025-10-24T16:34:56.943Z",
  "magicLinkURL": "text",
  "redirectTo": "text",
  "creationTimestamp": "2025-10-24T16:34:56.943Z",
  "lastChangeTimestamp": "2025-10-24T16:34:56.943Z"
}
200

Success

{
  "requestID": 1,
  "requestDateTime": "2025-10-24T16:34:56.943Z",
  "resultCode": 1,
  "resultMessage": "text"
}

Last updated