@pnp/cli-microsoft365
Version:
Manage Microsoft 365 and SharePoint Framework projects on any platform
102 lines • 4.14 kB
JavaScript
import { z } from 'zod';
import { globalOptionsZod } from '../../../../Command.js';
import request from '../../../../request.js';
import { validation } from '../../../../utils/validation.js';
import SpoCommand from '../../../base/SpoCommand.js';
import commands from '../../commands.js';
export const options = z.strictObject({
...globalOptionsZod.shape,
siteUrl: z.string()
.refine(url => validation.isValidSharePointUrl(url) === true, {
error: e => `'${e.input}' is not a valid SharePoint Online site URL.`
})
.alias('u'),
disabled: z.boolean().optional(),
ownerGroup: z.boolean().optional(),
email: z.string()
.refine(email => validation.isValidUserPrincipalName(email), {
error: e => `'${e.input}' is not a valid email address.`
}).optional(),
message: z.string().optional()
});
class SpoSiteAccessRequestSettingSetCommand extends SpoCommand {
get name() {
return commands.SITE_ACCESSREQUEST_SETTING_SET;
}
get description() {
return 'Update access requests for a specific site';
}
get schema() {
return options;
}
getRefinedSchema(schema) {
return schema
.refine(o => [o.disabled, o.ownerGroup, o.email].filter(v => v !== undefined).length === 1, {
error: 'Specify exactly one of disabled, ownerGroup, or email'
})
.refine(o => !(o.disabled && typeof o.message !== 'undefined'), {
error: 'The message option cannot be used when disabled is specified'
});
}
async commandAction(logger, args) {
if (this.verbose) {
await logger.logToStderr(`Updating access requests for site '${args.options.siteUrl}'...`);
}
try {
const { siteUrl, ownerGroup, email, message } = args.options;
const requestAccessEmail = email || '';
if (this.verbose) {
await logger.logToStderr(`Updating RequestAccessEmail to '${requestAccessEmail}'...`);
}
const requestPatchWeb = {
url: `${siteUrl}/_api/Web`,
headers: {
accept: 'application/json;odata=nometadata'
},
responseType: 'json',
data: {
RequestAccessEmail: requestAccessEmail
}
};
await request.patch(requestPatchWeb);
const useAccessRequestDefault = !!ownerGroup;
if (this.verbose) {
await logger.logToStderr(`Updating UseAccessRequestDefault to '${useAccessRequestDefault}'...`);
}
const requestUseDefault = {
url: `${siteUrl}/_api/Web/SetUseAccessRequestDefaultAndUpdate`,
headers: {
accept: 'application/json;odata=nometadata',
'content-type': 'application/json;odata=nometadata'
},
responseType: 'json',
data: {
useAccessRequestDefault: useAccessRequestDefault
}
};
await request.post(requestUseDefault);
if (message !== undefined) {
if (this.verbose) {
await logger.logToStderr(`Updating access request message to '${message}'...`);
}
const requestSetMessage = {
url: `${siteUrl}/_api/Web/SetAccessRequestSiteDescriptionAndUpdate`,
headers: {
accept: 'application/json;odata=nometadata',
'content-type': 'application/json;odata=nometadata'
},
responseType: 'json',
data: {
description: message
}
};
await request.post(requestSetMessage);
}
}
catch (err) {
this.handleRejectedODataJsonPromise(err);
}
}
}
export default new SpoSiteAccessRequestSettingSetCommand();
//# sourceMappingURL=site-accessrequest-setting-set.js.map