309 lines
6.9 KiB
JSON
309 lines
6.9 KiB
JSON
{
|
|
"Title": "Users",
|
|
"Interface": "User",
|
|
"Struct": [
|
|
{
|
|
"imports": [
|
|
"github.com/cortezaproject/corteza-server/system/types"
|
|
]
|
|
}
|
|
],
|
|
"Parameters": null,
|
|
"Protocol": "",
|
|
"Authentication": [
|
|
"Client ID",
|
|
"Session ID"
|
|
],
|
|
"Path": "/users",
|
|
"APIs": [
|
|
{
|
|
"Name": "list",
|
|
"Method": "GET",
|
|
"Title": "Search users (Directory)",
|
|
"Path": "/",
|
|
"Parameters": {
|
|
"get": [
|
|
{
|
|
"name": "query",
|
|
"required": false,
|
|
"title": "Search query to match against users",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "username",
|
|
"required": false,
|
|
"title": "Search username to match against users",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "email",
|
|
"required": false,
|
|
"title": "Search email to match against users",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "kind",
|
|
"required": false,
|
|
"title": "Kind (normal, bot)",
|
|
"type": "types.UserKind"
|
|
},
|
|
{
|
|
"name": "incDeleted",
|
|
"required": false,
|
|
"title": "Include deleted users (requires 'access' permission)",
|
|
"type": "bool"
|
|
},
|
|
{
|
|
"name": "incSuspended",
|
|
"required": false,
|
|
"title": "Include suspended users (requires 'access' permission)",
|
|
"type": "bool"
|
|
},
|
|
{
|
|
"name": "sort",
|
|
"required": false,
|
|
"title": "Sort by (createdAt, updatedAt, deletedAt, suspendedAt, email, username, userID)",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "page",
|
|
"required": false,
|
|
"title": "Page number (0 based)",
|
|
"type": "uint"
|
|
},
|
|
{
|
|
"name": "perPage",
|
|
"required": false,
|
|
"title": "Returned items per page",
|
|
"type": "uint"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "create",
|
|
"Method": "POST",
|
|
"Title": "Create user",
|
|
"Path": "/",
|
|
"Parameters": {
|
|
"post": [
|
|
{
|
|
"name": "email",
|
|
"required": true,
|
|
"title": "Email",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "name",
|
|
"required": false,
|
|
"title": "Name",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "handle",
|
|
"required": false,
|
|
"title": "Handle",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "kind",
|
|
"required": false,
|
|
"title": "Kind (normal, bot)",
|
|
"type": "types.UserKind"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "update",
|
|
"Method": "PUT",
|
|
"Title": "Update user details",
|
|
"Path": "/{userID}",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
],
|
|
"post": [
|
|
{
|
|
"name": "email",
|
|
"required": true,
|
|
"title": "Email",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "name",
|
|
"required": true,
|
|
"title": "Name",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "handle",
|
|
"required": false,
|
|
"title": "Handle",
|
|
"type": "string"
|
|
},
|
|
{
|
|
"name": "kind",
|
|
"required": false,
|
|
"title": "Kind (normal, bot)",
|
|
"type": "types.UserKind"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "read",
|
|
"Method": "GET",
|
|
"Title": "Read user details",
|
|
"Path": "/{userID}",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "delete",
|
|
"Method": "DELETE",
|
|
"Title": "Remove user",
|
|
"Path": "/{userID}",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "suspend",
|
|
"Method": "POST",
|
|
"Title": "Suspend user",
|
|
"Path": "/{userID}/suspend",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "unsuspend",
|
|
"Method": "POST",
|
|
"Title": "Unsuspend user",
|
|
"Path": "/{userID}/unsuspend",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "setPassword",
|
|
"Method": "POST",
|
|
"Title": "Set's or changes user's password",
|
|
"Path": "/{userID}/password",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
],
|
|
"post": [
|
|
{
|
|
"name": "password",
|
|
"required": true,
|
|
"sensitive": true,
|
|
"title": "New password",
|
|
"type": "string"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "membershipList",
|
|
"Method": "GET",
|
|
"Title": "Add member to a role",
|
|
"Path": "/{userID}/membership",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "membershipAdd",
|
|
"Method": "POST",
|
|
"Title": "Add role to a user",
|
|
"Path": "/{userID}/membership/{roleID}",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "roleID",
|
|
"required": true,
|
|
"title": "Role ID",
|
|
"type": "uint64"
|
|
},
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"Name": "membershipRemove",
|
|
"Method": "DELETE",
|
|
"Title": "Remove role from a user",
|
|
"Path": "/{userID}/membership/{roleID}",
|
|
"Parameters": {
|
|
"path": [
|
|
{
|
|
"name": "roleID",
|
|
"required": true,
|
|
"title": "Role ID",
|
|
"type": "uint64"
|
|
},
|
|
{
|
|
"name": "userID",
|
|
"required": true,
|
|
"title": "User ID",
|
|
"type": "uint64"
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
} |