@pnp/cli-microsoft365 5.9.0-beta.fd24b4e → 5.9.0
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/.eslintrc.js +15 -2
- package/README.md +5 -0
- package/dist/Command.js +16 -2
- package/dist/m365/aad/commands/app/app-add.js +37 -13
- package/dist/m365/commands/status.js +6 -1
- package/dist/m365/outlook/commands/mail/mail-send.js +55 -31
- package/dist/m365/planner/commands/bucket/bucket-get.js +1 -1
- package/dist/m365/pp/commands/Environment.js +3 -0
- package/dist/m365/pp/commands/card/card-get.js +110 -0
- package/dist/m365/pp/commands/card/card-list.js +68 -0
- package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +6 -12
- package/dist/m365/pp/commands/environment/environment-get.js +75 -0
- package/dist/m365/pp/commands/gateway/gateway-get.js +70 -0
- package/dist/m365/pp/commands/solution/solution-get.js +117 -0
- package/dist/m365/pp/commands.js +5 -0
- package/dist/m365/spfx/commands/project/project-doctor.js +4 -1
- package/dist/m365/spfx/commands/project/project-externalize.js +4 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010001_YORC_version.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010002_YORC_isCreatingSolution.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010003_YORC_packageManager.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010004_YORC_componentType.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010005_YORC_environment.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010006_YORC_framework.js +3 -2
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010007_YORC_isDomainIsolated.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010008_YORC_nodeVersion.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010009_YORC_sdkVersions_microsoft_graph_client.js +56 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010010_YORC_sdkVersions_teams_js.js +56 -0
- package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.16.0-beta.1.js → upgrade-1.16.0-beta.2.js} +44 -28
- package/dist/m365/spfx/commands/project/project-upgrade.js +1 -1
- package/dist/m365/spfx/commands/spfx-doctor.js +3 -3
- package/dist/m365/spo/commands/contenttype/contenttype-add.js +82 -43
- package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +53 -21
- package/dist/m365/spo/commands/contenttype/contenttype-get.js +35 -14
- package/dist/m365/spo/commands/eventreceiver/EventReceiver.js +3 -0
- package/dist/m365/spo/commands/eventreceiver/eventreceiver-remove.js +182 -0
- package/dist/m365/spo/commands/field/field-add.js +26 -1
- package/dist/m365/spo/commands/field/field-set.js +23 -13
- package/dist/m365/spo/commands/file/file-roleinheritance-break.js +129 -0
- package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
- package/dist/m365/spo/commands/group/AssociatedGroupPropertiesCollection.js +3 -0
- package/dist/m365/spo/commands/group/group-list.js +49 -10
- package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
- package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
- package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
- package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
- package/dist/m365/spo/commands/list/list-roleassignment-add.js +10 -10
- package/dist/m365/spo/commands/list/list-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands/list/list-roleinheritance-break.js +14 -6
- package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +15 -7
- package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
- package/dist/m365/spo/commands/list/list-webhook-get.js +17 -10
- package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
- package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
- package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
- package/dist/m365/spo/commands/listitem/listitem-add.js +24 -14
- package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +18 -8
- package/dist/m365/spo/commands/listitem/listitem-get.js +18 -8
- package/dist/m365/spo/commands/listitem/listitem-isrecord.js +20 -10
- package/dist/m365/spo/commands/listitem/listitem-list.js +27 -11
- package/dist/m365/spo/commands/listitem/listitem-record-declare.js +19 -12
- package/dist/m365/spo/commands/listitem/listitem-record-undeclare.js +24 -21
- package/dist/m365/spo/commands/listitem/listitem-remove.js +19 -11
- package/dist/m365/spo/commands/listitem/listitem-roleassignment-add.js +239 -0
- package/dist/m365/spo/commands/listitem/listitem-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +13 -5
- package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +14 -6
- package/dist/m365/spo/commands/listitem/listitem-set.js +52 -44
- package/dist/m365/spo/commands/web/web-roleassignment-add.js +10 -10
- package/dist/m365/spo/commands/web/web-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands/web/web-roleinheritance-break.js +100 -0
- package/dist/m365/spo/commands.js +5 -0
- package/dist/m365/teams/commands/channel/channel-add.js +9 -9
- package/dist/m365/todo/commands/list/list-get.js +89 -0
- package/dist/m365/todo/commands/task/task-add.js +55 -3
- package/dist/m365/todo/commands/task/task-get.js +108 -0
- package/dist/m365/todo/commands/task/task-set.js +53 -1
- package/dist/m365/todo/commands.js +2 -0
- package/docs/docs/_clisettings.md +19 -0
- package/docs/docs/cmd/outlook/mail/mail-send.md +13 -0
- package/docs/docs/cmd/planner/bucket/bucket-add.md +29 -0
- package/docs/docs/cmd/planner/bucket/bucket-get.md +29 -0
- package/docs/docs/cmd/planner/bucket/bucket-list.md +30 -0
- package/docs/docs/cmd/planner/bucket/bucket-remove.md +4 -0
- package/docs/docs/cmd/planner/bucket/bucket-set.md +4 -0
- package/docs/docs/cmd/planner/plan/plan-add.md +123 -0
- package/docs/docs/cmd/planner/plan/plan-get.md +75 -0
- package/docs/docs/cmd/planner/plan/plan-list.md +45 -0
- package/docs/docs/cmd/planner/plan/plan-remove.md +4 -0
- package/docs/docs/cmd/pp/card/card-get.md +51 -0
- package/docs/docs/cmd/pp/card/card-list.md +33 -0
- package/docs/docs/cmd/pp/dataverse/dataverse-table-list.md +2 -2
- package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
- package/docs/docs/cmd/pp/environment/environment-list.md +1 -1
- package/docs/docs/cmd/pp/gateway/gateway-get.md +24 -0
- package/docs/docs/cmd/pp/solution/solution-get.md +51 -0
- package/docs/docs/cmd/pp/solution/solution-list.md +2 -2
- package/docs/docs/cmd/spfx/project/project-rename.md +1 -14
- package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
- package/docs/docs/cmd/spo/contenttype/contenttype-add.md +20 -2
- package/docs/docs/cmd/spo/contenttype/contenttype-field-remove.md +22 -4
- package/docs/docs/cmd/spo/contenttype/contenttype-get.md +21 -3
- package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
- package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +69 -0
- package/docs/docs/cmd/spo/field/field-add.md +20 -2
- package/docs/docs/cmd/spo/field/field-set.md +11 -2
- package/docs/docs/cmd/spo/file/file-roleinheritance-break.md +54 -0
- package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
- package/docs/docs/cmd/spo/group/group-list.md +10 -1
- package/docs/docs/cmd/spo/list/list-contenttype-add.md +16 -7
- package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
- package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
- package/docs/docs/cmd/spo/list/list-contenttype-remove.md +17 -8
- package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +11 -8
- package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +14 -5
- package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
- package/docs/docs/cmd/spo/list/list-webhook-get.md +16 -7
- package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
- package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
- package/docs/docs/cmd/spo/list/list-webhook-set.md +14 -12
- package/docs/docs/cmd/spo/listitem/listitem-add.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-attachment-list.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-get.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-isrecord.md +12 -2
- package/docs/docs/cmd/spo/listitem/listitem-list.md +12 -3
- package/docs/docs/cmd/spo/listitem/listitem-record-declare.md +7 -4
- package/docs/docs/cmd/spo/listitem/listitem-record-undeclare.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-remove.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-roleassignment-add.md +81 -0
- package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +7 -4
- package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +11 -2
- package/docs/docs/cmd/spo/listitem/listitem-set.md +7 -4
- package/docs/docs/cmd/spo/web/web-roleinheritance-break.md +44 -0
- package/docs/docs/cmd/teams/channel/channel-add.md +4 -4
- package/docs/docs/cmd/tenant/id/id-get.md +20 -0
- package/docs/docs/cmd/tenant/report/report-activeusercounts.md +35 -0
- package/docs/docs/cmd/tenant/report/report-activeuserdetail.md +49 -0
- package/docs/docs/cmd/tenant/report/report-office365activationcounts.md +32 -0
- package/docs/docs/cmd/tenant/report/report-office365activationsusercounts.md +30 -0
- package/docs/docs/cmd/tenant/report/report-office365activationsuserdetail.md +36 -0
- package/docs/docs/cmd/tenant/report/report-servicesusercounts.md +41 -0
- package/docs/docs/cmd/tenant/security/security-alerts-list.md +105 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-get.md +87 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-list.md +91 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-get.md +62 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-list.md +51 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-get.md +64 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-list.md +52 -0
- package/docs/docs/cmd/todo/list/list-get.md +61 -0
- package/docs/docs/cmd/todo/task/task-add.md +32 -5
- package/docs/docs/cmd/todo/task/task-get.md +75 -0
- package/docs/docs/cmd/todo/task/task-set.md +29 -2
- package/package.json +12 -3
|
@@ -13,7 +13,7 @@ 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 _SpoGroupListCommand_instances, _SpoGroupListCommand_initOptions, _SpoGroupListCommand_initValidators;
|
|
16
|
+
var _SpoGroupListCommand_instances, _SpoGroupListCommand_initTelemetry, _SpoGroupListCommand_initOptions, _SpoGroupListCommand_initValidators;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const request_1 = require("../../../../request");
|
|
19
19
|
const validation_1 = require("../../../../utils/validation");
|
|
@@ -23,6 +23,7 @@ class SpoGroupListCommand extends SpoCommand_1.default {
|
|
|
23
23
|
constructor() {
|
|
24
24
|
super();
|
|
25
25
|
_SpoGroupListCommand_instances.add(this);
|
|
26
|
+
__classPrivateFieldGet(this, _SpoGroupListCommand_instances, "m", _SpoGroupListCommand_initTelemetry).call(this);
|
|
26
27
|
__classPrivateFieldGet(this, _SpoGroupListCommand_instances, "m", _SpoGroupListCommand_initOptions).call(this);
|
|
27
28
|
__classPrivateFieldGet(this, _SpoGroupListCommand_instances, "m", _SpoGroupListCommand_initValidators).call(this);
|
|
28
29
|
}
|
|
@@ -33,34 +34,72 @@ class SpoGroupListCommand extends SpoCommand_1.default {
|
|
|
33
34
|
return 'Lists all the groups within specific web';
|
|
34
35
|
}
|
|
35
36
|
defaultProperties() {
|
|
36
|
-
return ['Id', 'Title', 'LoginName', 'IsHiddenInUI', 'PrincipalType'];
|
|
37
|
+
return ['Id', 'Title', 'LoginName', 'IsHiddenInUI', 'PrincipalType', 'Type'];
|
|
37
38
|
}
|
|
38
39
|
commandAction(logger, args) {
|
|
39
40
|
return __awaiter(this, void 0, void 0, function* () {
|
|
40
41
|
if (this.verbose) {
|
|
41
42
|
logger.logToStderr(`Retrieving list of groups for specified web at ${args.options.webUrl}...`);
|
|
42
43
|
}
|
|
43
|
-
const
|
|
44
|
+
const baseUrl = `${args.options.webUrl}/_api/web`;
|
|
45
|
+
try {
|
|
46
|
+
if (!args.options.associatedGroupsOnly) {
|
|
47
|
+
yield this.getSiteGroups(baseUrl, logger);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
yield this.getAssociatedGroups(baseUrl, args.options, logger);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
this.handleRejectedODataJsonPromise(err);
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
getSiteGroups(baseUrl, logger) {
|
|
59
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
60
|
const requestOptions = {
|
|
45
|
-
url:
|
|
61
|
+
url: baseUrl + '/sitegroups',
|
|
46
62
|
headers: {
|
|
47
63
|
'accept': 'application/json;odata=nometadata'
|
|
48
64
|
},
|
|
49
65
|
responseType: 'json'
|
|
50
66
|
};
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
67
|
+
const groupProperties = yield request_1.default.get(requestOptions);
|
|
68
|
+
logger.log(groupProperties.value);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
getAssociatedGroups(baseUrl, options, logger) {
|
|
72
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
+
const requestOptions = {
|
|
74
|
+
url: baseUrl + '?$expand=AssociatedOwnerGroup,AssociatedMemberGroup,AssociatedVisitorGroup&$select=AssociatedOwnerGroup,AssociatedMemberGroup,AssociatedVisitorGroup',
|
|
75
|
+
headers: {
|
|
76
|
+
'accept': 'application/json;odata=nometadata'
|
|
77
|
+
},
|
|
78
|
+
responseType: 'json'
|
|
79
|
+
};
|
|
80
|
+
const groupProperties = yield request_1.default.get(requestOptions);
|
|
81
|
+
if (!options.output || options.output === 'json') {
|
|
82
|
+
logger.log(groupProperties);
|
|
54
83
|
}
|
|
55
|
-
|
|
56
|
-
|
|
84
|
+
else {
|
|
85
|
+
//converted to text friendly output
|
|
86
|
+
const output = Object.getOwnPropertyNames(groupProperties).map(prop => (Object.assign({ Type: prop }, groupProperties[prop])));
|
|
87
|
+
logger.log(output);
|
|
57
88
|
}
|
|
58
89
|
});
|
|
59
90
|
}
|
|
60
91
|
}
|
|
61
|
-
_SpoGroupListCommand_instances = new WeakSet(),
|
|
92
|
+
_SpoGroupListCommand_instances = new WeakSet(), _SpoGroupListCommand_initTelemetry = function _SpoGroupListCommand_initTelemetry() {
|
|
93
|
+
this.telemetry.push((args) => {
|
|
94
|
+
Object.assign(this.telemetryProperties, {
|
|
95
|
+
associatedGroupsOnly: (!(!args.options.associatedGroupsOnly)).toString()
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
}, _SpoGroupListCommand_initOptions = function _SpoGroupListCommand_initOptions() {
|
|
62
99
|
this.options.unshift({
|
|
63
100
|
option: '-u, --webUrl <webUrl>'
|
|
101
|
+
}, {
|
|
102
|
+
option: '--associatedGroupsOnly'
|
|
64
103
|
});
|
|
65
104
|
}, _SpoGroupListCommand_initValidators = function _SpoGroupListCommand_initValidators() {
|
|
66
105
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () { return validation_1.validation.isValidSharePointUrl(args.options.webUrl); }));
|
|
@@ -17,6 +17,7 @@ var _SpoListContentTypeAddCommand_instances, _SpoListContentTypeAddCommand_initT
|
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const request_1 = require("../../../../request");
|
|
19
19
|
const formatting_1 = require("../../../../utils/formatting");
|
|
20
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
20
21
|
const validation_1 = require("../../../../utils/validation");
|
|
21
22
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
23
|
const commands_1 = require("../../commands");
|
|
@@ -39,19 +40,25 @@ class SpoListContentTypeAddCommand extends SpoCommand_1.default {
|
|
|
39
40
|
commandAction(logger, args) {
|
|
40
41
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
42
|
if (this.verbose) {
|
|
42
|
-
const list = (args.options.listId ? args.options.listId : args.options.listTitle);
|
|
43
|
+
const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
|
|
43
44
|
logger.logToStderr(`Adding content type ${args.options.contentTypeId} to list ${list} in site at ${args.options.webUrl}...`);
|
|
44
45
|
}
|
|
45
|
-
let requestUrl =
|
|
46
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
46
47
|
if (args.options.listId) {
|
|
47
|
-
requestUrl
|
|
48
|
+
requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
48
49
|
}
|
|
49
|
-
else {
|
|
50
|
-
requestUrl
|
|
50
|
+
else if (args.options.listTitle) {
|
|
51
|
+
requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
51
52
|
}
|
|
52
|
-
|
|
53
|
+
else if (args.options.listUrl) {
|
|
54
|
+
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
55
|
+
requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
|
|
56
|
+
}
|
|
57
|
+
const requestBody = {
|
|
58
|
+
contentTypeId: args.options.contentTypeId
|
|
59
|
+
};
|
|
53
60
|
const requestOptions = {
|
|
54
|
-
url: requestUrl
|
|
61
|
+
url: `${requestUrl}/ContentTypes/AddAvailableContentType`,
|
|
55
62
|
headers: {
|
|
56
63
|
'accept': 'application/json;odata=nometadata'
|
|
57
64
|
},
|
|
@@ -67,17 +74,13 @@ class SpoListContentTypeAddCommand extends SpoCommand_1.default {
|
|
|
67
74
|
}
|
|
68
75
|
});
|
|
69
76
|
}
|
|
70
|
-
mapRequestBody(options) {
|
|
71
|
-
return {
|
|
72
|
-
contentTypeId: options.contentTypeId
|
|
73
|
-
};
|
|
74
|
-
}
|
|
75
77
|
}
|
|
76
78
|
_SpoListContentTypeAddCommand_instances = new WeakSet(), _SpoListContentTypeAddCommand_initTelemetry = function _SpoListContentTypeAddCommand_initTelemetry() {
|
|
77
79
|
this.telemetry.push((args) => {
|
|
78
80
|
Object.assign(this.telemetryProperties, {
|
|
79
81
|
listId: typeof args.options.listId !== 'undefined',
|
|
80
|
-
listTitle: typeof args.options.listTitle !== 'undefined'
|
|
82
|
+
listTitle: typeof args.options.listTitle !== 'undefined',
|
|
83
|
+
listUrl: typeof args.options.listUrl !== 'undefined'
|
|
81
84
|
});
|
|
82
85
|
});
|
|
83
86
|
}, _SpoListContentTypeAddCommand_initOptions = function _SpoListContentTypeAddCommand_initOptions() {
|
|
@@ -87,6 +90,8 @@ _SpoListContentTypeAddCommand_instances = new WeakSet(), _SpoListContentTypeAddC
|
|
|
87
90
|
option: '-l, --listId [listId]'
|
|
88
91
|
}, {
|
|
89
92
|
option: '-t, --listTitle [listTitle]'
|
|
93
|
+
}, {
|
|
94
|
+
option: '--listUrl [listUrl]'
|
|
90
95
|
}, {
|
|
91
96
|
option: '-c, --contentTypeId <contentTypeId>'
|
|
92
97
|
});
|
|
@@ -96,17 +101,15 @@ _SpoListContentTypeAddCommand_instances = new WeakSet(), _SpoListContentTypeAddC
|
|
|
96
101
|
if (isValidSharePointUrl !== true) {
|
|
97
102
|
return isValidSharePointUrl;
|
|
98
103
|
}
|
|
99
|
-
if (args.options.listId) {
|
|
100
|
-
|
|
101
|
-
return `${args.options.listId} is not a valid GUID`;
|
|
102
|
-
}
|
|
104
|
+
if (args.options.listId && !validation_1.validation.isValidGuid(args.options.listId)) {
|
|
105
|
+
return `${args.options.listId} is not a valid GUID`;
|
|
103
106
|
}
|
|
104
107
|
return true;
|
|
105
108
|
}));
|
|
106
109
|
}, _SpoListContentTypeAddCommand_initTypes = function _SpoListContentTypeAddCommand_initTypes() {
|
|
107
110
|
this.types.string.push('contentTypeId', 'c');
|
|
108
111
|
}, _SpoListContentTypeAddCommand_initOptionSets = function _SpoListContentTypeAddCommand_initOptionSets() {
|
|
109
|
-
this.optionSets.push(['listId', 'listTitle']);
|
|
112
|
+
this.optionSets.push(['listId', 'listTitle', 'listUrl']);
|
|
110
113
|
};
|
|
111
114
|
module.exports = new SpoListContentTypeAddCommand();
|
|
112
115
|
//# sourceMappingURL=list-contenttype-add.js.map
|
|
@@ -17,6 +17,7 @@ var _SpoListContentTypeDefaultSetCommand_instances, _SpoListContentTypeDefaultSe
|
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const request_1 = require("../../../../request");
|
|
19
19
|
const formatting_1 = require("../../../../utils/formatting");
|
|
20
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
20
21
|
const validation_1 = require("../../../../utils/validation");
|
|
21
22
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
23
|
const commands_1 = require("../../commands");
|
|
@@ -38,9 +39,17 @@ class SpoListContentTypeDefaultSetCommand extends SpoCommand_1.default {
|
|
|
38
39
|
}
|
|
39
40
|
commandAction(logger, args) {
|
|
40
41
|
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
42
|
+
let baseUrl = `${args.options.webUrl}/_api/web/`;
|
|
43
|
+
if (args.options.listId) {
|
|
44
|
+
baseUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
45
|
+
}
|
|
46
|
+
else if (args.options.listTitle) {
|
|
47
|
+
baseUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
48
|
+
}
|
|
49
|
+
else if (args.options.listUrl) {
|
|
50
|
+
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
51
|
+
baseUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
|
|
52
|
+
}
|
|
44
53
|
if (this.verbose) {
|
|
45
54
|
logger.logToStderr('Retrieving content type order...');
|
|
46
55
|
}
|
|
@@ -49,7 +58,6 @@ class SpoListContentTypeDefaultSetCommand extends SpoCommand_1.default {
|
|
|
49
58
|
// see if the specified content type is among the registered content types
|
|
50
59
|
// if it is, it means it's visible
|
|
51
60
|
const contentTypeIndex = contentTypeOrder.findIndex(ct => ct.StringValue.toUpperCase() === args.options.contentTypeId.toUpperCase());
|
|
52
|
-
let res;
|
|
53
61
|
if (contentTypeIndex > -1) {
|
|
54
62
|
if (this.debug) {
|
|
55
63
|
logger.logToStderr(`Content type ${args.options.contentTypeId} is visible in the list`);
|
|
@@ -70,7 +78,7 @@ class SpoListContentTypeDefaultSetCommand extends SpoCommand_1.default {
|
|
|
70
78
|
contentTypeOrder.unshift({
|
|
71
79
|
StringValue: args.options.contentTypeId
|
|
72
80
|
});
|
|
73
|
-
|
|
81
|
+
yield this.updateContentTypeOrder(baseUrl, contentTypeOrder);
|
|
74
82
|
}
|
|
75
83
|
}
|
|
76
84
|
else {
|
|
@@ -90,9 +98,8 @@ class SpoListContentTypeDefaultSetCommand extends SpoCommand_1.default {
|
|
|
90
98
|
contentTypeOrder.unshift({
|
|
91
99
|
StringValue: args.options.contentTypeId
|
|
92
100
|
});
|
|
93
|
-
|
|
101
|
+
yield this.updateContentTypeOrder(baseUrl, contentTypeOrder);
|
|
94
102
|
}
|
|
95
|
-
logger.log(res);
|
|
96
103
|
}
|
|
97
104
|
catch (err) {
|
|
98
105
|
this.handleRejectedODataJsonPromise(err);
|
|
@@ -100,64 +107,67 @@ class SpoListContentTypeDefaultSetCommand extends SpoCommand_1.default {
|
|
|
100
107
|
});
|
|
101
108
|
}
|
|
102
109
|
getContentTypeOrder(baseUrl, logger) {
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
.get(requestOptions)
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
if (contentTypeOrder.UniqueContentTypeOrder !== null) {
|
|
110
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
const requestOptions = {
|
|
112
|
+
url: `${baseUrl}/RootFolder?$select=ContentTypeOrder,UniqueContentTypeOrder`,
|
|
113
|
+
headers: {
|
|
114
|
+
'accept': 'application/json;odata=nometadata'
|
|
115
|
+
},
|
|
116
|
+
responseType: 'json'
|
|
117
|
+
};
|
|
118
|
+
const response = yield request_1.default.get(requestOptions);
|
|
119
|
+
let uniqueContentTypeOrder = response.ContentTypeOrder;
|
|
120
|
+
if (response.UniqueContentTypeOrder !== null) {
|
|
115
121
|
if (this.debug) {
|
|
116
122
|
logger.logToStderr('Using unique content type order');
|
|
117
123
|
}
|
|
118
|
-
uniqueContentTypeOrder =
|
|
124
|
+
uniqueContentTypeOrder = response.UniqueContentTypeOrder;
|
|
119
125
|
}
|
|
120
126
|
else {
|
|
121
127
|
if (this.debug) {
|
|
122
128
|
logger.logToStderr('Unique content type order not defined. Using content type order');
|
|
123
129
|
}
|
|
124
130
|
}
|
|
125
|
-
return
|
|
126
|
-
}
|
|
131
|
+
return uniqueContentTypeOrder;
|
|
132
|
+
});
|
|
127
133
|
}
|
|
128
134
|
updateContentTypeOrder(baseUrl, contentTypeOrder) {
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
135
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
136
|
+
const requestOptions = {
|
|
137
|
+
url: `${baseUrl}/RootFolder`,
|
|
138
|
+
headers: {
|
|
139
|
+
'accept': 'application/json;odata=nometadata',
|
|
140
|
+
'content-type': 'application/json;odata=nometadata',
|
|
141
|
+
'x-http-method': 'MERGE'
|
|
142
|
+
},
|
|
143
|
+
data: {
|
|
144
|
+
UniqueContentTypeOrder: contentTypeOrder
|
|
145
|
+
},
|
|
146
|
+
responseType: 'json'
|
|
147
|
+
};
|
|
148
|
+
yield request_1.default.post(requestOptions);
|
|
149
|
+
});
|
|
142
150
|
}
|
|
143
151
|
getListContentTypes(baseUrl) {
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
.get(requestOptions)
|
|
153
|
-
|
|
152
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
153
|
+
const requestOptions = {
|
|
154
|
+
url: `${baseUrl}/ContentTypes?$select=Id`,
|
|
155
|
+
headers: {
|
|
156
|
+
'accept': 'application/json;odata=nometadata'
|
|
157
|
+
},
|
|
158
|
+
responseType: 'json'
|
|
159
|
+
};
|
|
160
|
+
const response = yield request_1.default.get(requestOptions);
|
|
161
|
+
return response.value.map(ct => ct.Id.StringValue);
|
|
162
|
+
});
|
|
154
163
|
}
|
|
155
164
|
}
|
|
156
165
|
_SpoListContentTypeDefaultSetCommand_instances = new WeakSet(), _SpoListContentTypeDefaultSetCommand_initTelemetry = function _SpoListContentTypeDefaultSetCommand_initTelemetry() {
|
|
157
166
|
this.telemetry.push((args) => {
|
|
158
167
|
Object.assign(this.telemetryProperties, {
|
|
159
168
|
listId: typeof args.options.listId !== 'undefined',
|
|
160
|
-
listTitle: typeof args.options.listTitle !== 'undefined'
|
|
169
|
+
listTitle: typeof args.options.listTitle !== 'undefined',
|
|
170
|
+
listUrl: typeof args.options.listUrl !== 'undefined'
|
|
161
171
|
});
|
|
162
172
|
});
|
|
163
173
|
}, _SpoListContentTypeDefaultSetCommand_initOptions = function _SpoListContentTypeDefaultSetCommand_initOptions() {
|
|
@@ -167,6 +177,8 @@ _SpoListContentTypeDefaultSetCommand_instances = new WeakSet(), _SpoListContentT
|
|
|
167
177
|
option: '-l, --listId [listId]'
|
|
168
178
|
}, {
|
|
169
179
|
option: '-t, --listTitle [listTitle]'
|
|
180
|
+
}, {
|
|
181
|
+
option: '--listUrl [listUrl]'
|
|
170
182
|
}, {
|
|
171
183
|
option: '-c, --contentTypeId <contentTypeId>'
|
|
172
184
|
});
|
|
@@ -186,7 +198,7 @@ _SpoListContentTypeDefaultSetCommand_instances = new WeakSet(), _SpoListContentT
|
|
|
186
198
|
}, _SpoListContentTypeDefaultSetCommand_initTypes = function _SpoListContentTypeDefaultSetCommand_initTypes() {
|
|
187
199
|
this.types.string.push('contentTypeId', 'c');
|
|
188
200
|
}, _SpoListContentTypeDefaultSetCommand_initOptionSets = function _SpoListContentTypeDefaultSetCommand_initOptionSets() {
|
|
189
|
-
this.optionSets.push(['listId', 'listTitle']);
|
|
201
|
+
this.optionSets.push(['listId', 'listTitle', 'listUrl']);
|
|
190
202
|
};
|
|
191
203
|
module.exports = new SpoListContentTypeDefaultSetCommand();
|
|
192
204
|
//# sourceMappingURL=list-contenttype-default-set.js.map
|
|
@@ -17,6 +17,7 @@ var _SpoListContentTypeListCommand_instances, _SpoListContentTypeListCommand_ini
|
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const request_1 = require("../../../../request");
|
|
19
19
|
const formatting_1 = require("../../../../utils/formatting");
|
|
20
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
20
21
|
const validation_1 = require("../../../../utils/validation");
|
|
21
22
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
23
|
const commands_1 = require("../../commands");
|
|
@@ -41,18 +42,22 @@ class SpoListContentTypeListCommand extends SpoCommand_1.default {
|
|
|
41
42
|
commandAction(logger, args) {
|
|
42
43
|
return __awaiter(this, void 0, void 0, function* () {
|
|
43
44
|
if (this.verbose) {
|
|
44
|
-
const list = (args.options.listId ? args.options.listId : args.options.listTitle);
|
|
45
|
+
const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
|
|
45
46
|
logger.logToStderr(`Retrieving content types information for list ${list} in site at ${args.options.webUrl}...`);
|
|
46
47
|
}
|
|
47
|
-
let requestUrl =
|
|
48
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
48
49
|
if (args.options.listId) {
|
|
49
|
-
requestUrl
|
|
50
|
+
requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
50
51
|
}
|
|
51
|
-
else {
|
|
52
|
-
requestUrl
|
|
52
|
+
else if (args.options.listTitle) {
|
|
53
|
+
requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
54
|
+
}
|
|
55
|
+
else if (args.options.listUrl) {
|
|
56
|
+
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
57
|
+
requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
|
|
53
58
|
}
|
|
54
59
|
const requestOptions = {
|
|
55
|
-
url: requestUrl
|
|
60
|
+
url: `${requestUrl}/ContentTypes`,
|
|
56
61
|
method: 'GET',
|
|
57
62
|
headers: {
|
|
58
63
|
'accept': 'application/json;odata=nometadata'
|
|
@@ -73,7 +78,8 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
|
|
|
73
78
|
this.telemetry.push((args) => {
|
|
74
79
|
Object.assign(this.telemetryProperties, {
|
|
75
80
|
listId: typeof args.options.listId !== 'undefined',
|
|
76
|
-
listTitle: typeof args.options.listTitle !== 'undefined'
|
|
81
|
+
listTitle: typeof args.options.listTitle !== 'undefined',
|
|
82
|
+
listUrl: typeof args.options.listUrl !== 'undefined'
|
|
77
83
|
});
|
|
78
84
|
});
|
|
79
85
|
}, _SpoListContentTypeListCommand_initOptions = function _SpoListContentTypeListCommand_initOptions() {
|
|
@@ -83,6 +89,8 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
|
|
|
83
89
|
option: '-l, --listId [listId]'
|
|
84
90
|
}, {
|
|
85
91
|
option: '-t, --listTitle [listTitle]'
|
|
92
|
+
}, {
|
|
93
|
+
option: '--listUrl [listUrl]'
|
|
86
94
|
});
|
|
87
95
|
}, _SpoListContentTypeListCommand_initValidators = function _SpoListContentTypeListCommand_initValidators() {
|
|
88
96
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
@@ -98,7 +106,7 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
|
|
|
98
106
|
return true;
|
|
99
107
|
}));
|
|
100
108
|
}, _SpoListContentTypeListCommand_initOptionSets = function _SpoListContentTypeListCommand_initOptionSets() {
|
|
101
|
-
this.optionSets.push(['listId', 'listTitle']);
|
|
109
|
+
this.optionSets.push(['listId', 'listTitle', 'listUrl']);
|
|
102
110
|
};
|
|
103
111
|
module.exports = new SpoListContentTypeListCommand();
|
|
104
112
|
//# sourceMappingURL=list-contenttype-list.js.map
|
|
@@ -18,6 +18,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
18
18
|
const Cli_1 = require("../../../../cli/Cli");
|
|
19
19
|
const request_1 = require("../../../../request");
|
|
20
20
|
const formatting_1 = require("../../../../utils/formatting");
|
|
21
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
21
22
|
const validation_1 = require("../../../../utils/validation");
|
|
22
23
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
23
24
|
const commands_1 = require("../../commands");
|
|
@@ -41,18 +42,22 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
|
|
|
41
42
|
return __awaiter(this, void 0, void 0, function* () {
|
|
42
43
|
const removeContentTypeFromList = () => __awaiter(this, void 0, void 0, function* () {
|
|
43
44
|
if (this.verbose) {
|
|
44
|
-
const list = (args.options.listId ? args.options.listId : args.options.listTitle);
|
|
45
|
+
const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
|
|
45
46
|
logger.logToStderr(`Removing content type ${args.options.contentTypeId} from list ${list} in site at ${args.options.webUrl}...`);
|
|
46
47
|
}
|
|
47
|
-
let requestUrl =
|
|
48
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
48
49
|
if (args.options.listId) {
|
|
49
|
-
requestUrl
|
|
50
|
+
requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
|
|
50
51
|
}
|
|
51
|
-
else {
|
|
52
|
-
requestUrl
|
|
52
|
+
else if (args.options.listTitle) {
|
|
53
|
+
requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
|
|
54
|
+
}
|
|
55
|
+
else if (args.options.listUrl) {
|
|
56
|
+
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
57
|
+
requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
|
|
53
58
|
}
|
|
54
59
|
const requestOptions = {
|
|
55
|
-
url: requestUrl
|
|
60
|
+
url: `${requestUrl}/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`,
|
|
56
61
|
headers: {
|
|
57
62
|
'X-HTTP-Method': 'DELETE',
|
|
58
63
|
'If-Match': '*',
|
|
@@ -75,7 +80,7 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
|
|
|
75
80
|
type: 'confirm',
|
|
76
81
|
name: 'continue',
|
|
77
82
|
default: false,
|
|
78
|
-
message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId
|
|
83
|
+
message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl} in site ${args.options.webUrl}?`
|
|
79
84
|
});
|
|
80
85
|
if (result.continue) {
|
|
81
86
|
yield removeContentTypeFromList();
|
|
@@ -89,6 +94,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
|
|
|
89
94
|
Object.assign(this.telemetryProperties, {
|
|
90
95
|
listId: typeof args.options.listId !== 'undefined',
|
|
91
96
|
listTitle: typeof args.options.listTitle !== 'undefined',
|
|
97
|
+
listUrl: typeof args.options.listUrl !== 'undefined',
|
|
92
98
|
confirm: (!(!args.options.confirm)).toString()
|
|
93
99
|
});
|
|
94
100
|
});
|
|
@@ -99,6 +105,8 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
|
|
|
99
105
|
option: '-l, --listId [listId]'
|
|
100
106
|
}, {
|
|
101
107
|
option: '-t, --listTitle [listTitle]'
|
|
108
|
+
}, {
|
|
109
|
+
option: '--listUrl [listUrl]'
|
|
102
110
|
}, {
|
|
103
111
|
option: '-c, --contentTypeId <contentTypeId>'
|
|
104
112
|
}, {
|
|
@@ -120,7 +128,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
|
|
|
120
128
|
}, _SpoListContentTypeRemoveCommand_initTypes = function _SpoListContentTypeRemoveCommand_initTypes() {
|
|
121
129
|
this.types.string.push('contentTypeId', 'c');
|
|
122
130
|
}, _SpoListContentTypeRemoveCommand_initOptionSets = function _SpoListContentTypeRemoveCommand_initOptionSets() {
|
|
123
|
-
this.optionSets.push(['listId', 'listTitle']);
|
|
131
|
+
this.optionSets.push(['listId', 'listTitle', 'listUrl']);
|
|
124
132
|
};
|
|
125
133
|
module.exports = new SpoListContentTypeRemoveCommand();
|
|
126
134
|
//# sourceMappingURL=list-contenttype-remove.js.map
|
|
@@ -56,17 +56,17 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
|
|
|
56
56
|
const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
57
57
|
requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
|
|
58
58
|
}
|
|
59
|
-
args.options.roleDefinitionId = yield this.
|
|
59
|
+
args.options.roleDefinitionId = yield this.getRoleDefinitionId(args.options);
|
|
60
60
|
if (args.options.upn) {
|
|
61
|
-
args.options.principalId = yield this.
|
|
62
|
-
yield this.
|
|
61
|
+
args.options.principalId = yield this.getUserPrincipalId(args.options);
|
|
62
|
+
yield this.addRoleAssignment(requestUrl, logger, args.options);
|
|
63
63
|
}
|
|
64
64
|
else if (args.options.groupName) {
|
|
65
|
-
args.options.principalId = yield this.
|
|
66
|
-
this.
|
|
65
|
+
args.options.principalId = yield this.getGroupPrincipalId(args.options);
|
|
66
|
+
yield this.addRoleAssignment(requestUrl, logger, args.options);
|
|
67
67
|
}
|
|
68
68
|
else {
|
|
69
|
-
yield this.
|
|
69
|
+
yield this.addRoleAssignment(requestUrl, logger, args.options);
|
|
70
70
|
}
|
|
71
71
|
}
|
|
72
72
|
catch (err) {
|
|
@@ -74,7 +74,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
|
|
|
74
74
|
}
|
|
75
75
|
});
|
|
76
76
|
}
|
|
77
|
-
|
|
77
|
+
addRoleAssignment(requestUrl, logger, options) {
|
|
78
78
|
const requestOptions = {
|
|
79
79
|
url: `${requestUrl}roleassignments/addroleassignment(principalid='${options.principalId}',roledefid='${options.roleDefinitionId}')`,
|
|
80
80
|
method: 'POST',
|
|
@@ -89,7 +89,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
|
|
|
89
89
|
.then(_ => Promise.resolve())
|
|
90
90
|
.catch((err) => Promise.reject(err));
|
|
91
91
|
}
|
|
92
|
-
|
|
92
|
+
getRoleDefinitionId(options) {
|
|
93
93
|
if (!options.roleDefinitionName) {
|
|
94
94
|
return Promise.resolve(options.roleDefinitionId);
|
|
95
95
|
}
|
|
@@ -108,7 +108,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
|
|
|
108
108
|
return Promise.reject(err);
|
|
109
109
|
});
|
|
110
110
|
}
|
|
111
|
-
|
|
111
|
+
getGroupPrincipalId(options) {
|
|
112
112
|
const groupGetCommandOptions = {
|
|
113
113
|
webUrl: options.webUrl,
|
|
114
114
|
name: options.groupName,
|
|
@@ -124,7 +124,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
|
|
|
124
124
|
return Promise.reject(err);
|
|
125
125
|
});
|
|
126
126
|
}
|
|
127
|
-
|
|
127
|
+
getUserPrincipalId(options) {
|
|
128
128
|
const userGetCommandOptions = {
|
|
129
129
|
webUrl: options.webUrl,
|
|
130
130
|
email: options.upn,
|
|
@@ -57,15 +57,15 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
|
|
|
57
57
|
requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
|
|
58
58
|
}
|
|
59
59
|
if (args.options.upn) {
|
|
60
|
-
args.options.principalId = yield this.
|
|
61
|
-
yield this.
|
|
60
|
+
args.options.principalId = yield this.getUserPrincipalId(args.options);
|
|
61
|
+
yield this.removeRoleAssignment(requestUrl, logger, args.options);
|
|
62
62
|
}
|
|
63
63
|
else if (args.options.groupName) {
|
|
64
|
-
args.options.principalId = yield this.
|
|
65
|
-
yield this.
|
|
64
|
+
args.options.principalId = yield this.getGroupPrincipalId(args.options);
|
|
65
|
+
yield this.removeRoleAssignment(requestUrl, logger, args.options);
|
|
66
66
|
}
|
|
67
67
|
else {
|
|
68
|
-
yield this.
|
|
68
|
+
yield this.removeRoleAssignment(requestUrl, logger, args.options);
|
|
69
69
|
}
|
|
70
70
|
}
|
|
71
71
|
catch (err) {
|
|
@@ -88,7 +88,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
|
|
|
88
88
|
}
|
|
89
89
|
});
|
|
90
90
|
}
|
|
91
|
-
|
|
91
|
+
removeRoleAssignment(requestUrl, logger, options) {
|
|
92
92
|
const requestOptions = {
|
|
93
93
|
url: `${requestUrl}roleassignments/removeroleassignment(principalid='${options.principalId}')`,
|
|
94
94
|
method: 'POST',
|
|
@@ -103,7 +103,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
|
|
|
103
103
|
.then(_ => Promise.resolve())
|
|
104
104
|
.catch((err) => Promise.reject(err));
|
|
105
105
|
}
|
|
106
|
-
|
|
106
|
+
getGroupPrincipalId(options) {
|
|
107
107
|
const groupGetCommandOptions = {
|
|
108
108
|
webUrl: options.webUrl,
|
|
109
109
|
name: options.groupName,
|
|
@@ -119,7 +119,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
|
|
|
119
119
|
return Promise.reject(err);
|
|
120
120
|
});
|
|
121
121
|
}
|
|
122
|
-
|
|
122
|
+
getUserPrincipalId(options) {
|
|
123
123
|
const userGetCommandOptions = {
|
|
124
124
|
webUrl: options.webUrl,
|
|
125
125
|
email: options.upn,
|