Type user endpoints

This commit is contained in:
Andrew Kingston 2024-12-04 11:32:33 +00:00
parent edbcc1f764
commit 170d45320b
No known key found for this signature in database
3 changed files with 115 additions and 122 deletions

View File

@ -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() {

View File

@ -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 }

View File

@ -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`,