3
0
corteza/api/system/spec/user.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"
}
]
}
}
]
}