UNPKG

@pnp/cli-microsoft365

Version:

Manage Microsoft 365 and SharePoint Framework projects on any platform

82 lines 3.58 kB
import { z } from 'zod'; import { globalOptionsZod } from '../../../../Command.js'; import GraphCommand from '../../../base/GraphCommand.js'; import commands from '../../commands.js'; import request from '../../../../request.js'; import { roleDefinition } from '../../../../utils/roleDefinition.js'; import { validation } from '../../../../utils/validation.js'; export const options = z.strictObject({ ...globalOptionsZod.shape, id: z.uuid().optional().alias('i'), displayName: z.string().optional().alias('n'), newDisplayName: z.string().optional(), allowedResourceActions: z.string().optional().alias('a'), description: z.string().optional().alias('d'), enabled: z.boolean().optional().alias('e'), version: z.string().optional().alias('v') }); class EntraRoleDefinitionSetCommand extends GraphCommand { get name() { return commands.ROLEDEFINITION_SET; } get description() { return 'Updates a custom Microsoft Entra ID role definition'; } get schema() { return options; } getRefinedSchema(schema) { return schema .refine(options => !options.id !== !options.displayName, { error: 'Specify either id or displayName, but not both' }) .refine(options => options.id || options.displayName, { error: 'Specify either id or displayName' }) .refine(options => (!options.id && !options.displayName) || options.displayName || (options.id && validation.isValidGuid(options.id)), { error: e => `The '${e.input}' must be a valid GUID`, path: ['id'] }) .refine(options => Object.values([options.newDisplayName, options.description, options.allowedResourceActions, options.enabled, options.version]).filter(v => typeof v !== 'undefined').length > 0, { error: 'Provide value for at least one of the following parameters: newDisplayName, description, allowedResourceActions, enabled or version' }); } async commandAction(logger, args) { try { let roleDefinitionId = args.options.id; if (args.options.displayName) { roleDefinitionId = (await roleDefinition.getRoleDefinitionByDisplayName(args.options.displayName, 'id')).id; } if (args.options.verbose) { await logger.logToStderr(`Updating custom role definition with ID ${roleDefinitionId}...`); } const data = { displayName: args.options.newDisplayName, description: args.options.description, isEnabled: args.options.enabled, version: args.options.version }; if (args.options.allowedResourceActions) { data['rolePermissions'] = [ { allowedResourceActions: args.options.allowedResourceActions.split(',') } ]; } const requestOptions = { url: `${this.resource}/v1.0/roleManagement/directory/roleDefinitions/${roleDefinitionId}`, headers: { accept: 'application/json;odata.metadata=none' }, data: data, responseType: 'json' }; await request.patch(requestOptions); } catch (err) { this.handleRejectedODataJsonPromise(err); } } } export default new EntraRoleDefinitionSetCommand(); //# sourceMappingURL=roledefinition-set.js.map