@pnp/cli-microsoft365 6.2.0-beta.329fd79 → 6.2.0-beta.647e291
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 +6 -0
- package/dist/m365/aad/commands/approleassignment/approleassignment-add.js +3 -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-list.js +68 -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 +4 -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/GraphFileDetails.js +3 -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/file/file-sharinginfo-get.js +12 -12
- package/dist/m365/spo/commands/file/file-sharinglink-get.js +116 -0
- package/dist/m365/spo/commands/file/file-sharinglink-list.js +133 -0
- package/dist/m365/spo/commands/file/file-sharinglink-remove.js +135 -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/group/group-member-remove.js +78 -33
- package/dist/m365/spo/commands/list/list-add.js +3 -0
- package/dist/m365/spo/commands/list/list-retentionlabel-ensure.js +10 -2
- 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/ListItemRetentionLabel.js +3 -0
- package/dist/m365/spo/commands/listitem/SiteRetentionLabel.js +3 -0
- package/dist/m365/spo/commands/listitem/listitem-list.js +1 -1
- package/dist/m365/spo/commands/listitem/listitem-retentionlabel-ensure.js +161 -0
- 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 +9 -0
- package/dist/m365/teams/commands/chat/chat-list.js +29 -7
- package/dist/m365/teams/commands/message/message-send.js +81 -0
- package/dist/m365/teams/commands.js +1 -0
- package/dist/request.js +2 -2
- package/dist/utils/formatting.js +22 -0
- package/docs/docs/cmd/onenote/page/page-list.md +140 -0
- package/docs/docs/cmd/planner/bucket/bucket-add.md +17 -0
- package/docs/docs/cmd/planner/bucket/bucket-get.md +17 -0
- package/docs/docs/cmd/planner/bucket/bucket-list.md +17 -0
- package/docs/docs/cmd/planner/plan/plan-add.md +40 -0
- package/docs/docs/cmd/planner/plan/plan-get.md +21 -0
- package/docs/docs/cmd/planner/plan/plan-list.md +19 -0
- package/docs/docs/cmd/planner/plan/plan-set.md +20 -0
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-get.md +99 -0
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-list.md +95 -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/file/file-sharinglink-get.md +107 -0
- package/docs/docs/cmd/spo/file/file-sharinglink-list.md +106 -0
- package/docs/docs/cmd/spo/file/file-sharinglink-remove.md +52 -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/group/group-member-remove.md +24 -6
- package/docs/docs/cmd/spo/list/list-add.md +3 -9
- package/docs/docs/cmd/spo/list/list-retentionlabel-ensure.md +8 -5
- 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/listitem/listitem-retentionlabel-ensure.md +58 -0
- package/docs/docs/cmd/spo/term/term-list.md +138 -0
- package/docs/docs/cmd/teams/chat/chat-list.md +16 -4
- package/docs/docs/cmd/teams/message/message-send.md +119 -0
- package/npm-shrinkwrap.json +182 -202
- package/package.json +12 -11
|
@@ -0,0 +1,135 @@
|
|
|
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 _SpoFileSharingLinkRemoveCommand_instances, _SpoFileSharingLinkRemoveCommand_initTelemetry, _SpoFileSharingLinkRemoveCommand_initOptions, _SpoFileSharingLinkRemoveCommand_initValidators, _SpoFileSharingLinkRemoveCommand_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 SpoFileSharingLinkRemoveCommand extends SpoCommand_1.default {
|
|
26
|
+
get name() {
|
|
27
|
+
return commands_1.default.FILE_SHARINGLINK_REMOVE;
|
|
28
|
+
}
|
|
29
|
+
get description() {
|
|
30
|
+
return 'Removes a specific sharing link of a file';
|
|
31
|
+
}
|
|
32
|
+
constructor() {
|
|
33
|
+
super();
|
|
34
|
+
_SpoFileSharingLinkRemoveCommand_instances.add(this);
|
|
35
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkRemoveCommand_instances, "m", _SpoFileSharingLinkRemoveCommand_initTelemetry).call(this);
|
|
36
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkRemoveCommand_instances, "m", _SpoFileSharingLinkRemoveCommand_initOptions).call(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkRemoveCommand_instances, "m", _SpoFileSharingLinkRemoveCommand_initValidators).call(this);
|
|
38
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkRemoveCommand_instances, "m", _SpoFileSharingLinkRemoveCommand_initOptionSets).call(this);
|
|
39
|
+
}
|
|
40
|
+
commandAction(logger, args) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const removeSharingLink = () => __awaiter(this, void 0, void 0, function* () {
|
|
43
|
+
try {
|
|
44
|
+
if (this.verbose) {
|
|
45
|
+
logger.logToStderr(`Removing sharing link of file ${args.options.fileUrl || args.options.fileId} with id ${args.options.id}...`);
|
|
46
|
+
}
|
|
47
|
+
const fileDetails = yield this.getNeededFileInformation(args);
|
|
48
|
+
const requestOptions = {
|
|
49
|
+
url: `https://graph.microsoft.com/v1.0/sites/${fileDetails.SiteId}/drives/${fileDetails.VroomDriveID}/items/${fileDetails.VroomItemID}/permissions/${args.options.id}`,
|
|
50
|
+
headers: {
|
|
51
|
+
accept: 'application/json;odata.metadata=none'
|
|
52
|
+
},
|
|
53
|
+
responseType: 'json'
|
|
54
|
+
};
|
|
55
|
+
yield request_1.default.delete(requestOptions);
|
|
56
|
+
}
|
|
57
|
+
catch (err) {
|
|
58
|
+
this.handleRejectedODataJsonPromise(err);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
if (args.options.confirm) {
|
|
62
|
+
yield removeSharingLink();
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
const result = yield Cli_1.Cli.prompt({
|
|
66
|
+
type: 'confirm',
|
|
67
|
+
name: 'continue',
|
|
68
|
+
default: false,
|
|
69
|
+
message: `Are you sure you want to remove sharing link ${args.options.id} of file ${args.options.fileUrl || args.options.fileId}?`
|
|
70
|
+
});
|
|
71
|
+
if (result.continue) {
|
|
72
|
+
yield removeSharingLink();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
getNeededFileInformation(args) {
|
|
78
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
79
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
80
|
+
if (args.options.fileUrl) {
|
|
81
|
+
const fileServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
82
|
+
requestUrl += `GetFileByServerRelativePath(decodedUrl='${formatting_1.formatting.encodeQueryParameter(fileServerRelativeUrl)}')`;
|
|
83
|
+
}
|
|
84
|
+
else {
|
|
85
|
+
requestUrl += `GetFileById('${args.options.fileId}')`;
|
|
86
|
+
}
|
|
87
|
+
requestUrl += '?$select=SiteId,VroomItemId,VroomDriveId';
|
|
88
|
+
const requestOptions = {
|
|
89
|
+
url: requestUrl,
|
|
90
|
+
headers: {
|
|
91
|
+
accept: 'application/json;odata=nometadata'
|
|
92
|
+
},
|
|
93
|
+
responseType: 'json'
|
|
94
|
+
};
|
|
95
|
+
const res = yield request_1.default.get(requestOptions);
|
|
96
|
+
return res;
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
_SpoFileSharingLinkRemoveCommand_instances = new WeakSet(), _SpoFileSharingLinkRemoveCommand_initTelemetry = function _SpoFileSharingLinkRemoveCommand_initTelemetry() {
|
|
101
|
+
this.telemetry.push((args) => {
|
|
102
|
+
Object.assign(this.telemetryProperties, {
|
|
103
|
+
fileUrl: typeof args.options.fileUrl !== 'undefined',
|
|
104
|
+
fileId: typeof args.options.fileId !== 'undefined',
|
|
105
|
+
confirm: !!args.options.confirm
|
|
106
|
+
});
|
|
107
|
+
});
|
|
108
|
+
}, _SpoFileSharingLinkRemoveCommand_initOptions = function _SpoFileSharingLinkRemoveCommand_initOptions() {
|
|
109
|
+
this.options.unshift({
|
|
110
|
+
option: '-u, --webUrl <webUrl>'
|
|
111
|
+
}, {
|
|
112
|
+
option: '--fileUrl [fileUrl]'
|
|
113
|
+
}, {
|
|
114
|
+
option: '--fileId [fileId]'
|
|
115
|
+
}, {
|
|
116
|
+
option: '-i, --id <id>'
|
|
117
|
+
}, {
|
|
118
|
+
option: '--confirm'
|
|
119
|
+
});
|
|
120
|
+
}, _SpoFileSharingLinkRemoveCommand_initValidators = function _SpoFileSharingLinkRemoveCommand_initValidators() {
|
|
121
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
122
|
+
const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
123
|
+
if (isValidSharePointUrl !== true) {
|
|
124
|
+
return isValidSharePointUrl;
|
|
125
|
+
}
|
|
126
|
+
if (args.options.fileId && !validation_1.validation.isValidGuid(args.options.fileId)) {
|
|
127
|
+
return `${args.options.fileId} is not a valid GUID`;
|
|
128
|
+
}
|
|
129
|
+
return true;
|
|
130
|
+
}));
|
|
131
|
+
}, _SpoFileSharingLinkRemoveCommand_initOptionSets = function _SpoFileSharingLinkRemoveCommand_initOptionSets() {
|
|
132
|
+
this.optionSets.push({ options: ['fileUrl', 'fileId'] });
|
|
133
|
+
};
|
|
134
|
+
module.exports = new SpoFileSharingLinkRemoveCommand();
|
|
135
|
+
//# sourceMappingURL=file-sharinglink-remove.js.map
|
|
@@ -0,0 +1,138 @@
|
|
|
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 _SpoFolderRetentionLabelEnsureCommand_instances, _SpoFolderRetentionLabelEnsureCommand_initTelemetry, _SpoFolderRetentionLabelEnsureCommand_initOptions, _SpoFolderRetentionLabelEnsureCommand_initValidators, _SpoFolderRetentionLabelEnsureCommand_initOptionSets;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const Cli_1 = require("../../../../cli/Cli");
|
|
19
|
+
const request_1 = require("../../../../request");
|
|
20
|
+
const validation_1 = require("../../../../utils/validation");
|
|
21
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
|
+
const commands_1 = require("../../commands");
|
|
23
|
+
const SpoListItemRetentionLabelEnsureCommand = require("../listitem/listitem-retentionlabel-ensure");
|
|
24
|
+
const SpoListRetentionLabelEnsureCommand = require("../list/list-retentionlabel-ensure");
|
|
25
|
+
const formatting_1 = require("../../../../utils/formatting");
|
|
26
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
27
|
+
class SpoFolderRetentionLabelEnsureCommand extends SpoCommand_1.default {
|
|
28
|
+
get name() {
|
|
29
|
+
return commands_1.default.FOLDER_RETENTIONLABEL_ENSURE;
|
|
30
|
+
}
|
|
31
|
+
get description() {
|
|
32
|
+
return 'Apply a retention label to a folder';
|
|
33
|
+
}
|
|
34
|
+
constructor() {
|
|
35
|
+
super();
|
|
36
|
+
_SpoFolderRetentionLabelEnsureCommand_instances.add(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelEnsureCommand_instances, "m", _SpoFolderRetentionLabelEnsureCommand_initTelemetry).call(this);
|
|
38
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelEnsureCommand_instances, "m", _SpoFolderRetentionLabelEnsureCommand_initOptions).call(this);
|
|
39
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelEnsureCommand_instances, "m", _SpoFolderRetentionLabelEnsureCommand_initValidators).call(this);
|
|
40
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelEnsureCommand_instances, "m", _SpoFolderRetentionLabelEnsureCommand_initOptionSets).call(this);
|
|
41
|
+
}
|
|
42
|
+
commandAction(logger, args) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
try {
|
|
45
|
+
const folderProperties = yield this.getFolderProperties(logger, args);
|
|
46
|
+
if (folderProperties.ListItemAllFields) {
|
|
47
|
+
const options = {
|
|
48
|
+
webUrl: args.options.webUrl,
|
|
49
|
+
listId: folderProperties.ListItemAllFields.ParentList.Id,
|
|
50
|
+
listItemId: folderProperties.ListItemAllFields.Id,
|
|
51
|
+
name: args.options.name,
|
|
52
|
+
output: 'json',
|
|
53
|
+
debug: this.debug,
|
|
54
|
+
verbose: this.verbose
|
|
55
|
+
};
|
|
56
|
+
const spoListItemRetentionLabelEnsureCommandOutput = yield Cli_1.Cli.executeCommandWithOutput(SpoListItemRetentionLabelEnsureCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
|
|
57
|
+
if (this.verbose) {
|
|
58
|
+
logger.logToStderr(spoListItemRetentionLabelEnsureCommandOutput.stderr);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
const options = {
|
|
63
|
+
webUrl: args.options.webUrl,
|
|
64
|
+
listUrl: folderProperties.ServerRelativeUrl,
|
|
65
|
+
name: args.options.name,
|
|
66
|
+
output: 'json',
|
|
67
|
+
debug: this.debug,
|
|
68
|
+
verbose: this.verbose
|
|
69
|
+
};
|
|
70
|
+
const spoListRetentionLabelEnsureCommandOutput = yield Cli_1.Cli.executeCommandWithOutput(SpoListRetentionLabelEnsureCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
|
|
71
|
+
if (this.verbose) {
|
|
72
|
+
logger.logToStderr(spoListRetentionLabelEnsureCommandOutput.stderr);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
catch (err) {
|
|
77
|
+
this.handleRejectedODataJsonPromise(err);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
getFolderProperties(logger, args) {
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
if (this.verbose) {
|
|
84
|
+
logger.logToStderr(`Retrieving list and item information for folder '${args.options.folderId || args.options.folderUrl}' in site at ${args.options.webUrl}...`);
|
|
85
|
+
}
|
|
86
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
87
|
+
if (args.options.folderId) {
|
|
88
|
+
requestUrl += `GetFolderById('${args.options.folderId}')`;
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
const serverRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.folderUrl);
|
|
92
|
+
requestUrl += `GetFolderByServerRelativeUrl('${formatting_1.formatting.encodeQueryParameter(serverRelativeUrl)}')`;
|
|
93
|
+
}
|
|
94
|
+
const requestOptions = {
|
|
95
|
+
url: `${requestUrl}?$expand=ListItemAllFields,ListItemAllFields/ParentList&$select=ServerRelativeUrl,ListItemAllFields/ParentList/Id,ListItemAllFields/Id`,
|
|
96
|
+
headers: {
|
|
97
|
+
'accept': 'application/json;odata=nometadata'
|
|
98
|
+
},
|
|
99
|
+
responseType: 'json'
|
|
100
|
+
};
|
|
101
|
+
return yield request_1.default.get(requestOptions);
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
_SpoFolderRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoFolderRetentionLabelEnsureCommand_initTelemetry = function _SpoFolderRetentionLabelEnsureCommand_initTelemetry() {
|
|
106
|
+
this.telemetry.push((args) => {
|
|
107
|
+
Object.assign(this.telemetryProperties, {
|
|
108
|
+
folderUrl: typeof args.options.folderUrl !== 'undefined',
|
|
109
|
+
folderId: typeof args.options.folderId !== 'undefined'
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
}, _SpoFolderRetentionLabelEnsureCommand_initOptions = function _SpoFolderRetentionLabelEnsureCommand_initOptions() {
|
|
113
|
+
this.options.unshift({
|
|
114
|
+
option: '-u, --webUrl <webUrl>'
|
|
115
|
+
}, {
|
|
116
|
+
option: '--name <name>'
|
|
117
|
+
}, {
|
|
118
|
+
option: '--folderUrl [folderUrl]'
|
|
119
|
+
}, {
|
|
120
|
+
option: 'i, --folderId [folderId]'
|
|
121
|
+
});
|
|
122
|
+
}, _SpoFolderRetentionLabelEnsureCommand_initValidators = function _SpoFolderRetentionLabelEnsureCommand_initValidators() {
|
|
123
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
124
|
+
const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
125
|
+
if (isValidSharePointUrl !== true) {
|
|
126
|
+
return isValidSharePointUrl;
|
|
127
|
+
}
|
|
128
|
+
if (args.options.folderId &&
|
|
129
|
+
!validation_1.validation.isValidGuid(args.options.folderId)) {
|
|
130
|
+
return `${args.options.folderId} is not a valid GUID`;
|
|
131
|
+
}
|
|
132
|
+
return true;
|
|
133
|
+
}));
|
|
134
|
+
}, _SpoFolderRetentionLabelEnsureCommand_initOptionSets = function _SpoFolderRetentionLabelEnsureCommand_initOptionSets() {
|
|
135
|
+
this.optionSets.push({ options: ['folderUrl', 'folderId'] });
|
|
136
|
+
};
|
|
137
|
+
module.exports = new SpoFolderRetentionLabelEnsureCommand();
|
|
138
|
+
//# sourceMappingURL=folder-retentionlabel-ensure.js.map
|
|
@@ -0,0 +1,157 @@
|
|
|
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 _SpoFolderRetentionLabelRemoveCommand_instances, _SpoFolderRetentionLabelRemoveCommand_initTelemetry, _SpoFolderRetentionLabelRemoveCommand_initOptions, _SpoFolderRetentionLabelRemoveCommand_initValidators, _SpoFolderRetentionLabelRemoveCommand_initOptionSets;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const Cli_1 = require("../../../../cli/Cli");
|
|
19
|
+
const request_1 = require("../../../../request");
|
|
20
|
+
const validation_1 = require("../../../../utils/validation");
|
|
21
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
|
+
const commands_1 = require("../../commands");
|
|
23
|
+
const SpoListItemRetentionLabelRemoveCommand = require("../listitem/listitem-retentionlabel-remove");
|
|
24
|
+
const SpoListRetentionLabelRemoveCommand = require("../list/list-retentionlabel-remove");
|
|
25
|
+
const formatting_1 = require("../../../../utils/formatting");
|
|
26
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
27
|
+
class SpoFolderRetentionLabelRemoveCommand extends SpoCommand_1.default {
|
|
28
|
+
get name() {
|
|
29
|
+
return commands_1.default.FOLDER_RETENTIONLABEL_REMOVE;
|
|
30
|
+
}
|
|
31
|
+
get description() {
|
|
32
|
+
return 'Clear the retention label from a folder';
|
|
33
|
+
}
|
|
34
|
+
constructor() {
|
|
35
|
+
super();
|
|
36
|
+
_SpoFolderRetentionLabelRemoveCommand_instances.add(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelRemoveCommand_instances, "m", _SpoFolderRetentionLabelRemoveCommand_initTelemetry).call(this);
|
|
38
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelRemoveCommand_instances, "m", _SpoFolderRetentionLabelRemoveCommand_initOptions).call(this);
|
|
39
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelRemoveCommand_instances, "m", _SpoFolderRetentionLabelRemoveCommand_initValidators).call(this);
|
|
40
|
+
__classPrivateFieldGet(this, _SpoFolderRetentionLabelRemoveCommand_instances, "m", _SpoFolderRetentionLabelRemoveCommand_initOptionSets).call(this);
|
|
41
|
+
}
|
|
42
|
+
commandAction(logger, args) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
if (args.options.confirm) {
|
|
45
|
+
yield this.removeFolderRetentionLabel(logger, args);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
const result = yield Cli_1.Cli.prompt({
|
|
49
|
+
type: 'confirm',
|
|
50
|
+
name: 'continue',
|
|
51
|
+
default: false,
|
|
52
|
+
message: `Are you sure you want to remove the retentionlabel from folder ${args.options.folderId || args.options.folderUrl} located in site ${args.options.webUrl}?`
|
|
53
|
+
});
|
|
54
|
+
if (result.continue) {
|
|
55
|
+
yield this.removeFolderRetentionLabel(logger, args);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
removeFolderRetentionLabel(logger, args) {
|
|
61
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
62
|
+
try {
|
|
63
|
+
const folderProperties = yield this.getFolderProperties(logger, args);
|
|
64
|
+
if (folderProperties.ListItemAllFields) {
|
|
65
|
+
const options = {
|
|
66
|
+
webUrl: args.options.webUrl,
|
|
67
|
+
listId: folderProperties.ListItemAllFields.ParentList.Id,
|
|
68
|
+
listItemId: folderProperties.ListItemAllFields.Id,
|
|
69
|
+
confirm: true,
|
|
70
|
+
output: 'json',
|
|
71
|
+
debug: this.debug,
|
|
72
|
+
verbose: this.verbose
|
|
73
|
+
};
|
|
74
|
+
const spoListItemRetentionLabelRemoveCommandOutput = yield Cli_1.Cli.executeCommandWithOutput(SpoListItemRetentionLabelRemoveCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
|
|
75
|
+
if (this.verbose) {
|
|
76
|
+
logger.logToStderr(spoListItemRetentionLabelRemoveCommandOutput.stderr);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
const options = {
|
|
81
|
+
webUrl: args.options.webUrl,
|
|
82
|
+
listUrl: folderProperties.ServerRelativeUrl,
|
|
83
|
+
confirm: true,
|
|
84
|
+
output: 'json',
|
|
85
|
+
debug: this.debug,
|
|
86
|
+
verbose: this.verbose
|
|
87
|
+
};
|
|
88
|
+
const spoListRetentionLabelEnsureCommandOutput = yield Cli_1.Cli.executeCommandWithOutput(SpoListRetentionLabelRemoveCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
|
|
89
|
+
if (this.verbose) {
|
|
90
|
+
logger.logToStderr(spoListRetentionLabelEnsureCommandOutput.stderr);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
catch (err) {
|
|
95
|
+
this.handleRejectedODataJsonPromise(err);
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
getFolderProperties(logger, args) {
|
|
100
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
101
|
+
if (this.verbose) {
|
|
102
|
+
logger.logToStderr(`Retrieving list and item information for folder '${args.options.folderId || args.options.folderUrl}' in site at ${args.options.webUrl}...`);
|
|
103
|
+
}
|
|
104
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
105
|
+
if (args.options.folderId) {
|
|
106
|
+
requestUrl += `GetFolderById('${args.options.folderId}')`;
|
|
107
|
+
}
|
|
108
|
+
else {
|
|
109
|
+
const serverRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.folderUrl);
|
|
110
|
+
requestUrl += `GetFolderByServerRelativeUrl('${formatting_1.formatting.encodeQueryParameter(serverRelativeUrl)}')`;
|
|
111
|
+
}
|
|
112
|
+
const requestOptions = {
|
|
113
|
+
url: `${requestUrl}?$expand=ListItemAllFields,ListItemAllFields/ParentList&$select=ServerRelativeUrl,ListItemAllFields/ParentList/Id,ListItemAllFields/Id`,
|
|
114
|
+
headers: {
|
|
115
|
+
'accept': 'application/json;odata=nometadata'
|
|
116
|
+
},
|
|
117
|
+
responseType: 'json'
|
|
118
|
+
};
|
|
119
|
+
return yield request_1.default.get(requestOptions);
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
_SpoFolderRetentionLabelRemoveCommand_instances = new WeakSet(), _SpoFolderRetentionLabelRemoveCommand_initTelemetry = function _SpoFolderRetentionLabelRemoveCommand_initTelemetry() {
|
|
124
|
+
this.telemetry.push((args) => {
|
|
125
|
+
Object.assign(this.telemetryProperties, {
|
|
126
|
+
folderUrl: typeof args.options.folderUrl !== 'undefined',
|
|
127
|
+
folderId: typeof args.options.folderId !== 'undefined',
|
|
128
|
+
confirm: !!args.options.confirm
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
}, _SpoFolderRetentionLabelRemoveCommand_initOptions = function _SpoFolderRetentionLabelRemoveCommand_initOptions() {
|
|
132
|
+
this.options.unshift({
|
|
133
|
+
option: '-u, --webUrl <webUrl>'
|
|
134
|
+
}, {
|
|
135
|
+
option: '--folderUrl [folderUrl]'
|
|
136
|
+
}, {
|
|
137
|
+
option: '-i, --folderId [folderId]'
|
|
138
|
+
}, {
|
|
139
|
+
option: '--confirm'
|
|
140
|
+
});
|
|
141
|
+
}, _SpoFolderRetentionLabelRemoveCommand_initValidators = function _SpoFolderRetentionLabelRemoveCommand_initValidators() {
|
|
142
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
143
|
+
const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
144
|
+
if (isValidSharePointUrl !== true) {
|
|
145
|
+
return isValidSharePointUrl;
|
|
146
|
+
}
|
|
147
|
+
if (args.options.folderId &&
|
|
148
|
+
!validation_1.validation.isValidGuid(args.options.folderId)) {
|
|
149
|
+
return `${args.options.folderId} is not a valid GUID`;
|
|
150
|
+
}
|
|
151
|
+
return true;
|
|
152
|
+
}));
|
|
153
|
+
}, _SpoFolderRetentionLabelRemoveCommand_initOptionSets = function _SpoFolderRetentionLabelRemoveCommand_initOptionSets() {
|
|
154
|
+
this.optionSets.push({ options: ['folderUrl', 'folderId'] });
|
|
155
|
+
};
|
|
156
|
+
module.exports = new SpoFolderRetentionLabelRemoveCommand();
|
|
157
|
+
//# sourceMappingURL=folder-retentionlabel-remove.js.map
|
|
@@ -20,6 +20,7 @@ const request_1 = require("../../../../request");
|
|
|
20
20
|
const formatting_1 = require("../../../../utils/formatting");
|
|
21
21
|
const validation_1 = require("../../../../utils/validation");
|
|
22
22
|
const AadUserGetCommand = require("../../../aad/commands/user/user-get");
|
|
23
|
+
const AadGroupGetCommand = require("../../../aad/commands/group/group-get");
|
|
23
24
|
const SpoUserGetCommand = require("../user/user-get");
|
|
24
25
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
25
26
|
const commands_1 = require("../../commands");
|
|
@@ -47,7 +48,7 @@ class SpoGroupMemberAddCommand extends SpoCommand_1.default {
|
|
|
47
48
|
const groupId = yield this.getGroupId(args, logger);
|
|
48
49
|
const resolvedUsernameList = yield this.getValidUsers(args, logger);
|
|
49
50
|
if (this.verbose) {
|
|
50
|
-
logger.logToStderr(`Adding user(s) to SharePoint Group ${args.options.groupId
|
|
51
|
+
logger.logToStderr(`Adding user(s) to SharePoint Group ${args.options.groupId || args.options.groupName}`);
|
|
51
52
|
}
|
|
52
53
|
const data = {
|
|
53
54
|
url: args.options.webUrl,
|
|
@@ -104,15 +105,19 @@ class SpoGroupMemberAddCommand extends SpoCommand_1.default {
|
|
|
104
105
|
}
|
|
105
106
|
const validUserNames = [];
|
|
106
107
|
const invalidUserNames = [];
|
|
107
|
-
const userIdentifiers = args.options.userName || args.options.email || args.options.userId.toString();
|
|
108
|
+
const userIdentifiers = args.options.userName || args.options.email || args.options.aadGroupId || args.options.aadGroupName || args.options.userId.toString();
|
|
108
109
|
return Promise
|
|
109
110
|
.all(userIdentifiers.split(',').map((userIdentifier) => __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
const user = userIdentifier.trim();
|
|
110
112
|
try {
|
|
111
113
|
if (args.options.userId) {
|
|
112
|
-
yield this.spoUserGet(args.options,
|
|
114
|
+
yield this.spoUserGet(args.options, user, logger, validUserNames);
|
|
115
|
+
}
|
|
116
|
+
else if (args.options.aadGroupId || args.options.aadGroupName) {
|
|
117
|
+
yield this.aadGroupGet(args.options, user, logger, validUserNames);
|
|
113
118
|
}
|
|
114
119
|
else {
|
|
115
|
-
yield this.aadUserGet(args.options,
|
|
120
|
+
yield this.aadUserGet(args.options, user, logger, validUserNames);
|
|
116
121
|
}
|
|
117
122
|
}
|
|
118
123
|
catch (err) {
|
|
@@ -141,6 +146,19 @@ class SpoGroupMemberAddCommand extends SpoCommand_1.default {
|
|
|
141
146
|
validUserNames.push(JSON.parse(aadUserGetOutput.stdout).userPrincipalName);
|
|
142
147
|
});
|
|
143
148
|
}
|
|
149
|
+
aadGroupGet(options, userIdentifier, logger, validUserNames) {
|
|
150
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
151
|
+
if (this.verbose) {
|
|
152
|
+
logger.logToStderr(`Get UPN from Azure AD for group ${userIdentifier}`);
|
|
153
|
+
}
|
|
154
|
+
const aadUserGetCommandoptions = Object.assign(Object.assign(Object.assign({}, (options.aadGroupId && { id: userIdentifier })), (options.aadGroupName && { title: userIdentifier })), { output: 'json', debug: options.debug, verbose: options.verbose });
|
|
155
|
+
const aadGroupGetOutput = yield Cli_1.Cli.executeCommandWithOutput(AadGroupGetCommand, { options: Object.assign(Object.assign({}, aadUserGetCommandoptions), { _: [] }) });
|
|
156
|
+
if (this.debug) {
|
|
157
|
+
logger.logToStderr(aadGroupGetOutput.stderr);
|
|
158
|
+
}
|
|
159
|
+
validUserNames.push(JSON.parse(aadGroupGetOutput.stdout).mail);
|
|
160
|
+
});
|
|
161
|
+
}
|
|
144
162
|
spoUserGet(options, userIdentifier, logger, validUserNames) {
|
|
145
163
|
return __awaiter(this, void 0, void 0, function* () {
|
|
146
164
|
if (this.verbose) {
|
|
@@ -174,7 +192,9 @@ _SpoGroupMemberAddCommand_instances = new WeakSet(), _SpoGroupMemberAddCommand_i
|
|
|
174
192
|
groupName: typeof args.options.groupName !== 'undefined',
|
|
175
193
|
userName: typeof args.options.userName !== 'undefined',
|
|
176
194
|
email: typeof args.options.email !== 'undefined',
|
|
177
|
-
userId: typeof args.options.userId !== 'undefined'
|
|
195
|
+
userId: typeof args.options.userId !== 'undefined',
|
|
196
|
+
aadGroupId: typeof args.options.aadGroupId !== 'undefined',
|
|
197
|
+
aadGroupName: typeof args.options.aadGroupName !== 'undefined'
|
|
178
198
|
});
|
|
179
199
|
});
|
|
180
200
|
}, _SpoGroupMemberAddCommand_initOptions = function _SpoGroupMemberAddCommand_initOptions() {
|
|
@@ -190,6 +210,10 @@ _SpoGroupMemberAddCommand_instances = new WeakSet(), _SpoGroupMemberAddCommand_i
|
|
|
190
210
|
option: '--email [email]'
|
|
191
211
|
}, {
|
|
192
212
|
option: '--userId [userId]'
|
|
213
|
+
}, {
|
|
214
|
+
option: '--aadGroupId [aadGroupId]'
|
|
215
|
+
}, {
|
|
216
|
+
option: '--aadGroupName [aadGroupName]'
|
|
193
217
|
});
|
|
194
218
|
}, _SpoGroupMemberAddCommand_initValidators = function _SpoGroupMemberAddCommand_initValidators() {
|
|
195
219
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
@@ -210,10 +234,13 @@ _SpoGroupMemberAddCommand_instances = new WeakSet(), _SpoGroupMemberAddCommand_i
|
|
|
210
234
|
if (args.options.email && args.options.email.split(',').some(e => !validation_1.validation.isValidUserPrincipalName(e))) {
|
|
211
235
|
return `${args.options.email} contains one or more invalid email addresses`;
|
|
212
236
|
}
|
|
237
|
+
if (args.options.aadGroupId && args.options.aadGroupId.split(',').some(e => !validation_1.validation.isValidGuid(e))) {
|
|
238
|
+
return `${args.options.aadGroupId} contains one or more invalid GUIDs`;
|
|
239
|
+
}
|
|
213
240
|
return true;
|
|
214
241
|
}));
|
|
215
242
|
}, _SpoGroupMemberAddCommand_initOptionSets = function _SpoGroupMemberAddCommand_initOptionSets() {
|
|
216
|
-
this.optionSets.push({ options: ['groupId', 'groupName'] }, { options: ['userName', 'email', 'userId'] });
|
|
243
|
+
this.optionSets.push({ options: ['groupId', 'groupName'] }, { options: ['userName', 'email', 'userId', 'aadGroupId', 'aadGroupName'] });
|
|
217
244
|
};
|
|
218
245
|
module.exports = new SpoGroupMemberAddCommand();
|
|
219
246
|
//# sourceMappingURL=group-member-add.js.map
|