box-node-sdk
Version:
Official SDK for Box Platform APIs
358 lines (357 loc) • 12.5 kB
text/typescript
import { serializeSessionTerminationMessage } from '../schemas/sessionTerminationMessage';
import { deserializeSessionTerminationMessage } from '../schemas/sessionTerminationMessage';
import { serializeClientError } from '../schemas/clientError';
import { deserializeClientError } from '../schemas/clientError';
import { ResponseFormat } from '../networking/fetchOptions';
import { SessionTerminationMessage } from '../schemas/sessionTerminationMessage';
import { ClientError } from '../schemas/clientError';
import { BoxSdkError } from '../box/errors';
import { Authentication } from '../networking/auth';
import { NetworkSession } from '../networking/network';
import { FetchOptions } from '../networking/fetchOptions';
import { FetchResponse } from '../networking/fetchResponse';
import { prepareParams } from '../internal/utils';
import { toString } from '../internal/utils';
import { ByteStream } from '../internal/utils';
import { CancellationToken } from '../internal/utils';
import { SerializedData } from '../serialization/json';
import { sdIsEmpty } from '../serialization/json';
import { sdIsBoolean } from '../serialization/json';
import { sdIsNumber } from '../serialization/json';
import { sdIsString } from '../serialization/json';
import { sdIsList } from '../serialization/json';
import { sdIsMap } from '../serialization/json';
export class TerminateUsersSessionsOptionals {
readonly headers: TerminateUsersSessionsHeaders =
new TerminateUsersSessionsHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<
TerminateUsersSessionsOptionals,
'headers' | 'cancellationToken'
> &
Partial<
Pick<TerminateUsersSessionsOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface TerminateUsersSessionsOptionalsInput {
readonly headers?: TerminateUsersSessionsHeaders;
readonly cancellationToken?: CancellationToken;
}
export class TerminateGroupsSessionsOptionals {
readonly headers: TerminateGroupsSessionsHeaders =
new TerminateGroupsSessionsHeaders({});
readonly cancellationToken?: CancellationToken = void 0;
constructor(
fields: Omit<
TerminateGroupsSessionsOptionals,
'headers' | 'cancellationToken'
> &
Partial<
Pick<TerminateGroupsSessionsOptionals, 'headers' | 'cancellationToken'>
>,
) {
if (fields.headers !== undefined) {
this.headers = fields.headers;
}
if (fields.cancellationToken !== undefined) {
this.cancellationToken = fields.cancellationToken;
}
}
}
export interface TerminateGroupsSessionsOptionalsInput {
readonly headers?: TerminateGroupsSessionsHeaders;
readonly cancellationToken?: CancellationToken;
}
export interface TerminateUsersSessionsRequestBody {
/**
* A list of user IDs. */
readonly userIds: readonly string[];
/**
* A list of user logins. */
readonly userLogins: readonly string[];
readonly rawData?: SerializedData;
}
export class TerminateUsersSessionsHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<TerminateUsersSessionsHeaders, 'extraHeaders'> &
Partial<Pick<TerminateUsersSessionsHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface TerminateUsersSessionsHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export interface TerminateGroupsSessionsRequestBody {
/**
* A list of group IDs. */
readonly groupIds: readonly string[];
readonly rawData?: SerializedData;
}
export class TerminateGroupsSessionsHeaders {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
} = {};
constructor(
fields: Omit<TerminateGroupsSessionsHeaders, 'extraHeaders'> &
Partial<Pick<TerminateGroupsSessionsHeaders, 'extraHeaders'>>,
) {
if (fields.extraHeaders !== undefined) {
this.extraHeaders = fields.extraHeaders;
}
}
}
export interface TerminateGroupsSessionsHeadersInput {
/**
* Extra headers that will be included in the HTTP request. */
readonly extraHeaders?: {
readonly [key: string]: undefined | string;
};
}
export class SessionTerminationManager {
readonly auth?: Authentication;
readonly networkSession: NetworkSession = new NetworkSession({});
constructor(
fields: Omit<
SessionTerminationManager,
'networkSession' | 'terminateUsersSessions' | 'terminateGroupsSessions'
> &
Partial<Pick<SessionTerminationManager, 'networkSession'>>,
) {
if (fields.auth !== undefined) {
this.auth = fields.auth;
}
if (fields.networkSession !== undefined) {
this.networkSession = fields.networkSession;
}
}
/**
* Validates the roles and permissions of the user,
* and creates asynchronous jobs
* to terminate the user's sessions.
* Returns the status for the POST request.
* @param {TerminateUsersSessionsRequestBody} requestBody Request body of terminateUsersSessions method
* @param {TerminateUsersSessionsOptionalsInput} optionalsInput
* @returns {Promise<SessionTerminationMessage>}
*/
async terminateUsersSessions(
requestBody: TerminateUsersSessionsRequestBody,
optionalsInput: TerminateUsersSessionsOptionalsInput = {},
): Promise<SessionTerminationMessage> {
const optionals: TerminateUsersSessionsOptionals =
new TerminateUsersSessionsOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/users/terminate_sessions',
) as string,
method: 'POST',
headers: headersMap,
data: serializeTerminateUsersSessionsRequestBody(requestBody),
contentType: 'application/json',
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSessionTerminationMessage(response.data!),
rawData: response.data!,
};
}
/**
* Validates the roles and permissions of the group,
* and creates asynchronous jobs
* to terminate the group's sessions.
* Returns the status for the POST request.
* @param {TerminateGroupsSessionsRequestBody} requestBody Request body of terminateGroupsSessions method
* @param {TerminateGroupsSessionsOptionalsInput} optionalsInput
* @returns {Promise<SessionTerminationMessage>}
*/
async terminateGroupsSessions(
requestBody: TerminateGroupsSessionsRequestBody,
optionalsInput: TerminateGroupsSessionsOptionalsInput = {},
): Promise<SessionTerminationMessage> {
const optionals: TerminateGroupsSessionsOptionals =
new TerminateGroupsSessionsOptionals({
headers: optionalsInput.headers,
cancellationToken: optionalsInput.cancellationToken,
});
const headers: any = optionals.headers;
const cancellationToken: any = optionals.cancellationToken;
const headersMap: {
readonly [key: string]: string;
} = prepareParams({ ...{}, ...headers.extraHeaders });
const response: FetchResponse =
await this.networkSession.networkClient.fetch(
new FetchOptions({
url: ''.concat(
this.networkSession.baseUrls.baseUrl,
'/2.0/groups/terminate_sessions',
) as string,
method: 'POST',
headers: headersMap,
data: serializeTerminateGroupsSessionsRequestBody(requestBody),
contentType: 'application/json',
responseFormat: 'json' as ResponseFormat,
auth: this.auth,
networkSession: this.networkSession,
cancellationToken: cancellationToken,
}),
);
return {
...deserializeSessionTerminationMessage(response.data!),
rawData: response.data!,
};
}
}
export interface SessionTerminationManagerInput {
readonly auth?: Authentication;
readonly networkSession?: NetworkSession;
}
export function serializeTerminateUsersSessionsRequestBody(
val: TerminateUsersSessionsRequestBody,
): SerializedData {
return {
['user_ids']: val.userIds.map(function (item: string): SerializedData {
return item;
}) as readonly any[],
['user_logins']: val.userLogins.map(function (
item: string,
): SerializedData {
return item;
}) as readonly any[],
};
}
export function deserializeTerminateUsersSessionsRequestBody(
val: SerializedData,
): TerminateUsersSessionsRequestBody {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "TerminateUsersSessionsRequestBody"',
});
}
if (val.user_ids == void 0) {
throw new BoxSdkError({
message:
'Expecting "user_ids" of type "TerminateUsersSessionsRequestBody" to be defined',
});
}
if (!sdIsList(val.user_ids)) {
throw new BoxSdkError({
message:
'Expecting array for "user_ids" of type "TerminateUsersSessionsRequestBody"',
});
}
const userIds: readonly string[] = sdIsList(val.user_ids)
? (val.user_ids.map(function (itm: SerializedData): string {
if (!sdIsString(itm)) {
throw new BoxSdkError({
message: 'Expecting string for "TerminateUsersSessionsRequestBody"',
});
}
return itm;
}) as readonly any[])
: [];
if (val.user_logins == void 0) {
throw new BoxSdkError({
message:
'Expecting "user_logins" of type "TerminateUsersSessionsRequestBody" to be defined',
});
}
if (!sdIsList(val.user_logins)) {
throw new BoxSdkError({
message:
'Expecting array for "user_logins" of type "TerminateUsersSessionsRequestBody"',
});
}
const userLogins: readonly string[] = sdIsList(val.user_logins)
? (val.user_logins.map(function (itm: SerializedData): string {
if (!sdIsString(itm)) {
throw new BoxSdkError({
message: 'Expecting string for "TerminateUsersSessionsRequestBody"',
});
}
return itm;
}) as readonly any[])
: [];
return {
userIds: userIds,
userLogins: userLogins,
} satisfies TerminateUsersSessionsRequestBody;
}
export function serializeTerminateGroupsSessionsRequestBody(
val: TerminateGroupsSessionsRequestBody,
): SerializedData {
return {
['group_ids']: val.groupIds.map(function (item: string): SerializedData {
return item;
}) as readonly any[],
};
}
export function deserializeTerminateGroupsSessionsRequestBody(
val: SerializedData,
): TerminateGroupsSessionsRequestBody {
if (!sdIsMap(val)) {
throw new BoxSdkError({
message: 'Expecting a map for "TerminateGroupsSessionsRequestBody"',
});
}
if (val.group_ids == void 0) {
throw new BoxSdkError({
message:
'Expecting "group_ids" of type "TerminateGroupsSessionsRequestBody" to be defined',
});
}
if (!sdIsList(val.group_ids)) {
throw new BoxSdkError({
message:
'Expecting array for "group_ids" of type "TerminateGroupsSessionsRequestBody"',
});
}
const groupIds: readonly string[] = sdIsList(val.group_ids)
? (val.group_ids.map(function (itm: SerializedData): string {
if (!sdIsString(itm)) {
throw new BoxSdkError({
message:
'Expecting string for "TerminateGroupsSessionsRequestBody"',
});
}
return itm;
}) as readonly any[])
: [];
return { groupIds: groupIds } satisfies TerminateGroupsSessionsRequestBody;
}