Type user endpoints
This commit is contained in:
parent
edbcc1f764
commit
170d45320b
|
@ -35,7 +35,24 @@ export function createUsersStore() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function invite(payload) {
|
async function invite(payload) {
|
||||||
return API.inviteUsers(payload)
|
const users = payload.map(user => {
|
||||||
|
let builder = undefined
|
||||||
|
if (user.admin || user.builder) {
|
||||||
|
builder = { global: true }
|
||||||
|
} else if (user.creator) {
|
||||||
|
builder = { creator: true }
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
email: user.email,
|
||||||
|
userInfo: {
|
||||||
|
admin: user.admin ? { global: true } : undefined,
|
||||||
|
builder,
|
||||||
|
userGroups: user.groups,
|
||||||
|
roles: user.apps ? user.apps : undefined,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return API.inviteUsers(users)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function removeInvites(payload) {
|
async function removeInvites(payload) {
|
||||||
|
@ -93,10 +110,7 @@ export function createUsersStore() {
|
||||||
|
|
||||||
return body
|
return body
|
||||||
})
|
})
|
||||||
const response = await API.createUsers({
|
const response = await API.createUsers(mappedUsers, data.groups)
|
||||||
users: mappedUsers,
|
|
||||||
groups: data.groups,
|
|
||||||
})
|
|
||||||
|
|
||||||
// re-search from first page
|
// re-search from first page
|
||||||
await search()
|
await search()
|
||||||
|
@ -108,8 +122,8 @@ export function createUsersStore() {
|
||||||
update(users => users.filter(user => user._id !== id))
|
update(users => users.filter(user => user._id !== id))
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getUserCountByApp({ appId }) {
|
async function getUserCountByApp(appId) {
|
||||||
return await API.getUserCountByApp({ appId })
|
return await API.getUserCountByApp(appId)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function bulkDelete(users) {
|
async function bulkDelete(users) {
|
||||||
|
@ -121,11 +135,11 @@ export function createUsersStore() {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function addAppBuilder(userId, appId) {
|
async function addAppBuilder(userId, appId) {
|
||||||
return await API.addAppBuilder({ userId, appId })
|
return await API.addAppBuilder(userId, appId)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function removeAppBuilder(userId, appId) {
|
async function removeAppBuilder(userId, appId) {
|
||||||
return await API.removeAppBuilder({ userId, appId })
|
return await API.removeAppBuilder(userId, appId)
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getAccountHolder() {
|
async function getAccountHolder() {
|
||||||
|
|
|
@ -29,6 +29,7 @@ import { ScreenEndpoints } from "./screens"
|
||||||
import { SelfEndpoints } from "./self"
|
import { SelfEndpoints } from "./self"
|
||||||
import { TableEndpoints } from "./tables"
|
import { TableEndpoints } from "./tables"
|
||||||
import { TemplateEndpoints } from "./templates"
|
import { TemplateEndpoints } from "./templates"
|
||||||
|
import { UserEndpoints } from "./user"
|
||||||
|
|
||||||
export enum HTTPMethod {
|
export enum HTTPMethod {
|
||||||
POST = "POST",
|
POST = "POST",
|
||||||
|
@ -128,4 +129,5 @@ export type APIClient = BaseAPIClient &
|
||||||
ScreenEndpoints &
|
ScreenEndpoints &
|
||||||
SelfEndpoints &
|
SelfEndpoints &
|
||||||
TableEndpoints &
|
TableEndpoints &
|
||||||
TemplateEndpoints & { rowActions: RowActionEndpoints; [key: string]: any }
|
TemplateEndpoints &
|
||||||
|
UserEndpoints & { rowActions: RowActionEndpoints; [key: string]: any }
|
||||||
|
|
|
@ -1,4 +1,63 @@
|
||||||
export const buildUserEndpoints = API => ({
|
import {
|
||||||
|
AcceptUserInviteRequest,
|
||||||
|
AcceptUserInviteResponse,
|
||||||
|
AccountMetadata,
|
||||||
|
BulkUserCreated,
|
||||||
|
BulkUserDeleted,
|
||||||
|
BulkUserRequest,
|
||||||
|
BulkUserResponse,
|
||||||
|
CreateAdminUserRequest,
|
||||||
|
CreateAdminUserResponse,
|
||||||
|
DeleteInviteUsersRequest,
|
||||||
|
InviteUsersRequest,
|
||||||
|
InviteUsersResponse,
|
||||||
|
SaveUserResponse,
|
||||||
|
SearchUsersRequest,
|
||||||
|
UpdateSelfRequest,
|
||||||
|
User,
|
||||||
|
} from "@budibase/types"
|
||||||
|
import { BaseAPIClient } from "./types"
|
||||||
|
|
||||||
|
export interface UserEndpoints {
|
||||||
|
getUsers: () => Promise<User[]>
|
||||||
|
getUser: (userId: string) => Promise<User>
|
||||||
|
updateOwnMetadata: (metadata: UpdateSelfRequest) => Promise<void>
|
||||||
|
createAdminUser: (
|
||||||
|
user: CreateAdminUserRequest
|
||||||
|
) => Promise<CreateAdminUserResponse>
|
||||||
|
saveUser: (user: User) => Promise<SaveUserResponse>
|
||||||
|
deleteUser: (userId: string) => Promise<{ message: string }>
|
||||||
|
deleteUsers: (
|
||||||
|
users: Array<{
|
||||||
|
userId: string
|
||||||
|
email: string
|
||||||
|
}>
|
||||||
|
) => Promise<BulkUserDeleted | null>
|
||||||
|
onboardUsers: (data: InviteUsersRequest) => Promise<InviteUsersResponse>
|
||||||
|
getUserInvite: (code: string) => Promise<{ email: string }>
|
||||||
|
getUserInvites: () => Promise<any[]>
|
||||||
|
inviteUsers: (users: InviteUsersRequest) => Promise<InviteUsersResponse>
|
||||||
|
removeUserInvites: (
|
||||||
|
data: DeleteInviteUsersRequest
|
||||||
|
) => Promise<{ message: string }>
|
||||||
|
acceptInvite: (
|
||||||
|
data: AcceptUserInviteRequest
|
||||||
|
) => Promise<AcceptUserInviteResponse>
|
||||||
|
getUserCountByApp: (appId: string) => Promise<number>
|
||||||
|
addAppBuilder: (userId: string, appId: string) => Promise<{ message: string }>
|
||||||
|
removeAppBuilder: (
|
||||||
|
userId: string,
|
||||||
|
appId: string
|
||||||
|
) => Promise<{ message: string }>
|
||||||
|
getAccountHolder: () => Promise<AccountMetadata | null>
|
||||||
|
|
||||||
|
// Missing request or response types
|
||||||
|
searchUsers: (data: SearchUsersRequest) => Promise<any>
|
||||||
|
createUsers: (users: User[], groups: any[]) => Promise<BulkUserCreated | null>
|
||||||
|
updateUserInvite: (data: any) => Promise<any>
|
||||||
|
}
|
||||||
|
|
||||||
|
export const buildUserEndpoints = (API: BaseAPIClient): UserEndpoints => ({
|
||||||
/**
|
/**
|
||||||
* Gets a list of users in the current tenant.
|
* Gets a list of users in the current tenant.
|
||||||
*/
|
*/
|
||||||
|
@ -9,33 +68,12 @@ export const buildUserEndpoints = API => ({
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets a list of users in the current tenant.
|
* Searches a list of users in the current tenant.
|
||||||
* @param {string} bookmark The page to retrieve
|
|
||||||
* @param {object} query search filters for lookup by user (all operators not supported).
|
|
||||||
* @param {string} appId Facilitate app/role based user searching
|
|
||||||
* @param {boolean} paginate Allow the disabling of pagination
|
|
||||||
* @param {number} limit How many users to retrieve in a single search
|
|
||||||
*/
|
*/
|
||||||
searchUsers: async ({ paginate, bookmark, query, appId, limit } = {}) => {
|
searchUsers: async data => {
|
||||||
const opts = {}
|
return await API.post<SearchUsersRequest, any>({
|
||||||
if (bookmark) {
|
|
||||||
opts.bookmark = bookmark
|
|
||||||
}
|
|
||||||
if (query) {
|
|
||||||
opts.query = query
|
|
||||||
}
|
|
||||||
if (appId) {
|
|
||||||
opts.appId = appId
|
|
||||||
}
|
|
||||||
if (typeof paginate === "boolean") {
|
|
||||||
opts.paginate = paginate
|
|
||||||
}
|
|
||||||
if (limit) {
|
|
||||||
opts.limit = limit
|
|
||||||
}
|
|
||||||
return await API.post({
|
|
||||||
url: `/api/global/users/search`,
|
url: `/api/global/users/search`,
|
||||||
body: opts,
|
body: data,
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -48,17 +86,6 @@ export const buildUserEndpoints = API => ({
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a user for an app.
|
|
||||||
* @param user the user to create
|
|
||||||
*/
|
|
||||||
createAppUser: async user => {
|
|
||||||
return await API.post({
|
|
||||||
url: "/api/users/metadata",
|
|
||||||
body: user,
|
|
||||||
})
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Updates the current user metadata.
|
* Updates the current user metadata.
|
||||||
* @param metadata the metadata to save
|
* @param metadata the metadata to save
|
||||||
|
@ -72,12 +99,12 @@ export const buildUserEndpoints = API => ({
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an admin user.
|
* Creates an admin user.
|
||||||
* @param adminUser the admin user to create
|
* @param user the admin user to create
|
||||||
*/
|
*/
|
||||||
createAdminUser: async adminUser => {
|
createAdminUser: async user => {
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: "/api/global/users/init",
|
url: "/api/global/users/init",
|
||||||
body: adminUser,
|
body: user,
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -97,8 +124,8 @@ export const buildUserEndpoints = API => ({
|
||||||
* @param users the array of user objects to create
|
* @param users the array of user objects to create
|
||||||
* @param groups the array of group ids to add all users to
|
* @param groups the array of group ids to add all users to
|
||||||
*/
|
*/
|
||||||
createUsers: async ({ users, groups }) => {
|
createUsers: async (users, groups) => {
|
||||||
const res = await API.post({
|
const res = await API.post<BulkUserRequest, BulkUserResponse>({
|
||||||
url: "/api/global/users/bulk",
|
url: "/api/global/users/bulk",
|
||||||
body: {
|
body: {
|
||||||
create: {
|
create: {
|
||||||
|
@ -125,7 +152,7 @@ export const buildUserEndpoints = API => ({
|
||||||
* @param users the ID/email pair of the user to delete
|
* @param users the ID/email pair of the user to delete
|
||||||
*/
|
*/
|
||||||
deleteUsers: async users => {
|
deleteUsers: async users => {
|
||||||
const res = await API.post({
|
const res = await API.post<BulkUserRequest, BulkUserResponse>({
|
||||||
url: `/api/global/users/bulk`,
|
url: `/api/global/users/bulk`,
|
||||||
body: {
|
body: {
|
||||||
delete: {
|
delete: {
|
||||||
|
@ -137,39 +164,12 @@ export const buildUserEndpoints = API => ({
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Invites a user to the current tenant.
|
* Onboards multiple users
|
||||||
* @param email the email address to send the invitation to
|
|
||||||
* @param builder whether the user should be a global builder
|
|
||||||
* @param admin whether the user should be a global admin
|
|
||||||
*/
|
*/
|
||||||
inviteUser: async ({ email, builder, admin, apps }) => {
|
onboardUsers: async data => {
|
||||||
return await API.post({
|
|
||||||
url: "/api/global/users/invite",
|
|
||||||
body: {
|
|
||||||
email,
|
|
||||||
userInfo: {
|
|
||||||
admin: admin?.global ? { global: true } : undefined,
|
|
||||||
builder: builder?.global ? { global: true } : undefined,
|
|
||||||
apps: apps ? apps : undefined,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
},
|
|
||||||
|
|
||||||
onboardUsers: async payload => {
|
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: "/api/global/users/onboard",
|
url: "/api/global/users/onboard",
|
||||||
body: payload.map(invite => {
|
body: data,
|
||||||
const { email, admin, builder, apps } = invite
|
|
||||||
return {
|
|
||||||
email,
|
|
||||||
userInfo: {
|
|
||||||
admin,
|
|
||||||
builder,
|
|
||||||
apps: apps ? apps : undefined,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -214,72 +214,46 @@ export const buildUserEndpoints = API => ({
|
||||||
inviteUsers: async users => {
|
inviteUsers: async users => {
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: "/api/global/users/multi/invite",
|
url: "/api/global/users/multi/invite",
|
||||||
body: users.map(user => {
|
body: users,
|
||||||
let builder = undefined
|
|
||||||
if (user.admin || user.builder) {
|
|
||||||
builder = { global: true }
|
|
||||||
} else if (user.creator) {
|
|
||||||
builder = { creator: true }
|
|
||||||
}
|
|
||||||
return {
|
|
||||||
email: user.email,
|
|
||||||
userInfo: {
|
|
||||||
admin: user.admin ? { global: true } : undefined,
|
|
||||||
builder,
|
|
||||||
userGroups: user.groups,
|
|
||||||
roles: user.apps ? user.apps : undefined,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes multiple user invites from Redis cache
|
* Removes multiple user invites from Redis cache
|
||||||
*/
|
*/
|
||||||
removeUserInvites: async inviteCodes => {
|
removeUserInvites: async data => {
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: "/api/global/users/multi/invite/delete",
|
url: "/api/global/users/multi/invite/delete",
|
||||||
body: inviteCodes,
|
body: data,
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accepts an invite to join the platform and creates a user.
|
* Accepts an invite to join the platform and creates a user.
|
||||||
* @param inviteCode the invite code sent in the email
|
|
||||||
* @param password the password for the newly created user
|
|
||||||
* @param firstName the first name of the new user
|
|
||||||
* @param lastName the last name of the new user
|
|
||||||
*/
|
*/
|
||||||
acceptInvite: async ({ inviteCode, password, firstName, lastName }) => {
|
acceptInvite: async data => {
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: "/api/global/users/invite/accept",
|
url: "/api/global/users/invite/accept",
|
||||||
body: {
|
body: data,
|
||||||
inviteCode,
|
|
||||||
password,
|
|
||||||
firstName,
|
|
||||||
lastName,
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Accepts an invite to join the platform and creates a user.
|
* Counts the number of users in an app
|
||||||
* @param inviteCode the invite code sent in the email
|
|
||||||
* @param password the password for the newly created user
|
|
||||||
*/
|
*/
|
||||||
getUserCountByApp: async ({ appId }) => {
|
getUserCountByApp: async appId => {
|
||||||
return await API.get({
|
const res = await API.get<{ userCount: number }>({
|
||||||
url: `/api/global/users/count/${appId}`,
|
url: `/api/global/users/count/${appId}`,
|
||||||
})
|
})
|
||||||
|
return res.userCount
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a per app builder to the selected app
|
* Adds a per app builder to the selected app
|
||||||
* @param appId the applications id
|
|
||||||
* @param userId The id of the user to add as a builder
|
* @param userId The id of the user to add as a builder
|
||||||
|
* @param appId the applications id
|
||||||
*/
|
*/
|
||||||
addAppBuilder: async ({ userId, appId }) => {
|
addAppBuilder: async (userId, appId) => {
|
||||||
return await API.post({
|
return await API.post({
|
||||||
url: `/api/global/users/${userId}/app/${appId}/builder`,
|
url: `/api/global/users/${userId}/app/${appId}/builder`,
|
||||||
})
|
})
|
||||||
|
@ -287,15 +261,18 @@ export const buildUserEndpoints = API => ({
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes a per app builder to the selected app
|
* Removes a per app builder to the selected app
|
||||||
* @param appId the applications id
|
|
||||||
* @param userId The id of the user to remove as a builder
|
* @param userId The id of the user to remove as a builder
|
||||||
|
* @param appId the applications id
|
||||||
*/
|
*/
|
||||||
removeAppBuilder: async ({ userId, appId }) => {
|
removeAppBuilder: async (userId, appId) => {
|
||||||
return await API.delete({
|
return await API.delete({
|
||||||
url: `/api/global/users/${userId}/app/${appId}/builder`,
|
url: `/api/global/users/${userId}/app/${appId}/builder`,
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the account holder of the current tenant
|
||||||
|
*/
|
||||||
getAccountHolder: async () => {
|
getAccountHolder: async () => {
|
||||||
return await API.get({
|
return await API.get({
|
||||||
url: `/api/global/users/accountholder`,
|
url: `/api/global/users/accountholder`,
|
Loading…
Reference in New Issue