UNPKG

@pnp/cli-microsoft365

Version:

Manage Microsoft 365 and SharePoint Framework projects on any platform

104 lines 5.29 kB
import { z } from 'zod'; import { globalOptionsZod } from '../../../../Command.js'; import { zod } from '../../../../utils/zod.js'; import GraphCommand from '../../../base/GraphCommand.js'; import commands from '../../commands.js'; import { validation } from '../../../../utils/validation.js'; import request from '../../../../request.js'; import { odata } from '../../../../utils/odata.js'; const options = globalOptionsZod .extend({ id: zod.alias('i', z.string().refine(id => validation.isValidGuid(id), id => ({ message: `'${id}' is not a valid GUID.` })).optional()), displayName: zod.alias('d', z.string().optional()), marketingNotificationEmails: z.string().refine(emails => validation.isValidUserPrincipalNameArray(emails) === true, invalidEmails => ({ message: `The following marketing notification emails are invalid: ${invalidEmails}.` })).transform((value) => value.split(',')).optional(), securityComplianceNotificationMails: z.string().refine(emails => validation.isValidUserPrincipalNameArray(emails) === true, invalidEmails => ({ message: `The following security compliance notification emails are invalid: ${invalidEmails}.` })).transform((value) => value.split(',')).optional(), securityComplianceNotificationPhones: z.string().transform((value) => value.split(',')).optional(), technicalNotificationMails: z.string().refine(emails => validation.isValidUserPrincipalNameArray(emails) === true, invalidEmails => ({ message: `The following technical notification emails are invalid: ${invalidEmails}.` })).transform((value) => value.split(',')).optional(), contactEmail: z.string().refine(id => validation.isValidUserPrincipalName(id), id => ({ message: `'${id}' is not a valid email.` })).optional(), statementUrl: z.string().optional() }) .strict(); class EntraOrganizationSetCommand extends GraphCommand { get name() { return commands.ORGANIZATION_SET; } get description() { return 'Updates info about the organization'; } get schema() { return options; } getRefinedSchema(schema) { return schema .refine(options => !(options.id && options.displayName), { message: 'Specify either id or displayName, but not both' }) .refine(options => options.id || options.displayName, { message: 'Specify either id or displayName' }) .refine(options => [options.contactEmail, options.marketingNotificationEmails, options.securityComplianceNotificationMails, options.securityComplianceNotificationPhones, options.statementUrl, options.technicalNotificationMails].filter(o => o !== undefined).length > 0, { message: 'Specify at least one of the following options: contactEmail, marketingNotificationEmails, securityComplianceNotificationMails, securityComplianceNotificationPhones, statementUrl, or technicalNotificationMails' }); } async commandAction(logger, args) { try { let organizationId = args.options.id; if (args.options.displayName) { organizationId = await this.getOrganizationIdByDisplayName(args.options.displayName); } if (args.options.verbose) { await logger.logToStderr(`Updating organization with ID ${organizationId}...`); } const data = { marketingNotificationEmails: args.options.marketingNotificationEmails, securityComplianceNotificationMails: args.options.securityComplianceNotificationMails, securityComplianceNotificationPhones: args.options.securityComplianceNotificationPhones, technicalNotificationMails: args.options.technicalNotificationMails }; if (args.options.contactEmail || args.options.statementUrl) { data.privacyProfile = {}; } if (args.options.contactEmail) { data.privacyProfile.contactEmail = args.options.contactEmail; } if (args.options.statementUrl) { data.privacyProfile.statementUrl = args.options.statementUrl; } const requestOptions = { url: `${this.resource}/v1.0/organization/${organizationId}`, headers: { accept: 'application/json;odata.metadata=none', 'content-type': 'application/json' }, data: data, responseType: 'json' }; await request.patch(requestOptions); } catch (err) { this.handleRejectedODataJsonPromise(err); } } async getOrganizationIdByDisplayName(displayName) { const url = `${this.resource}/v1.0/organization?$select=id,displayName`; // the endpoint always returns one item const organizations = await odata.getAllItems(url); if (organizations[0].displayName !== displayName) { throw `The specified organization '${displayName}' does not exist.`; } return organizations[0].id; } } export default new EntraOrganizationSetCommand(); //# sourceMappingURL=organization-set.js.map