Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion KeeperSdk/src/folders/addFolder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { InMemoryStorage } from '../storage/InMemoryStorage'
import { isBoolean, KeeperSdkError, extractErrorMessage } from '../utils'
import { listFolder } from './listFolder'
import { tryResolvePath, splitPathComponents, type VaultFolderSession } from './changeDirectory'
import { FolderKind, FolderResultStatus, ParentFolderKind } from './folderHelpers'
import { FolderKind, FolderResultStatus, ParentFolderKind, validateFolderName } from './folderHelpers'

type NewFolderKind = FolderKind

Expand Down Expand Up @@ -134,6 +134,7 @@ export async function addFolder(auth: Auth, storage: InMemoryStorage, input: Add
if (!name) {
throw new KeeperSdkError('Folder name cannot be empty.', 'folder_name_required')
}
validateFolderName(name)

const parentUid = input.parentUid === undefined || input.parentUid === '' ? null : input.parentUid
const parent = resolveParentContext(storage, parentUid)
Expand Down
10 changes: 9 additions & 1 deletion KeeperSdk/src/folders/folderHelpers.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,14 @@
import type { DSharedFolder, DSharedFolderFolder, DUserFolder } from '@keeper-security/keeperapi'
import type { InMemoryStorage } from '../storage/InMemoryStorage'
import { escapeRegExp } from '../utils'
import { escapeRegExp, KeeperSdkError } from '../utils'

export const MAX_FOLDER_NAME_LENGTH = 255

export function validateFolderName(name: string): void {
if (name.length > MAX_FOLDER_NAME_LENGTH) {
throw new KeeperSdkError(`Folder name exceeds ${MAX_FOLDER_NAME_LENGTH} characters.`, 'folder_name_too_long')
}
}

export enum FolderKind {
UserFolder = 'user_folder',
Expand Down
3 changes: 2 additions & 1 deletion KeeperSdk/src/folders/updateFolder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ import type { DSharedFolder, DSharedFolderFolder, DUserFolder } from '@keeper-se
import { InMemoryStorage } from '../storage/InMemoryStorage'
import { anyIsBoolean, isBoolean, isObject, KeeperSdkError, extractErrorMessage } from '../utils'
import { resolveSingleFolder, type VaultFolderSession } from './changeDirectory'
import { FolderKind, FolderResultStatus } from './folderHelpers'
import { FolderKind, FolderResultStatus, validateFolderName } from './folderHelpers'

export type UpdateFolderInput = {
folderUid: string
Expand Down Expand Up @@ -79,6 +79,7 @@ export async function updateFolder(
}

const trimmedName = input.folderName?.trim() || ''
if (trimmedName) validateFolderName(trimmedName)

const hasPermissionUpdate = anyIsBoolean(
input.manageUsers,
Expand Down
27 changes: 24 additions & 3 deletions KeeperSdk/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -311,6 +311,15 @@ export {
DeleteUserStatus,
} from './users/deleteUser'

export {
actionUsers,
formatUserActionResult,
renderUserActionAsciiTable,
UserAction,
UserActionStatus,
UserActionSkipReason,
} from './users/actionUser'

export type {
UserColumnInput,
ListUsersOptions,
Expand All @@ -336,11 +345,23 @@ export type {
DeleteUserItemResult,
DeleteUserResult,
FormattedDeleteUserTable,
UserActionInput,
UserActionItemResult,
UserActionResult,
FormattedUserActionTable,
AliasUserInput,
AliasUserResult,
FormattedUserStatus,
} from './users/userTypes'

export { UserManager } from './users/UserManager'
export { EnterpriseUserStatus } from './users/userTypes'

export { Auth, KeeperEnvironment, syncDown, Authentication } from '@keeper-security/keeperapi'
export {
aliasUser,
AliasOperation,
} from './users/aliasUser'

export { UserManager } from './users/UserManager'

export type {
DRecord,
Expand All @@ -357,4 +378,4 @@ export type {
AuthUI3,
KeeperError,
LoginError,
} from '@keeper-security/keeperapi'
} from '@keeper-security/keeperapi'
25 changes: 24 additions & 1 deletion KeeperSdk/src/users/UserManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ import { KeeperSdkError, ResultCodes } from '../utils'
import { addUsers, formatAddUserResult, renderAddUserAsciiTable } from './addUser'
import { updateUsers, formatUpdateUserResult, renderUpdateUserAsciiTable } from './updateUser'
import { deleteUsers, formatDeleteUserResult, renderDeleteUserAsciiTable } from './deleteUser'
import { actionUsers, formatUserActionResult, renderUserActionAsciiTable } from './actionUser'
import { aliasUser } from './aliasUser'
import { listUsers, formatUsersTable, renderUsersAsciiTable } from './listUsers'
import { viewUser, formatUserView, userViewTable } from './viewUser'
import type {
Expand All @@ -24,6 +26,11 @@ import type {
DeleteUserInput,
DeleteUserResult,
FormattedDeleteUserTable,
UserActionInput,
UserActionResult,
FormattedUserActionTable,
AliasUserInput,
AliasUserResult,
} from './userTypes'

export type AuthProvider = () => Auth
Expand Down Expand Up @@ -95,11 +102,27 @@ export class UserManager {
return renderDeleteUserAsciiTable(table)
}

public async actionUsers(input: UserActionInput): Promise<UserActionResult> {
return actionUsers(this.requireAuth(), input)
}

public formatUserActionResult(result: UserActionResult): FormattedUserActionTable {
return formatUserActionResult(result)
}

public renderUserActionAsciiTable(table: FormattedUserActionTable): string {
return renderUserActionAsciiTable(table)
}

public async aliasUser(input: AliasUserInput): Promise<AliasUserResult> {
return aliasUser(this.requireAuth(), input)
}

private requireAuth(): Auth {
const auth = this.authProvider()
if (!auth) {
throw new KeeperSdkError('You are not logged in. Please log in first.', ResultCodes.NOT_LOGGED_IN)
}
return auth
}
}
}
Loading
Loading