@pnp/cli-microsoft365 6.2.0-beta.0ce0a85 → 6.2.0-beta.51aa7cb
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/m365/context/commands/option/option-remove.js +105 -0
- package/dist/m365/context/commands/option/option-set.js +84 -0
- package/dist/m365/context/commands.js +2 -0
- package/dist/m365/onenote/commands/page/page-list.js +137 -0
- package/dist/m365/onenote/commands.js +2 -1
- package/dist/m365/planner/commands/bucket/bucket-add.js +0 -6
- package/dist/m365/planner/commands/bucket/bucket-get.js +0 -6
- package/dist/m365/planner/commands/bucket/bucket-list.js +0 -6
- package/dist/m365/planner/commands/bucket/bucket-remove.js +0 -6
- package/dist/m365/planner/commands/bucket/bucket-set.js +0 -6
- package/dist/m365/planner/commands/plan/plan-add.js +0 -6
- package/dist/m365/planner/commands/plan/plan-get.js +0 -6
- package/dist/m365/planner/commands/plan/plan-list.js +0 -6
- package/dist/m365/planner/commands/plan/plan-remove.js +0 -6
- package/dist/m365/planner/commands/plan/plan-set.js +0 -6
- package/dist/m365/planner/commands/task/task-add.js +0 -6
- package/dist/m365/planner/commands/task/task-checklistitem-add.js +0 -6
- package/dist/m365/planner/commands/task/task-checklistitem-list.js +0 -6
- package/dist/m365/planner/commands/task/task-get.js +0 -6
- package/dist/m365/planner/commands/task/task-list.js +0 -6
- package/dist/m365/planner/commands/task/task-reference-list.js +0 -6
- package/dist/m365/planner/commands/task/task-set.js +0 -6
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-get.js +110 -0
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-remove.js +130 -0
- package/dist/m365/pp/commands/solution/solution-publish.js +156 -0
- package/dist/m365/pp/commands.js +3 -0
- package/dist/m365/purview/commands/retentionlabel/retentionlabel-add.js +143 -0
- package/dist/m365/purview/commands.js +1 -0
- package/dist/m365/spo/commands/file/file-retentionlabel-ensure.js +121 -0
- package/dist/m365/spo/commands/file/file-retentionlabel-remove.js +141 -0
- package/dist/m365/spo/commands/folder/folder-retentionlabel-ensure.js +138 -0
- package/dist/m365/spo/commands/folder/folder-retentionlabel-remove.js +157 -0
- package/dist/m365/spo/commands/group/group-member-add.js +33 -6
- package/dist/m365/spo/commands/list/list-add.js +3 -0
- package/dist/m365/spo/commands/list/list-retentionlabel-remove.js +146 -0
- package/dist/m365/spo/commands/list/list-set.js +3 -0
- package/dist/m365/spo/commands/listitem/listitem-list.js +1 -1
- package/dist/m365/spo/commands/listitem/listitem-retentionlabel-remove.js +2 -2
- package/dist/m365/spo/commands/term/term-list.js +99 -29
- package/dist/m365/spo/commands.js +5 -0
- package/dist/m365/teams/commands/message/message-send.js +81 -0
- package/dist/m365/teams/commands.js +1 -0
- package/dist/utils/formatting.js +22 -0
- package/docs/docs/cmd/context/option/option-remove.md +37 -0
- package/docs/docs/cmd/context/option/option-set.md +31 -0
- package/docs/docs/cmd/onenote/page/page-list.md +140 -0
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-get.md +99 -0
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-remove.md +53 -0
- package/docs/docs/cmd/pp/solution/solution-publish.md +52 -0
- package/docs/docs/cmd/purview/retentionlabel/retentionlabel-add.md +128 -0
- package/docs/docs/cmd/spo/cdn/cdn-get.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-add.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-list.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-remove.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-policy-list.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-policy-set.md +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-set.md +1 -1
- package/docs/docs/cmd/spo/file/file-retentionlabel-ensure.md +47 -0
- package/docs/docs/cmd/spo/file/file-retentionlabel-remove.md +43 -0
- package/docs/docs/cmd/spo/folder/folder-retentionlabel-ensure.md +47 -0
- package/docs/docs/cmd/spo/folder/folder-retentionlabel-remove.md +43 -0
- package/docs/docs/cmd/spo/group/group-member-add.md +22 -4
- package/docs/docs/cmd/spo/list/list-add.md +3 -9
- package/docs/docs/cmd/spo/list/list-retentionlabel-remove.md +52 -0
- package/docs/docs/cmd/spo/list/list-set.md +3 -3
- package/docs/docs/cmd/spo/listitem/listitem-get.md +11 -12
- package/docs/docs/cmd/spo/listitem/listitem-list.md +5 -5
- package/docs/docs/cmd/spo/term/term-list.md +138 -0
- package/docs/docs/cmd/teams/message/message-send.md +119 -0
- package/package.json +1 -1
|
@@ -78,6 +78,9 @@ class SpoListAddCommand extends SpoCommand_1.default {
|
|
|
78
78
|
}
|
|
79
79
|
commandAction(logger, args) {
|
|
80
80
|
return __awaiter(this, void 0, void 0, function* () {
|
|
81
|
+
if (args.options.schemaXml) {
|
|
82
|
+
this.warn(logger, `Option 'schemaXml' is deprecated.`);
|
|
83
|
+
}
|
|
81
84
|
if (this.verbose) {
|
|
82
85
|
logger.logToStderr(`Creating list in site at ${args.options.webUrl}...`);
|
|
83
86
|
}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
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
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _SpoListRetentionLabelRemoveCommand_instances, _SpoListRetentionLabelRemoveCommand_initTelemetry, _SpoListRetentionLabelRemoveCommand_initOptions, _SpoListRetentionLabelRemoveCommand_initValidators, _SpoListRetentionLabelRemoveCommand_initOptionSets;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const Cli_1 = require("../../../../cli/Cli");
|
|
19
|
+
const request_1 = require("../../../../request");
|
|
20
|
+
const formatting_1 = require("../../../../utils/formatting");
|
|
21
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
22
|
+
const validation_1 = require("../../../../utils/validation");
|
|
23
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
24
|
+
const commands_1 = require("../../commands");
|
|
25
|
+
class SpoListRetentionLabelRemoveCommand extends SpoCommand_1.default {
|
|
26
|
+
get name() {
|
|
27
|
+
return commands_1.default.LIST_RETENTIONLABEL_REMOVE;
|
|
28
|
+
}
|
|
29
|
+
get description() {
|
|
30
|
+
return 'Clears the retention label on the specified list or library.';
|
|
31
|
+
}
|
|
32
|
+
constructor() {
|
|
33
|
+
super();
|
|
34
|
+
_SpoListRetentionLabelRemoveCommand_instances.add(this);
|
|
35
|
+
__classPrivateFieldGet(this, _SpoListRetentionLabelRemoveCommand_instances, "m", _SpoListRetentionLabelRemoveCommand_initTelemetry).call(this);
|
|
36
|
+
__classPrivateFieldGet(this, _SpoListRetentionLabelRemoveCommand_instances, "m", _SpoListRetentionLabelRemoveCommand_initOptions).call(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoListRetentionLabelRemoveCommand_instances, "m", _SpoListRetentionLabelRemoveCommand_initValidators).call(this);
|
|
38
|
+
__classPrivateFieldGet(this, _SpoListRetentionLabelRemoveCommand_instances, "m", _SpoListRetentionLabelRemoveCommand_initOptionSets).call(this);
|
|
39
|
+
}
|
|
40
|
+
commandAction(logger, args) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
if (args.options.confirm) {
|
|
43
|
+
yield this.removeListRetentionLabel(logger, args);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const result = yield Cli_1.Cli.prompt({
|
|
47
|
+
type: 'confirm',
|
|
48
|
+
name: 'continue',
|
|
49
|
+
default: false,
|
|
50
|
+
message: `Are you sure you want to remove the retention label from list '${args.options.listId || args.options.listTitle || args.options.listUrl}'?`
|
|
51
|
+
});
|
|
52
|
+
if (result.continue) {
|
|
53
|
+
yield this.removeListRetentionLabel(logger, args);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
removeListRetentionLabel(logger, args) {
|
|
59
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
60
|
+
if (this.verbose) {
|
|
61
|
+
logger.logToStderr(`Clears the retention label from list ${args.options.listId || args.options.listTitle || args.options.listUrl} in site at ${args.options.webUrl}...`);
|
|
62
|
+
}
|
|
63
|
+
try {
|
|
64
|
+
const listServerRelativeUrl = yield this.getListServerRelativeUrl(args, logger);
|
|
65
|
+
const listAbsoluteUrl = urlUtil_1.urlUtil.getAbsoluteUrl(args.options.webUrl, listServerRelativeUrl);
|
|
66
|
+
const requestOptions = {
|
|
67
|
+
url: `${args.options.webUrl}/_api/SP_CompliancePolicy_SPPolicyStoreProxy_SetListComplianceTag`,
|
|
68
|
+
headers: {
|
|
69
|
+
'accept': 'application/json;odata=nometadata'
|
|
70
|
+
},
|
|
71
|
+
data: {
|
|
72
|
+
listUrl: listAbsoluteUrl,
|
|
73
|
+
complianceTagValue: '',
|
|
74
|
+
blockDelete: false,
|
|
75
|
+
blockEdit: false,
|
|
76
|
+
syncToItems: false
|
|
77
|
+
},
|
|
78
|
+
responseType: 'json'
|
|
79
|
+
};
|
|
80
|
+
yield request_1.default.post(requestOptions);
|
|
81
|
+
}
|
|
82
|
+
catch (err) {
|
|
83
|
+
this.handleRejectedODataJsonPromise(err);
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
getListServerRelativeUrl(args, logger) {
|
|
88
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
89
|
+
if (this.verbose) {
|
|
90
|
+
logger.logToStderr('Getting the list server relative URL');
|
|
91
|
+
}
|
|
92
|
+
if (args.options.listUrl) {
|
|
93
|
+
return urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
|
|
94
|
+
}
|
|
95
|
+
let listRestUrl = '';
|
|
96
|
+
if (args.options.listId) {
|
|
97
|
+
listRestUrl = `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/`;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
listRestUrl = `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/`;
|
|
101
|
+
}
|
|
102
|
+
const requestOptions = {
|
|
103
|
+
url: `${args.options.webUrl}/_api/web/${listRestUrl}?$expand=RootFolder&$select=RootFolder/ServerRelativeUrl`,
|
|
104
|
+
headers: {
|
|
105
|
+
'accept': 'application/json;odata=nometadata'
|
|
106
|
+
},
|
|
107
|
+
responseType: 'json'
|
|
108
|
+
};
|
|
109
|
+
const listInstance = yield request_1.default.get(requestOptions);
|
|
110
|
+
return listInstance.RootFolder.ServerRelativeUrl;
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
_SpoListRetentionLabelRemoveCommand_instances = new WeakSet(), _SpoListRetentionLabelRemoveCommand_initTelemetry = function _SpoListRetentionLabelRemoveCommand_initTelemetry() {
|
|
115
|
+
this.telemetry.push((args) => {
|
|
116
|
+
Object.assign(this.telemetryProperties, {
|
|
117
|
+
listId: typeof args.options.listId !== 'undefined',
|
|
118
|
+
listTitle: typeof args.options.listTitle !== 'undefined',
|
|
119
|
+
listUrl: typeof args.options.listUrl !== 'undefined',
|
|
120
|
+
confirm: !!args.options.confirm
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
}, _SpoListRetentionLabelRemoveCommand_initOptions = function _SpoListRetentionLabelRemoveCommand_initOptions() {
|
|
124
|
+
this.options.unshift({
|
|
125
|
+
option: '-u, --webUrl <webUrl>'
|
|
126
|
+
}, {
|
|
127
|
+
option: '-t, --listTitle [listTitle]'
|
|
128
|
+
}, {
|
|
129
|
+
option: '-i, --listId [listId]'
|
|
130
|
+
}, {
|
|
131
|
+
option: '-l, --listUrl [listUrl]'
|
|
132
|
+
}, {
|
|
133
|
+
option: '--confirm'
|
|
134
|
+
});
|
|
135
|
+
}, _SpoListRetentionLabelRemoveCommand_initValidators = function _SpoListRetentionLabelRemoveCommand_initValidators() {
|
|
136
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
137
|
+
if (args.options.listId && !validation_1.validation.isValidGuid(args.options.listId)) {
|
|
138
|
+
return `${args.options.listId} is not a valid GUID`;
|
|
139
|
+
}
|
|
140
|
+
return validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
141
|
+
}));
|
|
142
|
+
}, _SpoListRetentionLabelRemoveCommand_initOptionSets = function _SpoListRetentionLabelRemoveCommand_initOptionSets() {
|
|
143
|
+
this.optionSets.push({ options: ['listId', 'listTitle', 'listUrl'] });
|
|
144
|
+
};
|
|
145
|
+
module.exports = new SpoListRetentionLabelRemoveCommand();
|
|
146
|
+
//# sourceMappingURL=list-retentionlabel-remove.js.map
|
|
@@ -67,6 +67,9 @@ class SpoListSetCommand extends SpoCommand_1.default {
|
|
|
67
67
|
}
|
|
68
68
|
commandAction(logger, args) {
|
|
69
69
|
return __awaiter(this, void 0, void 0, function* () {
|
|
70
|
+
if (args.options.schemaXml) {
|
|
71
|
+
this.warn(logger, `Option 'schemaXml' is deprecated.`);
|
|
72
|
+
}
|
|
70
73
|
if (this.verbose) {
|
|
71
74
|
logger.logToStderr(`Updating list in site at ${args.options.webUrl}...`);
|
|
72
75
|
}
|
|
@@ -177,7 +177,7 @@ _SpoListItemListCommand_instances = new WeakSet(), _SpoListItemListCommand_initT
|
|
|
177
177
|
return true;
|
|
178
178
|
}));
|
|
179
179
|
}, _SpoListItemListCommand_initOptionSets = function _SpoListItemListCommand_initOptionSets() {
|
|
180
|
-
this.optionSets.push({ options: ['listId', 'listTitle'] });
|
|
180
|
+
this.optionSets.push({ options: ['listId', 'listTitle', 'listUrl'] });
|
|
181
181
|
}, _SpoListItemListCommand_initTypes = function _SpoListItemListCommand_initTypes() {
|
|
182
182
|
this.types.string.push('webUrl', 'camlQuery', 'pageSize', 'pageNumber', 'fields', 'filter');
|
|
183
183
|
};
|
|
@@ -47,7 +47,7 @@ class SpoListItemRetentionLabelRemoveCommand extends SpoCommand_1.default {
|
|
|
47
47
|
type: 'confirm',
|
|
48
48
|
name: 'continue',
|
|
49
49
|
default: false,
|
|
50
|
-
message: `Are you sure you want to remove the retentionlabel from list item ${args.options.listItemId} from list ${args.options.listId || args.options.listTitle || args.options.listUrl} located in site ${args.options.webUrl}?`
|
|
50
|
+
message: `Are you sure you want to remove the retentionlabel from list item ${args.options.listItemId} from list '${args.options.listId || args.options.listTitle || args.options.listUrl}' located in site ${args.options.webUrl}?`
|
|
51
51
|
});
|
|
52
52
|
if (result.continue) {
|
|
53
53
|
yield this.removeListItemRetentionLabel(logger, args);
|
|
@@ -58,7 +58,7 @@ class SpoListItemRetentionLabelRemoveCommand extends SpoCommand_1.default {
|
|
|
58
58
|
removeListItemRetentionLabel(logger, args) {
|
|
59
59
|
return __awaiter(this, void 0, void 0, function* () {
|
|
60
60
|
if (this.verbose) {
|
|
61
|
-
logger.logToStderr(`Removing retention label from list ${args.options.listId || args.options.listTitle || args.options.listUrl} in site at ${args.options.webUrl}...`);
|
|
61
|
+
logger.logToStderr(`Removing retention label from list item ${args.options.listItemId} from list '${args.options.listId || args.options.listTitle || args.options.listUrl}' in site at ${args.options.webUrl}...`);
|
|
62
62
|
}
|
|
63
63
|
try {
|
|
64
64
|
let url = `${args.options.webUrl}/_api/web`;
|
|
@@ -30,7 +30,7 @@ class SpoTermListCommand extends SpoCommand_1.default {
|
|
|
30
30
|
return 'Lists taxonomy terms from the given term set';
|
|
31
31
|
}
|
|
32
32
|
defaultProperties() {
|
|
33
|
-
return ['Id', 'Name'];
|
|
33
|
+
return ['Id', 'Name', 'ParentTermId'];
|
|
34
34
|
}
|
|
35
35
|
constructor() {
|
|
36
36
|
super();
|
|
@@ -50,27 +50,47 @@ class SpoTermListCommand extends SpoCommand_1.default {
|
|
|
50
50
|
}
|
|
51
51
|
const termGroupQuery = args.options.termGroupId ? `<Method Id="77" ParentId="75" Name="GetById"><Parameters><Parameter Type="Guid">{${args.options.termGroupId}}</Parameter></Parameters></Method>` : `<Method Id="77" ParentId="75" Name="GetByName"><Parameters><Parameter Type="String">${formatting_1.formatting.escapeXml(args.options.termGroupName)}</Parameter></Parameters></Method>`;
|
|
52
52
|
const termSetQuery = args.options.termSetId ? `<Method Id="82" ParentId="80" Name="GetById"><Parameters><Parameter Type="Guid">{${args.options.termSetId}}</Parameter></Parameters></Method>` : `<Method Id="82" ParentId="80" Name="GetByName"><Parameters><Parameter Type="String">${formatting_1.formatting.escapeXml(args.options.termSetName)}</Parameter></Parameters></Method>`;
|
|
53
|
-
const
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
'X-RequestDigest': res.FormDigestValue
|
|
57
|
-
},
|
|
58
|
-
data: `<Request AddExpandoFieldTypeSuffix="true" SchemaVersion="15.0.0.0" LibraryVersion="16.0.0.0" ApplicationName="${config_1.default.applicationName}" xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009"><Actions><ObjectPath Id="70" ObjectPathId="69" /><ObjectIdentityQuery Id="71" ObjectPathId="69" /><ObjectPath Id="73" ObjectPathId="72" /><ObjectIdentityQuery Id="74" ObjectPathId="72" /><ObjectPath Id="76" ObjectPathId="75" /><ObjectPath Id="78" ObjectPathId="77" /><ObjectIdentityQuery Id="79" ObjectPathId="77" /><ObjectPath Id="81" ObjectPathId="80" /><ObjectPath Id="83" ObjectPathId="82" /><ObjectIdentityQuery Id="84" ObjectPathId="82" /><ObjectPath Id="86" ObjectPathId="85" /><Query Id="87" ObjectPathId="85"><Query SelectAllProperties="false"><Properties /></Query><ChildItemQuery SelectAllProperties="true"><Properties><Property Name="Name" ScalarProperty="true" /><Property Name="Id" ScalarProperty="true" /></Properties></ChildItemQuery></Query></Actions><ObjectPaths><StaticMethod Id="69" Name="GetTaxonomySession" TypeId="{981cbc68-9edc-4f8d-872f-71146fcbb84f}" /><Method Id="72" ParentId="69" Name="GetDefaultSiteCollectionTermStore" /><Property Id="75" ParentId="72" Name="Groups" />${termGroupQuery}<Property Id="80" ParentId="77" Name="TermSets" />${termSetQuery}<Property Id="85" ParentId="82" Name="Terms" /></ObjectPaths></Request>`
|
|
59
|
-
};
|
|
60
|
-
const processQuery = yield request_1.default.post(requestOptions);
|
|
61
|
-
const json = JSON.parse(processQuery);
|
|
62
|
-
const response = json[0];
|
|
63
|
-
if (response.ErrorInfo) {
|
|
64
|
-
throw response.ErrorInfo.ErrorMessage;
|
|
65
|
-
}
|
|
66
|
-
const result = json[json.length - 1];
|
|
53
|
+
const data = `<Request AddExpandoFieldTypeSuffix="true" SchemaVersion="15.0.0.0" LibraryVersion="16.0.0.0" ApplicationName="${config_1.default.applicationName}" xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009"><Actions><ObjectPath Id="70" ObjectPathId="69" /><ObjectIdentityQuery Id="71" ObjectPathId="69" /><ObjectPath Id="73" ObjectPathId="72" /><ObjectIdentityQuery Id="74" ObjectPathId="72" /><ObjectPath Id="76" ObjectPathId="75" /><ObjectPath Id="78" ObjectPathId="77" /><ObjectIdentityQuery Id="79" ObjectPathId="77" /><ObjectPath Id="81" ObjectPathId="80" /><ObjectPath Id="83" ObjectPathId="82" /><ObjectIdentityQuery Id="84" ObjectPathId="82" /><ObjectPath Id="86" ObjectPathId="85" /><Query Id="87" ObjectPathId="85"><Query SelectAllProperties="false"><Properties /></Query><ChildItemQuery SelectAllProperties="true"><Properties><Property Name="Name" ScalarProperty="true" /><Property Name="Id" ScalarProperty="true" /></Properties></ChildItemQuery></Query></Actions><ObjectPaths><StaticMethod Id="69" Name="GetTaxonomySession" TypeId="{981cbc68-9edc-4f8d-872f-71146fcbb84f}" /><Method Id="72" ParentId="69" Name="GetDefaultSiteCollectionTermStore" /><Property Id="75" ParentId="72" Name="Groups" />${termGroupQuery}<Property Id="80" ParentId="77" Name="TermSets" />${termSetQuery}<Property Id="85" ParentId="82" Name="Terms" /></ObjectPaths></Request>`;
|
|
54
|
+
const result = yield this.executeCsomCall(data, spoAdminUrl, res);
|
|
55
|
+
const terms = [];
|
|
67
56
|
if (result._Child_Items_ && result._Child_Items_.length > 0) {
|
|
68
|
-
result._Child_Items_
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
57
|
+
for (const term of result._Child_Items_) {
|
|
58
|
+
this.setTermDetails(term);
|
|
59
|
+
terms.push(term);
|
|
60
|
+
if (args.options.includeChildTerms && term.TermsCount > 0) {
|
|
61
|
+
yield this.getChildTerms(spoAdminUrl, res, term);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
if (!args.options.output || args.options.output === 'json') {
|
|
66
|
+
logger.log(terms);
|
|
67
|
+
}
|
|
68
|
+
else if (!args.options.includeChildTerms) {
|
|
69
|
+
// Converted to text friendly output
|
|
70
|
+
logger.log(terms.map(i => {
|
|
71
|
+
return {
|
|
72
|
+
Id: i.Id,
|
|
73
|
+
Name: i.Name
|
|
74
|
+
};
|
|
75
|
+
}));
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
// Converted to text friendly output
|
|
79
|
+
const friendlyOutput = [];
|
|
80
|
+
terms.forEach(term => {
|
|
81
|
+
term.ParentTermId = '';
|
|
82
|
+
friendlyOutput.push(term);
|
|
83
|
+
if (term.Children && term.Children.length > 0) {
|
|
84
|
+
this.getFriendlyChildTerms(term, friendlyOutput);
|
|
85
|
+
}
|
|
72
86
|
});
|
|
73
|
-
logger.log(
|
|
87
|
+
logger.log(friendlyOutput.map(i => {
|
|
88
|
+
return {
|
|
89
|
+
Id: i.Id,
|
|
90
|
+
Name: i.Name,
|
|
91
|
+
ParentTermId: i.ParentTermId
|
|
92
|
+
};
|
|
93
|
+
}));
|
|
74
94
|
}
|
|
75
95
|
}
|
|
76
96
|
catch (err) {
|
|
@@ -78,6 +98,57 @@ class SpoTermListCommand extends SpoCommand_1.default {
|
|
|
78
98
|
}
|
|
79
99
|
});
|
|
80
100
|
}
|
|
101
|
+
getFriendlyChildTerms(term, friendlyOutput) {
|
|
102
|
+
term.Children.forEach(childTerm => {
|
|
103
|
+
childTerm.ParentTermId = term.Id;
|
|
104
|
+
friendlyOutput.push(childTerm);
|
|
105
|
+
if (childTerm.Children && childTerm.Children.length > 0) {
|
|
106
|
+
this.getFriendlyChildTerms(childTerm, friendlyOutput);
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
getChildTerms(spoAdminUrl, res, parentTerm) {
|
|
111
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
112
|
+
parentTerm.Children = [];
|
|
113
|
+
const data = `<Request AddExpandoFieldTypeSuffix="true" SchemaVersion="15.0.0.0" LibraryVersion="16.0.0.0" ApplicationName="${config_1.default.applicationName}" xmlns="http://schemas.microsoft.com/sharepoint/clientquery/2009"><Actions><ObjectPath Id="20" ObjectPathId="19" /><Query Id="21" ObjectPathId="19"><Query SelectAllProperties="false"><Properties /></Query><ChildItemQuery SelectAllProperties="true"><Properties><Property Name="CustomSortOrder" ScalarProperty="true" /><Property Name="CustomProperties" ScalarProperty="true" /><Property Name="LocalCustomProperties" ScalarProperty="true" /></Properties></ChildItemQuery></Query></Actions><ObjectPaths><Property Id="19" ParentId="16" Name="Terms" /><Identity Id="16" Name="${parentTerm._ObjectIdentity_}" /></ObjectPaths></Request>`;
|
|
114
|
+
const result = yield this.executeCsomCall(data, spoAdminUrl, res);
|
|
115
|
+
if (result._Child_Items_ && result._Child_Items_.length > 0) {
|
|
116
|
+
for (const term of result._Child_Items_) {
|
|
117
|
+
this.setTermDetails(term);
|
|
118
|
+
parentTerm.Children.push(term);
|
|
119
|
+
if (term.TermsCount > 0) {
|
|
120
|
+
yield this.getChildTerms(spoAdminUrl, res, term);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
setTermDetails(term) {
|
|
127
|
+
term.CreatedDate = this.parseTermDateToIsoString(term.CreatedDate);
|
|
128
|
+
term.Id = term.Id.replace('/Guid(', '').replace(')/', '');
|
|
129
|
+
term.LastModifiedDate = this.parseTermDateToIsoString(term.LastModifiedDate);
|
|
130
|
+
}
|
|
131
|
+
parseTermDateToIsoString(dateAsString) {
|
|
132
|
+
return new Date(Number(dateAsString.replace('/Date(', '').replace(')/', ''))).toISOString();
|
|
133
|
+
}
|
|
134
|
+
executeCsomCall(data, spoAdminUrl, res) {
|
|
135
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
136
|
+
const requestOptions = {
|
|
137
|
+
url: `${spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
138
|
+
headers: {
|
|
139
|
+
'X-RequestDigest': res.FormDigestValue
|
|
140
|
+
},
|
|
141
|
+
data: data
|
|
142
|
+
};
|
|
143
|
+
const processQuery = yield request_1.default.post(requestOptions);
|
|
144
|
+
const json = JSON.parse(processQuery);
|
|
145
|
+
const response = json[0];
|
|
146
|
+
if (response.ErrorInfo) {
|
|
147
|
+
throw response.ErrorInfo.ErrorMessage;
|
|
148
|
+
}
|
|
149
|
+
return json[json.length - 1];
|
|
150
|
+
});
|
|
151
|
+
}
|
|
81
152
|
}
|
|
82
153
|
_SpoTermListCommand_instances = new WeakSet(), _SpoTermListCommand_initTelemetry = function _SpoTermListCommand_initTelemetry() {
|
|
83
154
|
this.telemetry.push((args) => {
|
|
@@ -85,7 +156,8 @@ _SpoTermListCommand_instances = new WeakSet(), _SpoTermListCommand_initTelemetry
|
|
|
85
156
|
termGroupId: typeof args.options.termGroupId !== 'undefined',
|
|
86
157
|
termGroupName: typeof args.options.termGroupName !== 'undefined',
|
|
87
158
|
termSetId: typeof args.options.termSetId !== 'undefined',
|
|
88
|
-
termSetName: typeof args.options.termSetName !== 'undefined'
|
|
159
|
+
termSetName: typeof args.options.termSetName !== 'undefined',
|
|
160
|
+
includeChildTerms: !!args.options.includeChildTerms
|
|
89
161
|
});
|
|
90
162
|
});
|
|
91
163
|
}, _SpoTermListCommand_initOptions = function _SpoTermListCommand_initOptions() {
|
|
@@ -97,18 +169,16 @@ _SpoTermListCommand_instances = new WeakSet(), _SpoTermListCommand_initTelemetry
|
|
|
97
169
|
option: '--termSetId [termSetId]'
|
|
98
170
|
}, {
|
|
99
171
|
option: '--termSetName [termSetName]'
|
|
172
|
+
}, {
|
|
173
|
+
option: '--includeChildTerms'
|
|
100
174
|
});
|
|
101
175
|
}, _SpoTermListCommand_initValidators = function _SpoTermListCommand_initValidators() {
|
|
102
176
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
103
|
-
if (args.options.termGroupId) {
|
|
104
|
-
|
|
105
|
-
return `${args.options.termGroupId} is not a valid GUID`;
|
|
106
|
-
}
|
|
177
|
+
if (args.options.termGroupId && !validation_1.validation.isValidGuid(args.options.termGroupId)) {
|
|
178
|
+
return `${args.options.termGroupId} is not a valid GUID`;
|
|
107
179
|
}
|
|
108
|
-
if (args.options.termSetId) {
|
|
109
|
-
|
|
110
|
-
return `${args.options.termSetId} is not a valid GUID`;
|
|
111
|
-
}
|
|
180
|
+
if (args.options.termSetId && !validation_1.validation.isValidGuid(args.options.termSetId)) {
|
|
181
|
+
return `${args.options.termSetId} is not a valid GUID`;
|
|
112
182
|
}
|
|
113
183
|
return true;
|
|
114
184
|
}));
|
|
@@ -57,6 +57,8 @@ exports.default = {
|
|
|
57
57
|
FILE_MOVE: `${prefix} file move`,
|
|
58
58
|
FILE_REMOVE: `${prefix} file remove`,
|
|
59
59
|
FILE_RENAME: `${prefix} file rename`,
|
|
60
|
+
FILE_RETENTIONLABEL_ENSURE: `${prefix} file retentionlabel ensure`,
|
|
61
|
+
FILE_RETENTIONLABEL_REMOVE: `${prefix} file retentionlabel remove`,
|
|
60
62
|
FILE_ROLEASSIGNMENT_ADD: `${prefix} file roleassignment add`,
|
|
61
63
|
FILE_ROLEASSIGNMENT_REMOVE: `${prefix} file roleassignment remove`,
|
|
62
64
|
FILE_ROLEINHERITANCE_BREAK: `${prefix} file roleinheritance break`,
|
|
@@ -77,6 +79,8 @@ exports.default = {
|
|
|
77
79
|
FOLDER_MOVE: `${prefix} folder move`,
|
|
78
80
|
FOLDER_REMOVE: `${prefix} folder remove`,
|
|
79
81
|
FOLDER_RENAME: `${prefix} folder rename`,
|
|
82
|
+
FOLDER_RETENTIONLABEL_ENSURE: `${prefix} folder retentionlabel ensure`,
|
|
83
|
+
FOLDER_RETENTIONLABEL_REMOVE: `${prefix} folder retentionlabel remove`,
|
|
80
84
|
FOLDER_ROLEASSIGNMENT_REMOVE: `${prefix} folder roleassignment remove`,
|
|
81
85
|
FOLDER_ROLEASSIGNMENT_ADD: `${prefix} folder roleassignment add`,
|
|
82
86
|
FOLDER_ROLEINHERITANCE_BREAK: `${prefix} folder roleinheritance break`,
|
|
@@ -120,6 +124,7 @@ exports.default = {
|
|
|
120
124
|
LIST_REMOVE: `${prefix} list remove`,
|
|
121
125
|
LIST_RETENTIONLABEL_ENSURE: `${prefix} list retentionlabel ensure`,
|
|
122
126
|
LIST_RETENTIONLABEL_GET: `${prefix} list retentionlabel get`,
|
|
127
|
+
LIST_RETENTIONLABEL_REMOVE: `${prefix} list retentionlabel remove`,
|
|
123
128
|
LIST_ROLEASSIGNMENT_REMOVE: `${prefix} list roleassignment remove`,
|
|
124
129
|
LIST_ROLEASSIGNMENT_ADD: `${prefix} list roleassignment add`,
|
|
125
130
|
LIST_ROLEINHERITANCE_BREAK: `${prefix} list roleinheritance break`,
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
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
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _TeamsMessageSendCommand_instances, _TeamsMessageSendCommand_initOptions, _TeamsMessageSendCommand_initValidators;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const validation_1 = require("../../../../utils/validation");
|
|
20
|
+
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
21
|
+
const commands_1 = require("../../commands");
|
|
22
|
+
class TeamsMessageSendCommand extends GraphCommand_1.default {
|
|
23
|
+
get name() {
|
|
24
|
+
return commands_1.default.MESSAGE_SEND;
|
|
25
|
+
}
|
|
26
|
+
get description() {
|
|
27
|
+
return 'Sends a message to a channel in a Microsoft Teams team';
|
|
28
|
+
}
|
|
29
|
+
constructor() {
|
|
30
|
+
super();
|
|
31
|
+
_TeamsMessageSendCommand_instances.add(this);
|
|
32
|
+
__classPrivateFieldGet(this, _TeamsMessageSendCommand_instances, "m", _TeamsMessageSendCommand_initOptions).call(this);
|
|
33
|
+
__classPrivateFieldGet(this, _TeamsMessageSendCommand_instances, "m", _TeamsMessageSendCommand_initValidators).call(this);
|
|
34
|
+
}
|
|
35
|
+
commandAction(logger, args) {
|
|
36
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
37
|
+
try {
|
|
38
|
+
const requestOptions = {
|
|
39
|
+
url: `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${args.options.channelId}/messages`,
|
|
40
|
+
headers: {
|
|
41
|
+
accept: 'application/json;odata.metadata=none',
|
|
42
|
+
'content-type': 'application/json'
|
|
43
|
+
},
|
|
44
|
+
responseType: 'json',
|
|
45
|
+
data: {
|
|
46
|
+
body: {
|
|
47
|
+
contentType: 'html',
|
|
48
|
+
content: args.options.message
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
const response = yield request_1.default.post(requestOptions);
|
|
53
|
+
logger.log(response);
|
|
54
|
+
}
|
|
55
|
+
catch (err) {
|
|
56
|
+
this.handleRejectedODataJsonPromise(err);
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
_TeamsMessageSendCommand_instances = new WeakSet(), _TeamsMessageSendCommand_initOptions = function _TeamsMessageSendCommand_initOptions() {
|
|
62
|
+
this.options.unshift({
|
|
63
|
+
option: '-i, --teamId <teamId>'
|
|
64
|
+
}, {
|
|
65
|
+
option: '-c, --channelId <channelId>'
|
|
66
|
+
}, {
|
|
67
|
+
option: '-m, --message <message>'
|
|
68
|
+
});
|
|
69
|
+
}, _TeamsMessageSendCommand_initValidators = function _TeamsMessageSendCommand_initValidators() {
|
|
70
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
71
|
+
if (!validation_1.validation.isValidGuid(args.options.teamId)) {
|
|
72
|
+
return `${args.options.teamId} is not a valid GUID`;
|
|
73
|
+
}
|
|
74
|
+
if (!validation_1.validation.isValidTeamsChannelId(args.options.channelId)) {
|
|
75
|
+
return `${args.options.channelId} is not a valid Teams ChannelId`;
|
|
76
|
+
}
|
|
77
|
+
return true;
|
|
78
|
+
}));
|
|
79
|
+
};
|
|
80
|
+
module.exports = new TeamsMessageSendCommand();
|
|
81
|
+
//# sourceMappingURL=message-send.js.map
|
|
@@ -35,6 +35,7 @@ exports.default = {
|
|
|
35
35
|
MESSAGE_GET: `${prefix} message get`,
|
|
36
36
|
MESSAGE_LIST: `${prefix} message list`,
|
|
37
37
|
MESSAGE_REPLY_LIST: `${prefix} message reply list`,
|
|
38
|
+
MESSAGE_SEND: `${prefix} message send`,
|
|
38
39
|
MESSAGINGSETTINGS_LIST: `${prefix} messagingsettings list`,
|
|
39
40
|
MESSAGINGSETTINGS_SET: `${prefix} messagingsettings set`,
|
|
40
41
|
REPORT_DEVICEUSAGEDISTRIBUTIONUSERCOUNTS: `${prefix} report deviceusagedistributionusercounts`,
|
package/dist/utils/formatting.js
CHANGED
|
@@ -110,6 +110,28 @@ exports.formatting = {
|
|
|
110
110
|
default:
|
|
111
111
|
return value;
|
|
112
112
|
}
|
|
113
|
+
},
|
|
114
|
+
/**
|
|
115
|
+
* Converts an object into an xml:
|
|
116
|
+
* @obj the actual objec
|
|
117
|
+
* @returns A string containing the xml
|
|
118
|
+
*/
|
|
119
|
+
objectToXml(obj) {
|
|
120
|
+
let xml = '';
|
|
121
|
+
for (const prop in obj) {
|
|
122
|
+
xml += "<" + prop + ">";
|
|
123
|
+
if (obj[prop] instanceof Array) {
|
|
124
|
+
for (const array in obj[prop]) {
|
|
125
|
+
xml += this.objectToXml(new Object(obj[prop][array]));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
xml += obj[prop];
|
|
130
|
+
}
|
|
131
|
+
xml += "</" + prop + ">";
|
|
132
|
+
}
|
|
133
|
+
xml = xml.replace(/<\/?[0-9]{1,}>/g, '');
|
|
134
|
+
return xml;
|
|
113
135
|
}
|
|
114
136
|
};
|
|
115
137
|
//# sourceMappingURL=formatting.js.map
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# context option remove
|
|
2
|
+
|
|
3
|
+
Removes an already available name from local context file.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
|
|
7
|
+
```sh
|
|
8
|
+
m365 context option remove [options]
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Options
|
|
12
|
+
|
|
13
|
+
`-n, --name <name>`
|
|
14
|
+
: The name of the option which will be deleted from the context
|
|
15
|
+
|
|
16
|
+
`--confirm`
|
|
17
|
+
: Don't prompt for confirming removing the option
|
|
18
|
+
|
|
19
|
+
--8<-- "docs/cmd/_global.md"
|
|
20
|
+
|
|
21
|
+
## Examples
|
|
22
|
+
|
|
23
|
+
Removes an already available name from the local context file
|
|
24
|
+
|
|
25
|
+
```sh
|
|
26
|
+
m365 context option remove --name "listName"
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
Removes an already available name from the local context file without confirmation
|
|
30
|
+
|
|
31
|
+
```sh
|
|
32
|
+
m365 context option remove --name "listName" --confirm
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
## Response
|
|
36
|
+
|
|
37
|
+
The command won't return a response on success.
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# context option set
|
|
2
|
+
|
|
3
|
+
Allows to add a new name for the option and value to the local context file.
|
|
4
|
+
|
|
5
|
+
## Usage
|
|
6
|
+
|
|
7
|
+
```sh
|
|
8
|
+
m365 context option set [options]
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Options
|
|
12
|
+
|
|
13
|
+
`-n, --name <name>`
|
|
14
|
+
: The option name for which we will define the value
|
|
15
|
+
|
|
16
|
+
`-v, --value <value>`
|
|
17
|
+
: Default value for the option
|
|
18
|
+
|
|
19
|
+
--8<-- "docs/cmd/_global.md"
|
|
20
|
+
|
|
21
|
+
## Examples
|
|
22
|
+
|
|
23
|
+
Define a new default value for name listName in the context
|
|
24
|
+
|
|
25
|
+
```sh
|
|
26
|
+
m365 context option set --name 'listName' --value 'testList'
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
## Response
|
|
30
|
+
|
|
31
|
+
The command won't return a response on success.
|