@pnp/cli-microsoft365 7.0.0-beta.90ef876 → 7.0.0-beta.df9f285
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Command.js +1 -1
- package/dist/cli/Cli.js +23 -8
- package/dist/m365/aad/commands/user/user-get.js +7 -1
- package/dist/m365/aad/commands/user/user-list.js +3 -6
- package/dist/m365/aad/commands/user/user-set.js +20 -20
- package/dist/m365/booking/commands/business/business-get.js +14 -15
- package/dist/m365/cli/commands/config/config-set.js +1 -1
- package/dist/m365/pa/commands/app/app-consent-set.js +2 -2
- package/dist/m365/pa/commands/app/app-export.js +3 -3
- package/dist/m365/pa/commands/app/app-list.js +5 -5
- package/dist/m365/pa/commands/app/app-owner-set.js +115 -0
- package/dist/m365/pa/commands/app/app-permission-list.js +104 -0
- package/dist/m365/pa/commands.js +2 -0
- package/dist/m365/planner/commands/bucket/bucket-add.js +14 -10
- package/dist/m365/planner/commands/bucket/bucket-get.js +25 -19
- package/dist/m365/planner/commands/bucket/bucket-list.js +14 -10
- package/dist/m365/planner/commands/bucket/bucket-remove.js +26 -20
- package/dist/m365/planner/commands/bucket/bucket-set.js +26 -28
- package/dist/m365/planner/commands/roster/roster-member-add.js +3 -14
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-get.js +2 -2
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-list.js +2 -2
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-remove.js +3 -3
- package/dist/m365/pp/commands/card/card-clone.js +3 -3
- package/dist/m365/pp/commands/card/card-get.js +2 -2
- package/dist/m365/pp/commands/card/card-list.js +2 -2
- package/dist/m365/pp/commands/card/card-remove.js +3 -3
- package/dist/m365/pp/commands/chatbot/chatbot-get.js +2 -2
- package/dist/m365/pp/commands/chatbot/chatbot-list.js +3 -3
- package/dist/m365/pp/commands/chatbot/chatbot-remove.js +3 -3
- package/dist/m365/pp/commands/dataverse/dataverse-table-get.js +2 -2
- package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +2 -2
- package/dist/m365/pp/commands/dataverse/dataverse-table-remove.js +2 -2
- package/dist/m365/pp/commands/dataverse/dataverse-table-row-list.js +2 -2
- package/dist/m365/pp/commands/dataverse/dataverse-table-row-remove.js +2 -2
- package/dist/m365/pp/commands/solution/solution-get.js +2 -2
- package/dist/m365/pp/commands/solution/solution-list.js +2 -2
- package/dist/m365/pp/commands/solution/solution-publish.js +3 -3
- package/dist/m365/pp/commands/solution/solution-publisher-add.js +2 -2
- package/dist/m365/pp/commands/solution/solution-publisher-get.js +2 -2
- package/dist/m365/pp/commands/solution/solution-publisher-list.js +2 -2
- package/dist/m365/pp/commands/solution/solution-publisher-remove.js +3 -3
- package/dist/m365/pp/commands/solution/solution-remove.js +3 -3
- package/dist/m365/purview/commands/retentionevent/retentionevent-remove.js +19 -17
- package/dist/m365/purview/commands/retentioneventtype/retentioneventtype-remove.js +19 -17
- package/dist/m365/search/commands/externalconnection/externalconnection-remove.js +35 -34
- package/dist/m365/spfx/commands/project/project-externalize/rules/DynamicRule.js +59 -51
- package/dist/m365/spo/commands/file/file-list.js +3 -14
- package/dist/m365/spo/commands/folder/folder-remove.js +30 -28
- package/dist/m365/spo/commands/list/list-add.js +0 -9
- package/dist/m365/spo/commands/list/list-retentionlabel-ensure.js +0 -4
- package/dist/m365/spo/commands/list/list-retentionlabel-get.js +0 -4
- package/dist/m365/spo/commands/list/list-roleassignment-add.js +9 -47
- package/dist/m365/spo/commands/list/list-set.js +0 -9
- package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +4 -4
- package/dist/m365/spo/commands/page/page-remove.js +33 -31
- package/dist/m365/spo/commands/roledefinition/roledefinition-remove.js +25 -23
- package/dist/m365/spo/commands/site/site-apppermission-add.js +3 -3
- package/dist/m365/spo/commands/site/site-commsite-enable.js +9 -18
- package/dist/m365/spo/commands/site/site-set.js +10 -2
- package/dist/m365/spo/commands/tenant/tenant-appcatalog-add.js +13 -16
- package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-set.js +80 -2
- package/dist/m365/spo/commands/tenant/tenant-commandset-set.js +107 -24
- package/dist/m365/spo/commands/tenant/tenant-recyclebinitem-remove.js +48 -48
- package/dist/m365/spo/commands/theme/theme-get.js +1 -2
- package/dist/m365/spo/commands/user/user-get.js +5 -5
- package/dist/m365/spo/commands.js +0 -2
- package/dist/m365/teams/commands/chat/chat-get.js +4 -4
- package/dist/m365/teams/commands/chat/chat-member-add.js +117 -0
- package/dist/m365/teams/commands/chat/chat-message-send.js +4 -4
- package/dist/m365/teams/commands/meeting/meeting-get.js +16 -24
- package/dist/m365/teams/commands/meeting/meeting-list.js +2 -15
- package/dist/m365/teams/commands/team/team-app-list.js +1 -1
- package/dist/m365/teams/commands.js +1 -0
- package/dist/utils/spo.js +74 -0
- package/docs/docs/_clisettings.mdx +1 -1
- package/docs/docs/cmd/_global.mdx +1 -1
- package/docs/docs/cmd/aad/user/user-get.mdx +118 -25
- package/docs/docs/cmd/aad/user/user-list.mdx +0 -9
- package/docs/docs/cmd/aad/user/user-set.mdx +11 -11
- package/docs/docs/cmd/pa/app/app-consent-set.mdx +3 -3
- package/docs/docs/cmd/pa/app/app-export.mdx +3 -3
- package/docs/docs/cmd/pa/app/app-list.mdx +2 -2
- package/docs/docs/cmd/pa/app/app-owner-set.mdx +60 -0
- package/docs/docs/cmd/pa/app/app-permission-list.mdx +132 -0
- package/docs/docs/cmd/planner/bucket/bucket-add.mdx +21 -4
- package/docs/docs/cmd/planner/bucket/bucket-get.mdx +22 -5
- package/docs/docs/cmd/planner/bucket/bucket-list.mdx +21 -4
- package/docs/docs/cmd/planner/bucket/bucket-remove.mdx +21 -4
- package/docs/docs/cmd/planner/bucket/bucket-set.mdx +22 -5
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-get.mdx +4 -4
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-list.mdx +4 -4
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-remove.mdx +4 -4
- package/docs/docs/cmd/pp/card/card-clone.mdx +6 -6
- package/docs/docs/cmd/pp/card/card-get.mdx +6 -6
- package/docs/docs/cmd/pp/card/card-list.mdx +4 -4
- package/docs/docs/cmd/pp/card/card-remove.mdx +9 -9
- package/docs/docs/cmd/pp/chatbot/chatbot-get.mdx +6 -6
- package/docs/docs/cmd/pp/chatbot/chatbot-list.mdx +4 -4
- package/docs/docs/cmd/pp/chatbot/chatbot-remove.mdx +4 -4
- package/docs/docs/cmd/pp/dataverse/dataverse-table-get.mdx +2 -2
- package/docs/docs/cmd/pp/dataverse/dataverse-table-list.mdx +2 -2
- package/docs/docs/cmd/pp/dataverse/dataverse-table-remove.mdx +1 -1
- package/docs/docs/cmd/pp/dataverse/dataverse-table-row-list.mdx +5 -5
- package/docs/docs/cmd/pp/dataverse/dataverse-table-row-remove.mdx +5 -5
- package/docs/docs/cmd/pp/solution/solution-get.mdx +6 -6
- package/docs/docs/cmd/pp/solution/solution-list.mdx +4 -4
- package/docs/docs/cmd/pp/solution/solution-publish.mdx +4 -4
- package/docs/docs/cmd/pp/solution/solution-publisher-add.mdx +3 -3
- package/docs/docs/cmd/pp/solution/solution-publisher-get.mdx +6 -6
- package/docs/docs/cmd/pp/solution/solution-publisher-list.mdx +4 -4
- package/docs/docs/cmd/pp/solution/solution-publisher-remove.mdx +5 -5
- package/docs/docs/cmd/pp/solution/solution-remove.mdx +9 -9
- package/docs/docs/cmd/spo/file/file-list.mdx +6 -10
- package/docs/docs/cmd/spo/file/file-retentionlabel-ensure.mdx +1 -1
- package/docs/docs/cmd/spo/list/list-add.mdx +0 -3
- package/docs/docs/cmd/spo/list/list-retentionlabel-ensure.mdx +0 -6
- package/docs/docs/cmd/spo/list/list-retentionlabel-get.mdx +0 -6
- package/docs/docs/cmd/spo/list/list-set.mdx +0 -3
- package/docs/docs/cmd/spo/listitem/listitem-attachment-list.mdx +7 -7
- package/docs/docs/cmd/spo/site/site-add.mdx +35 -0
- package/docs/docs/cmd/spo/site/site-appcatalog-add.mdx +5 -1
- package/docs/docs/cmd/spo/site/site-appcatalog-list.mdx +14 -0
- package/docs/docs/cmd/spo/site/site-appcatalog-remove.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-apppermission-add.mdx +68 -0
- package/docs/docs/cmd/spo/site/site-apppermission-get.mdx +55 -0
- package/docs/docs/cmd/spo/site/site-apppermission-list.mdx +55 -0
- package/docs/docs/cmd/spo/site/site-apppermission-remove.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-apppermission-set.mdx +66 -0
- package/docs/docs/cmd/spo/site/site-chrome-set.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +11 -1
- package/docs/docs/cmd/spo/site/site-ensure.mdx +70 -0
- package/docs/docs/cmd/spo/site/site-get.mdx +179 -0
- package/docs/docs/cmd/spo/site/site-groupify.mdx +54 -0
- package/docs/docs/cmd/spo/site/site-hubsite-connect.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-hubsite-disconnect.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-hubsite-theme-sync.mdx +5 -1
- package/docs/docs/cmd/spo/site/site-inplacerecordsmanagement-set.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-list.mdx +303 -0
- package/docs/docs/cmd/spo/site/site-recyclebinitem-list.mdx +80 -0
- package/docs/docs/cmd/spo/site/site-recyclebinitem-restore.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-remove.mdx +4 -0
- package/docs/docs/cmd/spo/site/site-rename.mdx +92 -0
- package/docs/docs/cmd/spo/site/site-set.mdx +13 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-add.mdx +116 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-apply.mdx +125 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-get.mdx +117 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-list.mdx +94 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-remove.mdx +4 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-rights-grant.mdx +4 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-rights-list.mdx +54 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-rights-revoke.mdx +4 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-run-list.mdx +66 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-run-status-get.mdx +65 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-set.mdx +117 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-task-get.mdx +61 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-task-list.mdx +60 -0
- package/docs/docs/cmd/spo/sitedesign/sitedesign-task-remove.mdx +4 -0
- package/docs/docs/cmd/spo/sitescript/sitescript-add.mdx +75 -0
- package/docs/docs/cmd/spo/sitescript/sitescript-get.mdx +62 -0
- package/docs/docs/cmd/spo/sitescript/sitescript-list.mdx +60 -0
- package/docs/docs/cmd/spo/sitescript/sitescript-remove.mdx +4 -0
- package/docs/docs/cmd/spo/sitescript/sitescript-set.mdx +63 -0
- package/docs/docs/cmd/spo/storageentity/storageentity-get.mdx +53 -0
- package/docs/docs/cmd/spo/storageentity/storageentity-list.mdx +54 -0
- package/docs/docs/cmd/spo/storageentity/storageentity-remove.mdx +4 -0
- package/docs/docs/cmd/spo/storageentity/storageentity-set.mdx +4 -0
- package/docs/docs/cmd/spo/tenant/tenant-appcatalog-add.mdx +4 -0
- package/docs/docs/cmd/spo/tenant/tenant-appcatalogurl-get.mdx +35 -0
- package/docs/docs/cmd/spo/tenant/tenant-applicationcustomizer-set.mdx +12 -3
- package/docs/docs/cmd/spo/tenant/tenant-commandset-set.mdx +23 -11
- package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-list.mdx +67 -0
- package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-remove.mdx +4 -0
- package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-restore.mdx +50 -0
- package/docs/docs/cmd/spo/tenant/tenant-settings-list.mdx +729 -0
- package/docs/docs/cmd/spo/tenant/tenant-settings-set.mdx +5 -0
- package/docs/docs/cmd/spo/theme/theme-apply.mdx +35 -0
- package/docs/docs/cmd/spo/theme/theme-get.mdx +74 -0
- package/docs/docs/cmd/spo/theme/theme-list.mdx +52 -0
- package/docs/docs/cmd/spo/theme/theme-remove.mdx +4 -0
- package/docs/docs/cmd/spo/theme/theme-set.mdx +4 -0
- package/docs/docs/cmd/spo/user/user-get.mdx +6 -6
- package/docs/docs/cmd/teams/chat/chat-member-add.mdx +66 -0
- package/npm-shrinkwrap.json +212 -212
- package/package.json +10 -10
|
@@ -36,29 +36,8 @@ class SpoRoleDefinitionRemoveCommand extends SpoCommand_1.default {
|
|
|
36
36
|
}
|
|
37
37
|
commandAction(logger, args) {
|
|
38
38
|
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
-
const removeRoleDefinition = () => __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
if (this.verbose) {
|
|
41
|
-
logger.logToStderr(`Removing role definition from site ${args.options.webUrl}...`);
|
|
42
|
-
}
|
|
43
|
-
const requestOptions = {
|
|
44
|
-
url: `${args.options.webUrl}/_api/web/roledefinitions(${args.options.id})`,
|
|
45
|
-
method: 'delete',
|
|
46
|
-
headers: {
|
|
47
|
-
'X-HTTP-Method': 'DELETE',
|
|
48
|
-
'If-Match': '*',
|
|
49
|
-
'accept': 'application/json;odata=nometadata'
|
|
50
|
-
},
|
|
51
|
-
responseType: 'json'
|
|
52
|
-
};
|
|
53
|
-
try {
|
|
54
|
-
yield request_1.default.delete(requestOptions);
|
|
55
|
-
}
|
|
56
|
-
catch (err) {
|
|
57
|
-
this.handleRejectedODataJsonPromise(err);
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
39
|
if (args.options.force) {
|
|
61
|
-
yield removeRoleDefinition();
|
|
40
|
+
yield this.removeRoleDefinition(logger, args);
|
|
62
41
|
}
|
|
63
42
|
else {
|
|
64
43
|
const result = yield Cli_1.Cli.prompt({
|
|
@@ -68,11 +47,34 @@ class SpoRoleDefinitionRemoveCommand extends SpoCommand_1.default {
|
|
|
68
47
|
message: `Are you sure you want to remove the role definition with id ${args.options.id} from site ${args.options.webUrl}?`
|
|
69
48
|
});
|
|
70
49
|
if (result.continue) {
|
|
71
|
-
yield removeRoleDefinition();
|
|
50
|
+
yield this.removeRoleDefinition(logger, args);
|
|
72
51
|
}
|
|
73
52
|
}
|
|
74
53
|
});
|
|
75
54
|
}
|
|
55
|
+
removeRoleDefinition(logger, args) {
|
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
+
if (this.verbose) {
|
|
58
|
+
logger.logToStderr(`Removing role definition from site ${args.options.webUrl}...`);
|
|
59
|
+
}
|
|
60
|
+
const requestOptions = {
|
|
61
|
+
url: `${args.options.webUrl}/_api/web/roledefinitions(${args.options.id})`,
|
|
62
|
+
method: 'delete',
|
|
63
|
+
headers: {
|
|
64
|
+
'X-HTTP-Method': 'DELETE',
|
|
65
|
+
'If-Match': '*',
|
|
66
|
+
'accept': 'application/json;odata=nometadata'
|
|
67
|
+
},
|
|
68
|
+
responseType: 'json'
|
|
69
|
+
};
|
|
70
|
+
try {
|
|
71
|
+
yield request_1.default.delete(requestOptions);
|
|
72
|
+
}
|
|
73
|
+
catch (err) {
|
|
74
|
+
this.handleRejectedODataJsonPromise(err);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
76
78
|
}
|
|
77
79
|
_SpoRoleDefinitionRemoveCommand_instances = new WeakSet(), _SpoRoleDefinitionRemoveCommand_initTelemetry = function _SpoRoleDefinitionRemoveCommand_initTelemetry() {
|
|
78
80
|
this.telemetry.push((args) => {
|
|
@@ -47,10 +47,10 @@ class SpoSiteAppPermissionAddCommand extends GraphCommand_1.default {
|
|
|
47
47
|
}
|
|
48
48
|
let endpoint = "";
|
|
49
49
|
if (args.options.appId) {
|
|
50
|
-
endpoint = `${this.resource}/v1.0/myorganization/
|
|
50
|
+
endpoint = `${this.resource}/v1.0/myorganization/servicePrincipals?$select=appId,displayName&$filter=appId eq '${formatting_1.formatting.encodeQueryParameter(args.options.appId)}'`;
|
|
51
51
|
}
|
|
52
52
|
else {
|
|
53
|
-
endpoint = `${this.resource}/v1.0/myorganization/
|
|
53
|
+
endpoint = `${this.resource}/v1.0/myorganization/servicePrincipals?$select=appId,displayName&$filter=displayName eq '${formatting_1.formatting.encodeQueryParameter(args.options.appDisplayName)}'`;
|
|
54
54
|
}
|
|
55
55
|
const appRequestOptions = {
|
|
56
56
|
url: endpoint,
|
|
@@ -168,7 +168,7 @@ _SpoSiteAppPermissionAddCommand_instances = new WeakSet(), _SpoSiteAppPermission
|
|
|
168
168
|
return validation_1.validation.isValidSharePointUrl(args.options.siteUrl);
|
|
169
169
|
}));
|
|
170
170
|
}, _SpoSiteAppPermissionAddCommand_initOptionSets = function _SpoSiteAppPermissionAddCommand_initOptionSets() {
|
|
171
|
-
this.optionSets.push({ options: ['appId', 'appDisplayName'] });
|
|
171
|
+
this.optionSets.push({ options: ['appId', 'appDisplayName'], runsWhen: (args) => !args.options.appId && !args.options.appDisplayName });
|
|
172
172
|
};
|
|
173
173
|
module.exports = new SpoSiteAppPermissionAddCommand();
|
|
174
174
|
//# sourceMappingURL=site-apppermission-add.js.map
|
|
@@ -15,10 +15,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
15
15
|
};
|
|
16
16
|
var _SpoSiteCommSiteEnableCommand_instances, _SpoSiteCommSiteEnableCommand_initTelemetry, _SpoSiteCommSiteEnableCommand_initOptions, _SpoSiteCommSiteEnableCommand_initValidators;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
const config_1 = require("../../../../config");
|
|
19
18
|
const request_1 = require("../../../../request");
|
|
20
|
-
const formatting_1 = require("../../../../utils/formatting");
|
|
21
|
-
const spo_1 = require("../../../../utils/spo");
|
|
22
19
|
const validation_1 = require("../../../../utils/validation");
|
|
23
20
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
24
21
|
const commands_1 = require("../../commands");
|
|
@@ -38,26 +35,20 @@ class SpoSiteCommSiteEnableCommand extends SpoCommand_1.default {
|
|
|
38
35
|
}
|
|
39
36
|
commandAction(logger, args) {
|
|
40
37
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
const designPackageId = args.options.designPackageId || '
|
|
38
|
+
const designPackageId = args.options.designPackageId || '96c933ac-3698-44c7-9f4a-5fd17d71af9e';
|
|
39
|
+
if (this.verbose) {
|
|
40
|
+
logger.logToStderr(`Enabling communication site at ${args.options.url}...`);
|
|
41
|
+
}
|
|
42
42
|
try {
|
|
43
|
-
const spoAdminUrl = yield spo_1.spo.getSpoAdminUrl(logger, this.debug);
|
|
44
|
-
if (this.debug) {
|
|
45
|
-
logger.logToStderr(`Retrieving request digest...`);
|
|
46
|
-
}
|
|
47
|
-
const ctxInfo = yield spo_1.spo.getRequestDigest(spoAdminUrl);
|
|
48
43
|
const requestOptions = {
|
|
49
|
-
url: `${
|
|
44
|
+
url: `${args.options.url}/_api/sitepages/communicationsite/enable`,
|
|
50
45
|
headers: {
|
|
51
|
-
'
|
|
46
|
+
'accept': 'application/json;odata=nometadata'
|
|
52
47
|
},
|
|
53
|
-
data:
|
|
48
|
+
data: { designPackageId },
|
|
49
|
+
responseType: 'json'
|
|
54
50
|
};
|
|
55
|
-
|
|
56
|
-
const json = JSON.parse(res);
|
|
57
|
-
const response = json[0];
|
|
58
|
-
if (response.ErrorInfo) {
|
|
59
|
-
throw response.ErrorInfo.ErrorMessage;
|
|
60
|
-
}
|
|
51
|
+
yield request_1.default.post(requestOptions);
|
|
61
52
|
}
|
|
62
53
|
catch (err) {
|
|
63
54
|
this.handleRejectedODataJsonPromise(err);
|
|
@@ -311,7 +311,7 @@ class SpoSiteSetCommand extends SpoCommand_1.default {
|
|
|
311
311
|
}
|
|
312
312
|
updateSiteProperties(logger, args) {
|
|
313
313
|
const isGroupConnectedSite = this.isGroupConnectedSite();
|
|
314
|
-
const sharedProperties = ['classification', 'disableFlows', 'shareByEmailEnabled', 'sharingCapability', 'noScriptSite'];
|
|
314
|
+
const sharedProperties = ['classification', 'disableFlows', 'socialBarOnSitePagesDisabled', 'shareByEmailEnabled', 'sharingCapability', 'noScriptSite'];
|
|
315
315
|
const siteProperties = ['title', 'resourceQuota', 'resourceQuotaWarningLevel', 'storageQuota', 'storageQuotaWarningLevel', 'allowSelfServiceUpgrade'];
|
|
316
316
|
let properties = sharedProperties;
|
|
317
317
|
properties = properties;
|
|
@@ -363,6 +363,9 @@ class SpoSiteSetCommand extends SpoCommand_1.default {
|
|
|
363
363
|
if (typeof args.options.disableFlows !== 'undefined') {
|
|
364
364
|
payload.push(`<SetProperty Id="${propertyId++}" ObjectPathId="5" Name="DisableFlows"><Parameter Type="Boolean">${args.options.disableFlows}</Parameter></SetProperty>`);
|
|
365
365
|
}
|
|
366
|
+
if (typeof args.options.socialBarOnSitePagesDisabled !== 'undefined') {
|
|
367
|
+
payload.push(`<SetProperty Id="${propertyId++}" ObjectPathId="5" Name="SocialBarOnSitePagesDisabled"><Parameter Type="Boolean">${args.options.socialBarOnSitePagesDisabled}</Parameter></SetProperty>`);
|
|
368
|
+
}
|
|
366
369
|
if (typeof args.options.shareByEmailEnabled !== 'undefined') {
|
|
367
370
|
payload.push(`<SetProperty Id="${propertyId++}" ObjectPathId="5" Name="ShareByEmailEnabled"><Parameter Type="Boolean">${args.options.shareByEmailEnabled}</Parameter></SetProperty>`);
|
|
368
371
|
}
|
|
@@ -442,6 +445,7 @@ _SpoSiteSetCommand_instances = new WeakSet(), _SpoSiteSetCommand_initTelemetry =
|
|
|
442
445
|
Object.assign(this.telemetryProperties, {
|
|
443
446
|
classification: typeof args.options.classification === 'string',
|
|
444
447
|
disableFlows: args.options.disableFlows,
|
|
448
|
+
socialBarOnSitePagesDisabled: args.options.socialBarOnSitePagesDisabled,
|
|
445
449
|
isPublic: args.options.isPublic,
|
|
446
450
|
owners: typeof args.options.owners !== 'undefined',
|
|
447
451
|
shareByEmailEnabled: args.options.shareByEmailEnabled,
|
|
@@ -470,6 +474,9 @@ _SpoSiteSetCommand_instances = new WeakSet(), _SpoSiteSetCommand_initTelemetry =
|
|
|
470
474
|
}, {
|
|
471
475
|
option: '--disableFlows [disableFlows]',
|
|
472
476
|
autocomplete: ['true', 'false']
|
|
477
|
+
}, {
|
|
478
|
+
option: '--socialBarOnSitePagesDisabled [socialBarOnSitePagesDisabled]',
|
|
479
|
+
autocomplete: ['true', 'false']
|
|
473
480
|
}, {
|
|
474
481
|
option: '--isPublic [isPublic]',
|
|
475
482
|
autocomplete: ['true', 'false']
|
|
@@ -517,6 +524,7 @@ _SpoSiteSetCommand_instances = new WeakSet(), _SpoSiteSetCommand_initTelemetry =
|
|
|
517
524
|
}
|
|
518
525
|
if (typeof args.options.classification === 'undefined' &&
|
|
519
526
|
typeof args.options.disableFlows === 'undefined' &&
|
|
527
|
+
typeof args.options.socialBarOnSitePagesDisabled === 'undefined' &&
|
|
520
528
|
typeof args.options.title === 'undefined' &&
|
|
521
529
|
typeof args.options.description === 'undefined' &&
|
|
522
530
|
typeof args.options.isPublic === 'undefined' &&
|
|
@@ -580,7 +588,7 @@ _SpoSiteSetCommand_instances = new WeakSet(), _SpoSiteSetCommand_initTelemetry =
|
|
|
580
588
|
}));
|
|
581
589
|
}, _SpoSiteSetCommand_initTypes = function _SpoSiteSetCommand_initTypes() {
|
|
582
590
|
this.types.string.push('classification');
|
|
583
|
-
this.types.boolean.push('isPublic', 'disableFlows', 'shareByEmailEnabled', 'allowSelfServiceUpgrade', 'noScriptSite');
|
|
591
|
+
this.types.boolean.push('isPublic', 'disableFlows', 'socialBarOnSitePagesDisabled', 'shareByEmailEnabled', 'allowSelfServiceUpgrade', 'noScriptSite');
|
|
584
592
|
};
|
|
585
593
|
module.exports = new SpoSiteSetCommand();
|
|
586
594
|
//# sourceMappingURL=site-set.js.map
|
|
@@ -62,7 +62,8 @@ class SpoTenantAppCatalogAddCommand extends SpoCommand_1.default {
|
|
|
62
62
|
});
|
|
63
63
|
}
|
|
64
64
|
ensureNoExistingSite(url, force, logger) {
|
|
65
|
-
|
|
65
|
+
var _a, _b;
|
|
66
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
66
67
|
if (this.verbose) {
|
|
67
68
|
logger.logToStderr(`Checking if site ${url} exists...`);
|
|
68
69
|
}
|
|
@@ -74,14 +75,13 @@ class SpoTenantAppCatalogAddCommand extends SpoCommand_1.default {
|
|
|
74
75
|
_: []
|
|
75
76
|
}
|
|
76
77
|
};
|
|
77
|
-
|
|
78
|
-
.executeCommandWithOutput(spoSiteGetCommand, siteGetOptions)
|
|
79
|
-
.then(() => {
|
|
78
|
+
try {
|
|
79
|
+
yield Cli_1.Cli.executeCommandWithOutput(spoSiteGetCommand, siteGetOptions);
|
|
80
80
|
if (this.verbose) {
|
|
81
81
|
logger.logToStderr(`Found site ${url}`);
|
|
82
82
|
}
|
|
83
83
|
if (!force) {
|
|
84
|
-
|
|
84
|
+
throw new Command_1.CommandError(`Another site exists at ${url}`);
|
|
85
85
|
}
|
|
86
86
|
if (this.verbose) {
|
|
87
87
|
logger.logToStderr(`Deleting site ${url}...`);
|
|
@@ -90,24 +90,21 @@ class SpoTenantAppCatalogAddCommand extends SpoCommand_1.default {
|
|
|
90
90
|
url: url,
|
|
91
91
|
skipRecycleBin: true,
|
|
92
92
|
wait: true,
|
|
93
|
-
|
|
93
|
+
confirm: true,
|
|
94
94
|
verbose: this.verbose,
|
|
95
95
|
debug: this.debug
|
|
96
96
|
};
|
|
97
|
-
Cli_1.Cli
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
// some other error occurred
|
|
103
|
-
return reject(err.error);
|
|
97
|
+
yield Cli_1.Cli.executeCommand(spoSiteRemoveCommand, { options: Object.assign(Object.assign({}, siteRemoveOptions), { _: [] }) });
|
|
98
|
+
}
|
|
99
|
+
catch (err) {
|
|
100
|
+
if (((_a = err.error) === null || _a === void 0 ? void 0 : _a.message) !== 'File not Found' && ((_b = err.error) === null || _b === void 0 ? void 0 : _b.message) !== '404 FILE NOT FOUND') {
|
|
101
|
+
throw err.error || err;
|
|
104
102
|
}
|
|
105
103
|
if (this.verbose) {
|
|
106
104
|
logger.logToStderr(`No site found at ${url}`);
|
|
107
105
|
}
|
|
108
|
-
//
|
|
109
|
-
|
|
110
|
-
});
|
|
106
|
+
// Site not found. Continue
|
|
107
|
+
}
|
|
111
108
|
});
|
|
112
109
|
}
|
|
113
110
|
createAppCatalog(options, logger) {
|
|
@@ -23,6 +23,8 @@ const validation_1 = require("../../../../utils/validation");
|
|
|
23
23
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
24
24
|
const commands_1 = require("../../commands");
|
|
25
25
|
const os = require("os");
|
|
26
|
+
const Cli_1 = require("../../../../cli/Cli");
|
|
27
|
+
const spoListItemListCommand = require("../listitem/listitem-list");
|
|
26
28
|
const request_1 = require("../../../../request");
|
|
27
29
|
class SpoTenantApplicationCustomizerSetCommand extends SpoCommand_1.default {
|
|
28
30
|
get name() {
|
|
@@ -46,6 +48,20 @@ class SpoTenantApplicationCustomizerSetCommand extends SpoCommand_1.default {
|
|
|
46
48
|
if (!appCatalogUrl) {
|
|
47
49
|
throw 'No app catalog URL found';
|
|
48
50
|
}
|
|
51
|
+
if (args.options.newClientSideComponentId !== undefined) {
|
|
52
|
+
const componentManifest = yield this.getComponentManifest(appCatalogUrl, args.options.newClientSideComponentId, logger);
|
|
53
|
+
const clientComponentManifest = JSON.parse(componentManifest.ClientComponentManifest);
|
|
54
|
+
if (clientComponentManifest.extensionType !== "ApplicationCustomizer") {
|
|
55
|
+
throw `The extension type of this component is not of type 'ApplicationCustomizer' but of type '${clientComponentManifest.extensionType}'`;
|
|
56
|
+
}
|
|
57
|
+
const solution = yield this.getSolutionFromAppCatalog(appCatalogUrl, componentManifest.SolutionId, logger);
|
|
58
|
+
if (!solution.ContainsTenantWideExtension) {
|
|
59
|
+
throw `The solution does not contain an extension that can be deployed to all sites. Make sure that you've entered the correct component Id.`;
|
|
60
|
+
}
|
|
61
|
+
else if (!solution.SkipFeatureDeployment) {
|
|
62
|
+
throw 'The solution has not been deployed to all sites. Make sure to deploy this solution to all sites.';
|
|
63
|
+
}
|
|
64
|
+
}
|
|
49
65
|
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
|
|
50
66
|
const listItemId = yield this.getListItemId(appCatalogUrl, args.options, listServerRelativeUrl, logger);
|
|
51
67
|
yield this.updateTenantWideExtension(appCatalogUrl, args.options, listServerRelativeUrl, listItemId, logger);
|
|
@@ -72,9 +88,59 @@ class SpoTenantApplicationCustomizerSetCommand extends SpoCommand_1.default {
|
|
|
72
88
|
return listItemInstances[0].Id;
|
|
73
89
|
});
|
|
74
90
|
}
|
|
91
|
+
getComponentManifest(appCatalogUrl, clientSideComponentId, logger) {
|
|
92
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
93
|
+
if (this.verbose) {
|
|
94
|
+
logger.logToStderr('Retrieving component manifest item from the ComponentManifests list on the app catalog site so that we get the solution id');
|
|
95
|
+
}
|
|
96
|
+
const camlQuery = `<View><ViewFields><FieldRef Name='ClientComponentId'></FieldRef><FieldRef Name='SolutionId'></FieldRef><FieldRef Name='ClientComponentManifest'></FieldRef></ViewFields><Query><Where><Eq><FieldRef Name='ClientComponentId' /><Value Type='Guid'>${clientSideComponentId}</Value></Eq></Where></Query></View>`;
|
|
97
|
+
const commandOptions = {
|
|
98
|
+
webUrl: appCatalogUrl,
|
|
99
|
+
listUrl: `${urlUtil_1.urlUtil.getServerRelativeSiteUrl(appCatalogUrl)}/Lists/ComponentManifests`,
|
|
100
|
+
camlQuery: camlQuery,
|
|
101
|
+
verbose: this.verbose,
|
|
102
|
+
debug: this.debug,
|
|
103
|
+
output: 'json'
|
|
104
|
+
};
|
|
105
|
+
const output = yield Cli_1.Cli.executeCommandWithOutput(spoListItemListCommand, { options: Object.assign(Object.assign({}, commandOptions), { _: [] }) });
|
|
106
|
+
if (this.verbose) {
|
|
107
|
+
logger.logToStderr(output.stderr);
|
|
108
|
+
}
|
|
109
|
+
const outputParsed = JSON.parse(output.stdout);
|
|
110
|
+
if (outputParsed.length === 0) {
|
|
111
|
+
throw 'No component found with the specified clientSideComponentId found in the component manifest list. Make sure that the application is added to the application catalog';
|
|
112
|
+
}
|
|
113
|
+
return outputParsed[0];
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
getSolutionFromAppCatalog(appCatalogUrl, solutionId, logger) {
|
|
117
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
118
|
+
if (this.verbose) {
|
|
119
|
+
logger.logToStderr(`Retrieving solution with id ${solutionId} from the application catalog`);
|
|
120
|
+
}
|
|
121
|
+
const camlQuery = `<View><ViewFields><FieldRef Name='SkipFeatureDeployment'></FieldRef><FieldRef Name='ContainsTenantWideExtension'></FieldRef></ViewFields><Query><Where><Eq><FieldRef Name='AppProductID' /><Value Type='Guid'>${solutionId}</Value></Eq></Where></Query></View>`;
|
|
122
|
+
const commandOptions = {
|
|
123
|
+
webUrl: appCatalogUrl,
|
|
124
|
+
listUrl: `${urlUtil_1.urlUtil.getServerRelativeSiteUrl(appCatalogUrl)}/AppCatalog`,
|
|
125
|
+
camlQuery: camlQuery,
|
|
126
|
+
verbose: this.verbose,
|
|
127
|
+
debug: this.debug,
|
|
128
|
+
output: 'json'
|
|
129
|
+
};
|
|
130
|
+
const output = yield Cli_1.Cli.executeCommandWithOutput(spoListItemListCommand, { options: Object.assign(Object.assign({}, commandOptions), { _: [] }) });
|
|
131
|
+
if (this.verbose) {
|
|
132
|
+
logger.logToStderr(output.stderr);
|
|
133
|
+
}
|
|
134
|
+
const outputParsed = JSON.parse(output.stdout);
|
|
135
|
+
if (outputParsed.length === 0) {
|
|
136
|
+
throw `No component found with the solution id ${solutionId}. Make sure that the solution is available in the app catalog`;
|
|
137
|
+
}
|
|
138
|
+
return outputParsed[0];
|
|
139
|
+
});
|
|
140
|
+
}
|
|
75
141
|
updateTenantWideExtension(appCatalogUrl, options, listServerRelativeUrl, itemId, logger) {
|
|
76
142
|
return __awaiter(this, void 0, void 0, function* () {
|
|
77
|
-
const { title, id, clientSideComponentId, newTitle, clientSideComponentProperties, webTemplate } = options;
|
|
143
|
+
const { title, id, clientSideComponentId, newTitle, newClientSideComponentId, clientSideComponentProperties, webTemplate } = options;
|
|
78
144
|
if (this.verbose) {
|
|
79
145
|
logger.logToStderr(`Updating tenant-wide application customizer: "${title || id || clientSideComponentId}"...`);
|
|
80
146
|
}
|
|
@@ -85,6 +151,12 @@ class SpoTenantApplicationCustomizerSetCommand extends SpoCommand_1.default {
|
|
|
85
151
|
FieldValue: newTitle
|
|
86
152
|
});
|
|
87
153
|
}
|
|
154
|
+
if (newClientSideComponentId !== undefined) {
|
|
155
|
+
formValues.push({
|
|
156
|
+
FieldName: 'TenantWideExtensionComponentId',
|
|
157
|
+
FieldValue: newClientSideComponentId
|
|
158
|
+
});
|
|
159
|
+
}
|
|
88
160
|
if (clientSideComponentProperties !== undefined) {
|
|
89
161
|
formValues.push({
|
|
90
162
|
FieldName: 'TenantWideExtensionComponentProperties',
|
|
@@ -118,6 +190,7 @@ _SpoTenantApplicationCustomizerSetCommand_instances = new WeakSet(), _SpoTenantA
|
|
|
118
190
|
id: typeof args.options.id !== 'undefined',
|
|
119
191
|
clientSideComponentId: typeof args.options.clientSideComponentId !== 'undefined',
|
|
120
192
|
newTitle: typeof args.options.newTitle !== 'undefined',
|
|
193
|
+
newClientSideComponentId: typeof args.options.newClientSideComponentId !== 'undefined',
|
|
121
194
|
clientSideComponentProperties: typeof args.options.clientSideComponentProperties !== 'undefined',
|
|
122
195
|
webTemplate: typeof args.options.webTemplate !== 'undefined'
|
|
123
196
|
});
|
|
@@ -131,6 +204,8 @@ _SpoTenantApplicationCustomizerSetCommand_instances = new WeakSet(), _SpoTenantA
|
|
|
131
204
|
option: '-c, --clientSideComponentId [clientSideComponentId]'
|
|
132
205
|
}, {
|
|
133
206
|
option: '--newTitle [newTitle]'
|
|
207
|
+
}, {
|
|
208
|
+
option: '--newClientSideComponentId [newClientSideComponentId]'
|
|
134
209
|
}, {
|
|
135
210
|
option: '-p, --clientSideComponentProperties [clientSideComponentProperties]'
|
|
136
211
|
}, {
|
|
@@ -144,7 +219,10 @@ _SpoTenantApplicationCustomizerSetCommand_instances = new WeakSet(), _SpoTenantA
|
|
|
144
219
|
if (args.options.clientSideComponentId && !validation_1.validation.isValidGuid(args.options.clientSideComponentId)) {
|
|
145
220
|
return `${args.options.clientSideComponentId} is not a valid GUID`;
|
|
146
221
|
}
|
|
147
|
-
if (
|
|
222
|
+
if (args.options.newClientSideComponentId && !validation_1.validation.isValidGuid(args.options.newClientSideComponentId)) {
|
|
223
|
+
return `${args.options.newClientSideComponentId} is not a valid GUID`;
|
|
224
|
+
}
|
|
225
|
+
if (!args.options.newTitle && !args.options.newClientSideComponentId && !args.options.clientSideComponentProperties && !args.options.webTemplate) {
|
|
148
226
|
return `Please specify an option to be updated`;
|
|
149
227
|
}
|
|
150
228
|
return true;
|
|
@@ -13,15 +13,19 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
13
13
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
14
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
15
|
};
|
|
16
|
-
var _SpoTenantCommandSetSetCommand_instances, _SpoTenantCommandSetSetCommand_initTelemetry, _SpoTenantCommandSetSetCommand_initOptions, _SpoTenantCommandSetSetCommand_initValidators;
|
|
16
|
+
var _SpoTenantCommandSetSetCommand_instances, _SpoTenantCommandSetSetCommand_initTelemetry, _SpoTenantCommandSetSetCommand_initOptions, _SpoTenantCommandSetSetCommand_initValidators, _SpoTenantCommandSetSetCommand_initOptionSets;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const validation_1 = require("../../../../utils/validation");
|
|
19
19
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
20
20
|
const commands_1 = require("../../commands");
|
|
21
|
+
const os = require("os");
|
|
21
22
|
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
23
|
+
const Cli_1 = require("../../../../cli/Cli");
|
|
24
|
+
const spoListItemListCommand = require("../listitem/listitem-list");
|
|
22
25
|
const request_1 = require("../../../../request");
|
|
23
26
|
const formatting_1 = require("../../../../utils/formatting");
|
|
24
27
|
const spo_1 = require("../../../../utils/spo");
|
|
28
|
+
const odata_1 = require("../../../../utils/odata");
|
|
25
29
|
class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
26
30
|
get name() {
|
|
27
31
|
return commands_1.default.TENANT_COMMANDSET_SET;
|
|
@@ -35,6 +39,7 @@ class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
|
35
39
|
__classPrivateFieldGet(this, _SpoTenantCommandSetSetCommand_instances, "m", _SpoTenantCommandSetSetCommand_initTelemetry).call(this);
|
|
36
40
|
__classPrivateFieldGet(this, _SpoTenantCommandSetSetCommand_instances, "m", _SpoTenantCommandSetSetCommand_initOptions).call(this);
|
|
37
41
|
__classPrivateFieldGet(this, _SpoTenantCommandSetSetCommand_instances, "m", _SpoTenantCommandSetSetCommand_initValidators).call(this);
|
|
42
|
+
__classPrivateFieldGet(this, _SpoTenantCommandSetSetCommand_instances, "m", _SpoTenantCommandSetSetCommand_initOptionSets).call(this);
|
|
38
43
|
}
|
|
39
44
|
commandAction(logger, args) {
|
|
40
45
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -43,34 +48,97 @@ class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
|
43
48
|
if (!appCatalogUrl) {
|
|
44
49
|
throw 'No app catalog URL found';
|
|
45
50
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
51
|
+
if (args.options.newClientSideComponentId !== undefined) {
|
|
52
|
+
const componentManifest = yield this.getComponentManifest(appCatalogUrl, args.options.newClientSideComponentId, logger);
|
|
53
|
+
const clientComponentManifest = JSON.parse(componentManifest.ClientComponentManifest);
|
|
54
|
+
if (clientComponentManifest.extensionType !== "ListViewCommandSet") {
|
|
55
|
+
throw `The extension type of this component is not of type 'ListViewCommandSet' but of type '${clientComponentManifest.extensionType}'`;
|
|
56
|
+
}
|
|
57
|
+
const solution = yield this.getSolutionFromAppCatalog(appCatalogUrl, componentManifest.SolutionId, logger);
|
|
58
|
+
if (!solution.ContainsTenantWideExtension) {
|
|
59
|
+
throw `The solution does not contain an extension that can be deployed to all sites. Make sure that you've entered the correct component Id.`;
|
|
60
|
+
}
|
|
61
|
+
else if (!solution.SkipFeatureDeployment) {
|
|
62
|
+
throw 'The solution has not been deployed to all sites. Make sure to deploy this solution to all sites.';
|
|
63
|
+
}
|
|
50
64
|
}
|
|
51
|
-
|
|
65
|
+
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
|
|
66
|
+
const listItemId = yield this.getListItemId(appCatalogUrl, args.options, listServerRelativeUrl, logger);
|
|
67
|
+
yield this.updateTenantWideExtension(logger, appCatalogUrl, args.options, listServerRelativeUrl, listItemId);
|
|
52
68
|
}
|
|
53
69
|
catch (err) {
|
|
54
70
|
this.handleRejectedODataJsonPromise(err);
|
|
55
71
|
}
|
|
56
72
|
});
|
|
57
73
|
}
|
|
58
|
-
|
|
74
|
+
getComponentManifest(appCatalogUrl, clientSideComponentId, logger) {
|
|
59
75
|
return __awaiter(this, void 0, void 0, function* () {
|
|
60
76
|
if (this.verbose) {
|
|
61
|
-
logger.logToStderr(
|
|
77
|
+
logger.logToStderr('Retrieving component manifest item from the ComponentManifests list on the app catalog site so that we get the solution id');
|
|
62
78
|
}
|
|
63
|
-
const
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
79
|
+
const camlQuery = `<View><ViewFields><FieldRef Name='ClientComponentId'></FieldRef><FieldRef Name='SolutionId'></FieldRef><FieldRef Name='ClientComponentManifest'></FieldRef></ViewFields><Query><Where><Eq><FieldRef Name='ClientComponentId' /><Value Type='Guid'>${clientSideComponentId}</Value></Eq></Where></Query></View>`;
|
|
80
|
+
const commandOptions = {
|
|
81
|
+
webUrl: appCatalogUrl,
|
|
82
|
+
listUrl: `${urlUtil_1.urlUtil.getServerRelativeSiteUrl(appCatalogUrl)}/Lists/ComponentManifests`,
|
|
83
|
+
camlQuery: camlQuery,
|
|
84
|
+
verbose: this.verbose,
|
|
85
|
+
debug: this.debug,
|
|
86
|
+
output: 'json'
|
|
69
87
|
};
|
|
70
|
-
|
|
88
|
+
const output = yield Cli_1.Cli.executeCommandWithOutput(spoListItemListCommand, { options: Object.assign(Object.assign({}, commandOptions), { _: [] }) });
|
|
89
|
+
if (this.verbose) {
|
|
90
|
+
logger.logToStderr(output.stderr);
|
|
91
|
+
}
|
|
92
|
+
const outputParsed = JSON.parse(output.stdout);
|
|
93
|
+
if (outputParsed.length === 0) {
|
|
94
|
+
throw 'No component found with the specified clientSideComponentId found in the component manifest list. Make sure that the application is added to the application catalog';
|
|
95
|
+
}
|
|
96
|
+
return outputParsed[0];
|
|
71
97
|
});
|
|
72
98
|
}
|
|
73
|
-
|
|
99
|
+
getSolutionFromAppCatalog(appCatalogUrl, solutionId, logger) {
|
|
100
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
101
|
+
if (this.verbose) {
|
|
102
|
+
logger.logToStderr(`Retrieving solution with id ${solutionId} from the application catalog`);
|
|
103
|
+
}
|
|
104
|
+
const camlQuery = `<View><ViewFields><FieldRef Name='SkipFeatureDeployment'></FieldRef><FieldRef Name='ContainsTenantWideExtension'></FieldRef></ViewFields><Query><Where><Eq><FieldRef Name='AppProductID' /><Value Type='Guid'>${solutionId}</Value></Eq></Where></Query></View>`;
|
|
105
|
+
const commandOptions = {
|
|
106
|
+
webUrl: appCatalogUrl,
|
|
107
|
+
listUrl: `${urlUtil_1.urlUtil.getServerRelativeSiteUrl(appCatalogUrl)}/AppCatalog`,
|
|
108
|
+
camlQuery: camlQuery,
|
|
109
|
+
verbose: this.verbose,
|
|
110
|
+
debug: this.debug,
|
|
111
|
+
output: 'json'
|
|
112
|
+
};
|
|
113
|
+
const output = yield Cli_1.Cli.executeCommandWithOutput(spoListItemListCommand, { options: Object.assign(Object.assign({}, commandOptions), { _: [] }) });
|
|
114
|
+
if (this.verbose) {
|
|
115
|
+
logger.logToStderr(output.stderr);
|
|
116
|
+
}
|
|
117
|
+
const outputParsed = JSON.parse(output.stdout);
|
|
118
|
+
if (outputParsed.length === 0) {
|
|
119
|
+
throw `No component found with the solution id ${solutionId}. Make sure that the solution is available in the app catalog`;
|
|
120
|
+
}
|
|
121
|
+
return outputParsed[0];
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
getListItemId(appCatalogUrl, options, listServerRelativeUrl, logger) {
|
|
125
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
126
|
+
const { title, id, clientSideComponentId } = options;
|
|
127
|
+
const filter = title ? `Title eq '${title}'` : id ? `Id eq '${id}'` : `TenantWideExtensionComponentId eq '${clientSideComponentId}'`;
|
|
128
|
+
if (this.verbose) {
|
|
129
|
+
logger.logToStderr(`Getting tenant-wide listview commandset: "${title || id || clientSideComponentId}"...`);
|
|
130
|
+
}
|
|
131
|
+
const listItemInstances = yield odata_1.odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Items?$filter=startswith(TenantWideExtensionLocation, 'ClientSideExtension.ListViewCommandSet') and ${filter}`);
|
|
132
|
+
if (!listItemInstances || listItemInstances.length === 0) {
|
|
133
|
+
throw 'The specified listview commandset was not found';
|
|
134
|
+
}
|
|
135
|
+
if (listItemInstances.length > 1) {
|
|
136
|
+
throw `Multiple listview commandsets with ${title ? `title '${title}'` : `ClientSideComponentId '${clientSideComponentId}'`} found. Please disambiguate using IDs: ${os.EOL}${listItemInstances.map(item => `- ${item.Id}`).join(os.EOL)}`;
|
|
137
|
+
}
|
|
138
|
+
return listItemInstances[0].Id;
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
updateTenantWideExtension(logger, appCatalogUrl, options, listServerRelativeUrl, listItemId) {
|
|
74
142
|
return __awaiter(this, void 0, void 0, function* () {
|
|
75
143
|
if (this.verbose) {
|
|
76
144
|
logger.logToStderr('Updating tenant wide extension to the TenantWideExtensions list');
|
|
@@ -82,10 +150,10 @@ class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
|
82
150
|
FieldValue: options.newTitle
|
|
83
151
|
});
|
|
84
152
|
}
|
|
85
|
-
if (options.
|
|
153
|
+
if (options.newClientSideComponentId !== undefined) {
|
|
86
154
|
formValues.push({
|
|
87
155
|
FieldName: 'TenantWideExtensionComponentId',
|
|
88
|
-
FieldValue: options.
|
|
156
|
+
FieldValue: options.newClientSideComponentId
|
|
89
157
|
});
|
|
90
158
|
}
|
|
91
159
|
if (options.location !== undefined) {
|
|
@@ -113,7 +181,7 @@ class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
|
113
181
|
});
|
|
114
182
|
}
|
|
115
183
|
const requestOptions = {
|
|
116
|
-
url: `${appCatalogUrl}/_api/web/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Items(${
|
|
184
|
+
url: `${appCatalogUrl}/_api/web/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Items(${listItemId})/ValidateUpdateListItem()`,
|
|
117
185
|
headers: {
|
|
118
186
|
'accept': 'application/json;odata=nometadata'
|
|
119
187
|
},
|
|
@@ -149,9 +217,12 @@ class SpoTenantCommandSetSetCommand extends SpoCommand_1.default {
|
|
|
149
217
|
_SpoTenantCommandSetSetCommand_instances = new WeakSet(), _SpoTenantCommandSetSetCommand_initTelemetry = function _SpoTenantCommandSetSetCommand_initTelemetry() {
|
|
150
218
|
this.telemetry.push((args) => {
|
|
151
219
|
Object.assign(this.telemetryProperties, {
|
|
220
|
+
title: typeof args.options.title !== 'undefined',
|
|
221
|
+
id: typeof args.options.id !== 'undefined',
|
|
222
|
+
clientSideComponentId: typeof args.options.clientSideComponentId !== 'undefined',
|
|
152
223
|
newTitle: typeof args.options.newTitle !== 'undefined',
|
|
153
224
|
listType: args.options.listType,
|
|
154
|
-
|
|
225
|
+
newClientSideComponentId: typeof args.options.newClientSideComponentId !== 'undefined',
|
|
155
226
|
clientSideComponentProperties: typeof args.options.clientSideComponentProperties !== 'undefined',
|
|
156
227
|
webTemplate: typeof args.options.webTemplate !== 'undefined',
|
|
157
228
|
location: args.options.location
|
|
@@ -159,14 +230,18 @@ _SpoTenantCommandSetSetCommand_instances = new WeakSet(), _SpoTenantCommandSetSe
|
|
|
159
230
|
});
|
|
160
231
|
}, _SpoTenantCommandSetSetCommand_initOptions = function _SpoTenantCommandSetSetCommand_initOptions() {
|
|
161
232
|
this.options.unshift({
|
|
162
|
-
option: '-i, --id
|
|
233
|
+
option: '-i, --id [id]'
|
|
234
|
+
}, {
|
|
235
|
+
option: '-t, --title [title]'
|
|
236
|
+
}, {
|
|
237
|
+
option: '-c, --clientSideComponentId [clientSideComponentId]'
|
|
163
238
|
}, {
|
|
164
|
-
option: '
|
|
239
|
+
option: '--newTitle [newTitle]'
|
|
165
240
|
}, {
|
|
166
241
|
option: '-l, --listType [listType]',
|
|
167
242
|
autocomplete: SpoTenantCommandSetSetCommand.listTypes
|
|
168
243
|
}, {
|
|
169
|
-
option: '
|
|
244
|
+
option: '--newClientSideComponentId [newClientSideComponentId]'
|
|
170
245
|
}, {
|
|
171
246
|
option: '-p, --clientSideComponentProperties [clientSideComponentProperties]'
|
|
172
247
|
}, {
|
|
@@ -179,15 +254,21 @@ _SpoTenantCommandSetSetCommand_instances = new WeakSet(), _SpoTenantCommandSetSe
|
|
|
179
254
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
180
255
|
if (!args.options.newTitle &&
|
|
181
256
|
!args.options.listType &&
|
|
182
|
-
!args.options.
|
|
257
|
+
!args.options.newClientSideComponentId &&
|
|
183
258
|
!args.options.clientSideComponentProperties &&
|
|
184
259
|
!args.options.webTemplate &&
|
|
185
260
|
!args.options.location) {
|
|
186
261
|
return 'Specify at least one property to update';
|
|
187
262
|
}
|
|
263
|
+
if (args.options.id && isNaN(parseInt(args.options.id))) {
|
|
264
|
+
return `${args.options.id} is not a number`;
|
|
265
|
+
}
|
|
188
266
|
if (args.options.clientSideComponentId && !validation_1.validation.isValidGuid(args.options.clientSideComponentId)) {
|
|
189
267
|
return `${args.options.clientSideComponentId} is not a valid GUID`;
|
|
190
268
|
}
|
|
269
|
+
if (args.options.newClientSideComponentId && !validation_1.validation.isValidGuid(args.options.newClientSideComponentId)) {
|
|
270
|
+
return `${args.options.newClientSideComponentId} is not a valid GUID`;
|
|
271
|
+
}
|
|
191
272
|
if (args.options.listType && SpoTenantCommandSetSetCommand.listTypes.indexOf(args.options.listType) < 0) {
|
|
192
273
|
return `${args.options.listType} is not a valid list type. Allowed values are ${SpoTenantCommandSetSetCommand.listTypes.join(', ')}`;
|
|
193
274
|
}
|
|
@@ -196,6 +277,8 @@ _SpoTenantCommandSetSetCommand_instances = new WeakSet(), _SpoTenantCommandSetSe
|
|
|
196
277
|
}
|
|
197
278
|
return true;
|
|
198
279
|
}));
|
|
280
|
+
}, _SpoTenantCommandSetSetCommand_initOptionSets = function _SpoTenantCommandSetSetCommand_initOptionSets() {
|
|
281
|
+
this.optionSets.push({ options: ['title', 'id', 'clientSideComponentId'] });
|
|
199
282
|
};
|
|
200
283
|
SpoTenantCommandSetSetCommand.listTypes = ['List', 'Library', 'SitePages'];
|
|
201
284
|
SpoTenantCommandSetSetCommand.locations = ['ContextMenu', 'CommandBar', 'Both'];
|