@pnp/cli-microsoft365
Version:
Manage Microsoft 365 and SharePoint Framework projects on any platform
82 lines • 3.58 kB
JavaScript
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