@pnp/cli-microsoft365 6.2.0-beta.d0cdaa3 → 6.2.0-beta.d5442a1

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.
Files changed (37) hide show
  1. package/.eslintrc.js +6 -0
  2. package/dist/m365/aad/commands/approleassignment/approleassignment-add.js +3 -0
  3. package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-list.js +68 -0
  4. package/dist/m365/pp/commands.js +1 -0
  5. package/dist/m365/purview/commands/retentionlabel/retentionlabel-get.js +70 -0
  6. package/dist/m365/purview/commands.js +1 -0
  7. package/dist/m365/spo/commands/file/GraphFileDetails.js +3 -0
  8. package/dist/m365/spo/commands/file/file-sharinginfo-get.js +12 -12
  9. package/dist/m365/spo/commands/file/file-sharinglink-list.js +120 -0
  10. package/dist/m365/spo/commands/group/group-member-remove.js +78 -33
  11. package/dist/m365/spo/commands/list/list-retentionlabel-ensure.js +10 -2
  12. package/dist/m365/spo/commands/listitem/ListItemRetentionLabel.js +3 -0
  13. package/dist/m365/spo/commands/listitem/SiteRetentionLabel.js +3 -0
  14. package/dist/m365/spo/commands/listitem/listitem-record-lock.js +129 -0
  15. package/dist/m365/spo/commands/listitem/listitem-record-unlock.js +129 -0
  16. package/dist/m365/spo/commands/listitem/listitem-retentionlabel-ensure.js +161 -0
  17. package/dist/m365/spo/commands.js +4 -0
  18. package/dist/m365/teams/commands/chat/chat-list.js +29 -7
  19. package/dist/request.js +2 -2
  20. package/docs/docs/cmd/planner/bucket/bucket-add.md +17 -0
  21. package/docs/docs/cmd/planner/bucket/bucket-get.md +17 -0
  22. package/docs/docs/cmd/planner/bucket/bucket-list.md +17 -0
  23. package/docs/docs/cmd/planner/plan/plan-add.md +40 -0
  24. package/docs/docs/cmd/planner/plan/plan-get.md +21 -0
  25. package/docs/docs/cmd/planner/plan/plan-list.md +19 -0
  26. package/docs/docs/cmd/planner/plan/plan-set.md +20 -0
  27. package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-list.md +95 -0
  28. package/docs/docs/cmd/purview/retentionlabel/retentionlabel-get.md +95 -0
  29. package/docs/docs/cmd/spo/file/file-sharinglink-list.md +97 -0
  30. package/docs/docs/cmd/spo/group/group-member-remove.md +24 -6
  31. package/docs/docs/cmd/spo/list/list-retentionlabel-ensure.md +8 -5
  32. package/docs/docs/cmd/spo/listitem/listitem-record-lock.md +52 -0
  33. package/docs/docs/cmd/spo/listitem/listitem-record-unlock.md +52 -0
  34. package/docs/docs/cmd/spo/listitem/listitem-retentionlabel-ensure.md +58 -0
  35. package/docs/docs/cmd/teams/chat/chat-list.md +16 -4
  36. package/npm-shrinkwrap.json +182 -202
  37. package/package.json +12 -11
package/.eslintrc.js CHANGED
@@ -5,11 +5,13 @@ const dictionary = [
5
5
  'activation',
6
6
  'activations',
7
7
  'adaptive',
8
+ 'ai',
8
9
  'app',
9
10
  'apply',
10
11
  'approve',
11
12
  'assets',
12
13
  'bin',
14
+ 'builder',
13
15
  'catalog',
14
16
  'checklist',
15
17
  'client',
@@ -31,6 +33,7 @@ const dictionary = [
31
33
  'home',
32
34
  'hub',
33
35
  'in',
36
+ 'info',
34
37
  'inheritance',
35
38
  'init',
36
39
  'install',
@@ -39,9 +42,11 @@ const dictionary = [
39
42
  'issue',
40
43
  'label',
41
44
  'list',
45
+ 'link',
42
46
  'management',
43
47
  'member',
44
48
  'messaging',
49
+ 'model',
45
50
  'news',
46
51
  'oauth2',
47
52
  'office365',
@@ -60,6 +65,7 @@ const dictionary = [
60
65
  'service',
61
66
  'setting',
62
67
  'settings',
68
+ 'sharing',
63
69
  'side',
64
70
  'site',
65
71
  'status',
@@ -58,6 +58,9 @@ class AadAppRoleAssignmentAddCommand extends GraphCommand_1.default {
58
58
  };
59
59
  try {
60
60
  const servicePrincipalResult = yield request_1.default.get(getServicePrinciplesRequestOptions);
61
+ if (servicePrincipalResult.value.length === 0) {
62
+ return Promise.reject(`The specified service principal doesn't exist`);
63
+ }
61
64
  if (servicePrincipalResult.value.length > 1) {
62
65
  throw 'More than one service principal found. Please use the appId or appObjectId option to make sure the right service principal is specified.';
63
66
  }
@@ -0,0 +1,68 @@
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 _PpAiBuilderModelListCommand_instances, _PpAiBuilderModelListCommand_initTelemetry, _PpAiBuilderModelListCommand_initOptions;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const odata_1 = require("../../../../utils/odata");
19
+ const powerPlatform_1 = require("../../../../utils/powerPlatform");
20
+ const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
21
+ const commands_1 = require("../../commands");
22
+ class PpAiBuilderModelListCommand extends PowerPlatformCommand_1.default {
23
+ get name() {
24
+ return commands_1.default.AIBUILDERMODEL_LIST;
25
+ }
26
+ get description() {
27
+ return 'List available AI builder models in the specified Power Platform environment.';
28
+ }
29
+ defaultProperties() {
30
+ return ['msdyn_name', 'msdyn_aimodelid', 'createdon', 'modifiedon'];
31
+ }
32
+ constructor() {
33
+ super();
34
+ _PpAiBuilderModelListCommand_instances.add(this);
35
+ __classPrivateFieldGet(this, _PpAiBuilderModelListCommand_instances, "m", _PpAiBuilderModelListCommand_initTelemetry).call(this);
36
+ __classPrivateFieldGet(this, _PpAiBuilderModelListCommand_instances, "m", _PpAiBuilderModelListCommand_initOptions).call(this);
37
+ }
38
+ commandAction(logger, args) {
39
+ return __awaiter(this, void 0, void 0, function* () {
40
+ if (this.verbose) {
41
+ logger.logToStderr(`Retrieving available AI Builder models`);
42
+ }
43
+ try {
44
+ const dynamicsApiUrl = yield powerPlatform_1.powerPlatform.getDynamicsInstanceApiUrl(args.options.environment, args.options.asAdmin);
45
+ const aimodels = yield odata_1.odata.getAllItems(`${dynamicsApiUrl}/api/data/v9.0/msdyn_aimodels?$filter=iscustomizable/Value eq true`);
46
+ logger.log(aimodels);
47
+ }
48
+ catch (err) {
49
+ this.handleRejectedODataJsonPromise(err);
50
+ }
51
+ });
52
+ }
53
+ }
54
+ _PpAiBuilderModelListCommand_instances = new WeakSet(), _PpAiBuilderModelListCommand_initTelemetry = function _PpAiBuilderModelListCommand_initTelemetry() {
55
+ this.telemetry.push((args) => {
56
+ Object.assign(this.telemetryProperties, {
57
+ asAdmin: !!args.options.asAdmin
58
+ });
59
+ });
60
+ }, _PpAiBuilderModelListCommand_initOptions = function _PpAiBuilderModelListCommand_initOptions() {
61
+ this.options.unshift({
62
+ option: '-e, --environment <environment>'
63
+ }, {
64
+ option: '--asAdmin'
65
+ });
66
+ };
67
+ module.exports = new PpAiBuilderModelListCommand();
68
+ //# sourceMappingURL=aibuildermodel-list.js.map
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const prefix = 'pp';
4
4
  exports.default = {
5
+ AIBUILDERMODEL_LIST: `${prefix} aibuildermodel list`,
5
6
  CARD_CLONE: `${prefix} card clone`,
6
7
  CARD_GET: `${prefix} card get`,
7
8
  CARD_LIST: `${prefix} card list`,
@@ -0,0 +1,70 @@
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 _PurviewRetentionLabelGetCommand_instances, _PurviewRetentionLabelGetCommand_initOptions, _PurviewRetentionLabelGetCommand_initValidators;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const GraphCommand_1 = require("../../../base/GraphCommand");
19
+ const commands_1 = require("../../commands");
20
+ const request_1 = require("../../../../request");
21
+ const validation_1 = require("../../../../utils/validation");
22
+ class PurviewRetentionLabelGetCommand extends GraphCommand_1.default {
23
+ get name() {
24
+ return commands_1.default.RETENTIONLABEL_GET;
25
+ }
26
+ get description() {
27
+ return 'Retrieve the specified retention label';
28
+ }
29
+ constructor() {
30
+ super();
31
+ _PurviewRetentionLabelGetCommand_instances.add(this);
32
+ __classPrivateFieldGet(this, _PurviewRetentionLabelGetCommand_instances, "m", _PurviewRetentionLabelGetCommand_initOptions).call(this);
33
+ __classPrivateFieldGet(this, _PurviewRetentionLabelGetCommand_instances, "m", _PurviewRetentionLabelGetCommand_initValidators).call(this);
34
+ }
35
+ commandAction(logger, args) {
36
+ return __awaiter(this, void 0, void 0, function* () {
37
+ try {
38
+ if (this.verbose) {
39
+ logger.logToStderr(`Retrieving retention label with id ${args.options.id}`);
40
+ }
41
+ const requestOptions = {
42
+ url: `${this.resource}/beta/security/labels/retentionLabels/${args.options.id}`,
43
+ headers: {
44
+ accept: 'application/json;odata.metadata=none'
45
+ },
46
+ responseType: 'json'
47
+ };
48
+ const res = yield request_1.default.get(requestOptions);
49
+ logger.log(res);
50
+ }
51
+ catch (err) {
52
+ this.handleRejectedODataJsonPromise(err);
53
+ }
54
+ });
55
+ }
56
+ }
57
+ _PurviewRetentionLabelGetCommand_instances = new WeakSet(), _PurviewRetentionLabelGetCommand_initOptions = function _PurviewRetentionLabelGetCommand_initOptions() {
58
+ this.options.unshift({
59
+ option: '-i, --id <id>'
60
+ });
61
+ }, _PurviewRetentionLabelGetCommand_initValidators = function _PurviewRetentionLabelGetCommand_initValidators() {
62
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
63
+ if (!validation_1.validation.isValidGuid(args.options.id)) {
64
+ return `'${args.options.id}' is not a valid GUID.`;
65
+ }
66
+ return true;
67
+ }));
68
+ };
69
+ module.exports = new PurviewRetentionLabelGetCommand();
70
+ //# sourceMappingURL=retentionlabel-get.js.map
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const prefix = 'purview';
4
4
  exports.default = {
5
+ RETENTIONLABEL_GET: `${prefix} retentionlabel get`,
5
6
  RETENTIONLABEL_LIST: `${prefix} retentionlabel list`,
6
7
  RETENTIONLABEL_REMOVE: `${prefix} retentionlabel remove`,
7
8
  RETENTIONLABEL_SET: `${prefix} retentionlabel set`
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=GraphFileDetails.js.map
@@ -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 _SpoFileSharinginfoGetCommand_instances, _SpoFileSharinginfoGetCommand_initTelemetry, _SpoFileSharinginfoGetCommand_initOptions, _SpoFileSharinginfoGetCommand_initValidators, _SpoFileSharinginfoGetCommand_initOptionSets;
16
+ var _SpoFileSharingInfoGetCommand_instances, _SpoFileSharingInfoGetCommand_initTelemetry, _SpoFileSharingInfoGetCommand_initOptions, _SpoFileSharingInfoGetCommand_initValidators, _SpoFileSharingInfoGetCommand_initOptionSets;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
@@ -21,7 +21,7 @@ const validation_1 = require("../../../../utils/validation");
21
21
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
22
  const commands_1 = require("../../commands");
23
23
  const FileSharingPrincipalType_1 = require("./FileSharingPrincipalType");
24
- class SpoFileSharinginfoGetCommand extends SpoCommand_1.default {
24
+ class SpoFileSharingInfoGetCommand extends SpoCommand_1.default {
25
25
  get name() {
26
26
  return commands_1.default.FILE_SHARINGINFO_GET;
27
27
  }
@@ -30,11 +30,11 @@ class SpoFileSharinginfoGetCommand extends SpoCommand_1.default {
30
30
  }
31
31
  constructor() {
32
32
  super();
33
- _SpoFileSharinginfoGetCommand_instances.add(this);
34
- __classPrivateFieldGet(this, _SpoFileSharinginfoGetCommand_instances, "m", _SpoFileSharinginfoGetCommand_initTelemetry).call(this);
35
- __classPrivateFieldGet(this, _SpoFileSharinginfoGetCommand_instances, "m", _SpoFileSharinginfoGetCommand_initOptions).call(this);
36
- __classPrivateFieldGet(this, _SpoFileSharinginfoGetCommand_instances, "m", _SpoFileSharinginfoGetCommand_initValidators).call(this);
37
- __classPrivateFieldGet(this, _SpoFileSharinginfoGetCommand_instances, "m", _SpoFileSharinginfoGetCommand_initOptionSets).call(this);
33
+ _SpoFileSharingInfoGetCommand_instances.add(this);
34
+ __classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initTelemetry).call(this);
35
+ __classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initOptions).call(this);
36
+ __classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initValidators).call(this);
37
+ __classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initOptionSets).call(this);
38
38
  }
39
39
  getExcludedOptionsWithUrls() {
40
40
  return ['fileUrl'];
@@ -113,14 +113,14 @@ class SpoFileSharinginfoGetCommand extends SpoCommand_1.default {
113
113
  }));
114
114
  }
115
115
  }
116
- _SpoFileSharinginfoGetCommand_instances = new WeakSet(), _SpoFileSharinginfoGetCommand_initTelemetry = function _SpoFileSharinginfoGetCommand_initTelemetry() {
116
+ _SpoFileSharingInfoGetCommand_instances = new WeakSet(), _SpoFileSharingInfoGetCommand_initTelemetry = function _SpoFileSharingInfoGetCommand_initTelemetry() {
117
117
  this.telemetry.push((args) => {
118
118
  Object.assign(this.telemetryProperties, {
119
119
  fileId: (!(!args.options.fileId)).toString(),
120
120
  fileUrl: (!(!args.options.fileUrl)).toString()
121
121
  });
122
122
  });
123
- }, _SpoFileSharinginfoGetCommand_initOptions = function _SpoFileSharinginfoGetCommand_initOptions() {
123
+ }, _SpoFileSharingInfoGetCommand_initOptions = function _SpoFileSharingInfoGetCommand_initOptions() {
124
124
  this.options.unshift({
125
125
  option: '-u, --webUrl <webUrl>'
126
126
  }, {
@@ -128,7 +128,7 @@ _SpoFileSharinginfoGetCommand_instances = new WeakSet(), _SpoFileSharinginfoGetC
128
128
  }, {
129
129
  option: '-f, --fileUrl [fileUrl]'
130
130
  });
131
- }, _SpoFileSharinginfoGetCommand_initValidators = function _SpoFileSharinginfoGetCommand_initValidators() {
131
+ }, _SpoFileSharingInfoGetCommand_initValidators = function _SpoFileSharingInfoGetCommand_initValidators() {
132
132
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
133
133
  const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
134
134
  if (isValidSharePointUrl !== true) {
@@ -141,8 +141,8 @@ _SpoFileSharinginfoGetCommand_instances = new WeakSet(), _SpoFileSharinginfoGetC
141
141
  }
142
142
  return true;
143
143
  }));
144
- }, _SpoFileSharinginfoGetCommand_initOptionSets = function _SpoFileSharinginfoGetCommand_initOptionSets() {
144
+ }, _SpoFileSharingInfoGetCommand_initOptionSets = function _SpoFileSharingInfoGetCommand_initOptionSets() {
145
145
  this.optionSets.push({ options: ['fileId', 'fileUrl'] });
146
146
  };
147
- module.exports = new SpoFileSharinginfoGetCommand();
147
+ module.exports = new SpoFileSharingInfoGetCommand();
148
148
  //# sourceMappingURL=file-sharinginfo-get.js.map
@@ -0,0 +1,120 @@
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 _SpoFileSharingLinkListCommand_instances, _SpoFileSharingLinkListCommand_initTelemetry, _SpoFileSharingLinkListCommand_initOptions, _SpoFileSharingLinkListCommand_initValidators, _SpoFileSharingLinkListCommand_initOptionSets;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const request_1 = require("../../../../request");
19
+ const formatting_1 = require("../../../../utils/formatting");
20
+ const odata_1 = require("../../../../utils/odata");
21
+ const validation_1 = require("../../../../utils/validation");
22
+ const SpoCommand_1 = require("../../../base/SpoCommand");
23
+ const commands_1 = require("../../commands");
24
+ class SpoFileSharingLinkListCommand extends SpoCommand_1.default {
25
+ get name() {
26
+ return commands_1.default.FILE_SHARINGLINK_LIST;
27
+ }
28
+ get description() {
29
+ return 'Lists all the sharing links of a specific file';
30
+ }
31
+ defaultProperties() {
32
+ return ['id', 'roles', 'link'];
33
+ }
34
+ constructor() {
35
+ super();
36
+ _SpoFileSharingLinkListCommand_instances.add(this);
37
+ __classPrivateFieldGet(this, _SpoFileSharingLinkListCommand_instances, "m", _SpoFileSharingLinkListCommand_initTelemetry).call(this);
38
+ __classPrivateFieldGet(this, _SpoFileSharingLinkListCommand_instances, "m", _SpoFileSharingLinkListCommand_initOptions).call(this);
39
+ __classPrivateFieldGet(this, _SpoFileSharingLinkListCommand_instances, "m", _SpoFileSharingLinkListCommand_initValidators).call(this);
40
+ __classPrivateFieldGet(this, _SpoFileSharingLinkListCommand_instances, "m", _SpoFileSharingLinkListCommand_initOptionSets).call(this);
41
+ }
42
+ commandAction(logger, args) {
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ if (this.verbose) {
45
+ logger.logToStderr(`Retrieving sharing links for file ${args.options.fileId || args.options.fileUrl}...`);
46
+ }
47
+ try {
48
+ const fileDetails = yield this.getFileDetails(args.options.webUrl, args.options.fileId, args.options.fileUrl);
49
+ const sharingLinks = yield odata_1.odata.getAllItems(`https://graph.microsoft.com/v1.0/sites/${fileDetails.SiteId}/drives/${fileDetails.VroomDriveID}/items/${fileDetails.VroomItemID}/permissions?$filter=Link ne null`);
50
+ if (!args.options.output || args.options.output === 'json' || args.options.output === 'md') {
51
+ logger.log(sharingLinks);
52
+ }
53
+ else {
54
+ //converted to text friendly output
55
+ logger.log(sharingLinks.map(i => {
56
+ return {
57
+ id: i.id,
58
+ roles: i.roles.join(','),
59
+ link: i.link.webUrl
60
+ };
61
+ }));
62
+ }
63
+ }
64
+ catch (err) {
65
+ this.handleRejectedODataJsonPromise(err);
66
+ }
67
+ });
68
+ }
69
+ getFileDetails(webUrl, fileId, fileUrl) {
70
+ return __awaiter(this, void 0, void 0, function* () {
71
+ let requestUrl = `${webUrl}/_api/web/`;
72
+ if (fileId) {
73
+ requestUrl += `GetFileById('${fileId}')`;
74
+ }
75
+ else if (fileUrl) {
76
+ requestUrl += `GetFileByServerRelativePath(decodedUrl='${formatting_1.formatting.encodeQueryParameter(fileUrl)}')`;
77
+ }
78
+ const requestOptions = {
79
+ url: requestUrl += '?$select=SiteId,VroomItemId,VroomDriveId',
80
+ headers: {
81
+ accept: 'application/json;odata=nometadata'
82
+ },
83
+ responseType: 'json'
84
+ };
85
+ const res = yield request_1.default.get(requestOptions);
86
+ return res;
87
+ });
88
+ }
89
+ }
90
+ _SpoFileSharingLinkListCommand_instances = new WeakSet(), _SpoFileSharingLinkListCommand_initTelemetry = function _SpoFileSharingLinkListCommand_initTelemetry() {
91
+ this.telemetry.push((args) => {
92
+ Object.assign(this.telemetryProperties, {
93
+ fileId: typeof args.options.fileId !== 'undefined',
94
+ fileUrl: typeof args.options.fileUrl !== 'undefined'
95
+ });
96
+ });
97
+ }, _SpoFileSharingLinkListCommand_initOptions = function _SpoFileSharingLinkListCommand_initOptions() {
98
+ this.options.unshift({
99
+ option: '-u, --webUrl <webUrl>'
100
+ }, {
101
+ option: '-i, --fileId [fileId]'
102
+ }, {
103
+ option: '-f, --fileUrl [fileUrl]'
104
+ });
105
+ }, _SpoFileSharingLinkListCommand_initValidators = function _SpoFileSharingLinkListCommand_initValidators() {
106
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
107
+ const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
108
+ if (isValidSharePointUrl !== true) {
109
+ return isValidSharePointUrl;
110
+ }
111
+ if (args.options.fileId && !validation_1.validation.isValidGuid(args.options.fileId)) {
112
+ return `${args.options.fileId} is not a valid GUID`;
113
+ }
114
+ return true;
115
+ }));
116
+ }, _SpoFileSharingLinkListCommand_initOptionSets = function _SpoFileSharingLinkListCommand_initOptionSets() {
117
+ this.optionSets.push({ options: ['fileId', 'fileUrl'] });
118
+ };
119
+ module.exports = new SpoFileSharingLinkListCommand();
120
+ //# sourceMappingURL=file-sharinglink-list.js.map
@@ -22,6 +22,7 @@ const validation_1 = require("../../../../utils/validation");
22
22
  const AadUserGetCommand = require("../../../aad/commands/user/user-get");
23
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
24
24
  const commands_1 = require("../../commands");
25
+ const SpoGroupMemberListCommand = require("./group-member-list");
25
26
  class SpoGroupMemberRemoveCommand extends SpoCommand_1.default {
26
27
  get name() {
27
28
  return commands_1.default.GROUP_MEMBER_REMOVE;
@@ -58,54 +59,89 @@ class SpoGroupMemberRemoveCommand extends SpoCommand_1.default {
58
59
  }
59
60
  commandAction(logger, args) {
60
61
  return __awaiter(this, void 0, void 0, function* () {
61
- const removeUserfromSPGroup = () => __awaiter(this, void 0, void 0, function* () {
62
- if (this.verbose) {
63
- logger.logToStderr(`Removing User ${args.options.userName || args.options.email || args.options.userId} from Group: ${args.options.groupId ? args.options.groupId : args.options.groupName}`);
64
- }
65
- let requestUrl = `${args.options.webUrl}/_api/web/sitegroups/${args.options.groupId
66
- ? `GetById('${args.options.groupId}')`
67
- : `GetByName('${formatting_1.formatting.encodeQueryParameter(args.options.groupName)}')`}`;
68
- if (args.options.userId) {
69
- requestUrl += `/users/removeById(${args.options.userId})`;
70
- }
71
- else {
72
- const userName = yield this.getUserName(logger, args);
73
- const loginName = `i:0#.f|membership|${userName}`;
74
- requestUrl += `/users/removeByLoginName(@LoginName)?@LoginName='${formatting_1.formatting.encodeQueryParameter(loginName)}'`;
75
- }
76
- const requestOptions = {
77
- url: requestUrl,
78
- headers: {
79
- 'accept': 'application/json;odata=nometadata'
80
- },
81
- responseType: 'json'
82
- };
83
- try {
84
- yield request_1.default.post(requestOptions);
85
- }
86
- catch (err) {
87
- this.handleRejectedODataJsonPromise(err);
88
- }
89
- });
90
62
  if (args.options.confirm) {
91
63
  if (this.debug) {
92
64
  logger.logToStderr('Confirmation bypassed by entering confirm option. Removing the user from SharePoint Group...');
93
65
  }
94
- yield removeUserfromSPGroup();
66
+ yield this.removeUserfromSPGroup(logger, args);
95
67
  }
96
68
  else {
97
69
  const result = yield Cli_1.Cli.prompt({
98
70
  type: 'confirm',
99
71
  name: 'continue',
100
72
  default: false,
101
- message: `Are you sure you want to remove user ${args.options.userName || args.options.userId || args.options.email} from the SharePoint group?`
73
+ message: `Are you sure you want to remove user ${args.options.userName || args.options.userId || args.options.email || args.options.aadGroupId || args.options.aadGroupName} from the SharePoint group?`
102
74
  });
103
75
  if (result.continue) {
104
- yield removeUserfromSPGroup();
76
+ yield this.removeUserfromSPGroup(logger, args);
105
77
  }
106
78
  }
107
79
  });
108
80
  }
81
+ removeUserfromSPGroup(logger, args) {
82
+ return __awaiter(this, void 0, void 0, function* () {
83
+ if (this.verbose) {
84
+ logger.logToStderr(`Removing User ${args.options.userName || args.options.email || args.options.userId || args.options.aadGroupId || args.options.aadGroupName} from Group: ${args.options.groupId || args.options.groupName}`);
85
+ }
86
+ let requestUrl = `${args.options.webUrl}/_api/web/sitegroups/${args.options.groupId
87
+ ? `GetById('${args.options.groupId}')`
88
+ : `GetByName('${formatting_1.formatting.encodeQueryParameter(args.options.groupName)}')`}`;
89
+ if (args.options.userId) {
90
+ requestUrl += `/users/removeById(${args.options.userId})`;
91
+ }
92
+ else if (args.options.userName || args.options.email) {
93
+ const userName = yield this.getUserName(logger, args);
94
+ const loginName = `i:0#.f|membership|${userName}`;
95
+ requestUrl += `/users/removeByLoginName(@LoginName)?@LoginName='${formatting_1.formatting.encodeQueryParameter(loginName)}'`;
96
+ }
97
+ else {
98
+ const aadGroupId = yield this.getGroupId(args);
99
+ requestUrl += `/users/RemoveById(${aadGroupId})`;
100
+ }
101
+ const requestOptions = {
102
+ url: requestUrl,
103
+ headers: {
104
+ 'accept': 'application/json;odata=nometadata'
105
+ },
106
+ responseType: 'json'
107
+ };
108
+ try {
109
+ yield request_1.default.post(requestOptions);
110
+ }
111
+ catch (err) {
112
+ this.handleRejectedODataJsonPromise(err);
113
+ }
114
+ });
115
+ }
116
+ getGroupId(args) {
117
+ return __awaiter(this, void 0, void 0, function* () {
118
+ const options = {
119
+ webUrl: args.options.webUrl,
120
+ output: 'json',
121
+ debug: this.debug,
122
+ verbose: this.verbose
123
+ };
124
+ if (args.options.groupId) {
125
+ options.groupId = args.options.groupId;
126
+ }
127
+ else {
128
+ options.groupName = args.options.groupName;
129
+ }
130
+ const output = yield Cli_1.Cli.executeCommandWithOutput(SpoGroupMemberListCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) });
131
+ const getGroupMemberListOutput = JSON.parse(output.stdout);
132
+ let foundgroups;
133
+ if (args.options.aadGroupId) {
134
+ foundgroups = getGroupMemberListOutput.filter((x) => { return x.LoginName.indexOf(args.options.aadGroupId) > -1 && (x.LoginName.indexOf("c:0o.c|federateddirectoryclaimprovider|") === 0 || x.LoginName.indexOf("c:0t.c|tenant|") === 0); });
135
+ }
136
+ else {
137
+ foundgroups = getGroupMemberListOutput.filter((x) => { return x.Title === args.options.aadGroupName && (x.LoginName.indexOf("c:0o.c|federateddirectoryclaimprovider|") === 0 || x.LoginName.indexOf("c:0t.c|tenant|") === 0); });
138
+ }
139
+ if (foundgroups.length === 0) {
140
+ throw `The Azure AD group ${args.options.aadGroupId || args.options.aadGroupName} is not found in SharePoint group ${args.options.groupId || args.options.groupName}`;
141
+ }
142
+ return foundgroups[0].Id;
143
+ });
144
+ }
109
145
  }
110
146
  _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCommand_initTelemetry = function _SpoGroupMemberRemoveCommand_initTelemetry() {
111
147
  this.telemetry.push((args) => {
@@ -115,6 +151,8 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
115
151
  userName: (!(!args.options.userName)).toString(),
116
152
  email: (!(!args.options.email)).toString(),
117
153
  userId: (!(!args.options.userId)).toString(),
154
+ aadGroupId: (!(!args.options.groupId)).toString(),
155
+ aadGroupName: (!(!args.options.groupName)).toString(),
118
156
  confirm: (!(!args.options.confirm)).toString()
119
157
  });
120
158
  });
@@ -131,6 +169,10 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
131
169
  option: '--email [email]'
132
170
  }, {
133
171
  option: '--userId [userId]'
172
+ }, {
173
+ option: '--aadGroupId [aadGroupId]'
174
+ }, {
175
+ option: '--aadGroupName [aadGroupName]'
134
176
  }, {
135
177
  option: '--confirm'
136
178
  });
@@ -148,10 +190,13 @@ _SpoGroupMemberRemoveCommand_instances = new WeakSet(), _SpoGroupMemberRemoveCom
148
190
  if (args.options.email && !validation_1.validation.isValidUserPrincipalName(args.options.email)) {
149
191
  return `${args.options.email} is not a valid email`;
150
192
  }
193
+ if (args.options.aadGroupId && !validation_1.validation.isValidGuid(args.options.aadGroupId)) {
194
+ return `${args.options.aadGroupId} is not a valid GUID`;
195
+ }
151
196
  return validation_1.validation.isValidSharePointUrl(args.options.webUrl);
152
197
  }));
153
198
  }, _SpoGroupMemberRemoveCommand_initOptionSets = function _SpoGroupMemberRemoveCommand_initOptionSets() {
154
- this.optionSets.push({ options: ['groupName', 'groupId'] }, { options: ['userName', 'email', 'userId'] });
199
+ this.optionSets.push({ options: ['groupName', 'groupId'] }, { options: ['userName', 'email', 'userId', 'aadGroupId', 'aadGroupName'] });
155
200
  };
156
201
  module.exports = new SpoGroupMemberRemoveCommand();
157
202
  //# sourceMappingURL=group-member-remove.js.map
@@ -42,6 +42,10 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
42
42
  commandAction(logger, args) {
43
43
  return __awaiter(this, void 0, void 0, function* () {
44
44
  this.showDeprecationWarning(logger, commands_1.default.LIST_LABEL_SET, commands_1.default.LIST_RETENTIONLABEL_ENSURE);
45
+ if (args.options.label) {
46
+ args.options.name = args.options.label;
47
+ this.warn(logger, `Option 'label' is deprecated. Please use 'name' instead`);
48
+ }
45
49
  if (args.options.blockDelete) {
46
50
  this.warn(logger, `Option 'blockDelete' is deprecated.`);
47
51
  }
@@ -81,7 +85,7 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
81
85
  },
82
86
  data: {
83
87
  listUrl: listAbsoluteUrl,
84
- complianceTagValue: args.options.label,
88
+ complianceTagValue: args.options.name,
85
89
  blockDelete: args.options.blockDelete || false,
86
90
  blockEdit: args.options.blockEdit || false,
87
91
  syncToItems: args.options.syncToItems || false
@@ -99,6 +103,8 @@ class SpoListRetentionLabelEnsureCommand extends SpoCommand_1.default {
99
103
  _SpoListRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoListRetentionLabelEnsureCommand_initTelemetry = function _SpoListRetentionLabelEnsureCommand_initTelemetry() {
100
104
  this.telemetry.push((args) => {
101
105
  Object.assign(this.telemetryProperties, {
106
+ name: (!(!args.options.name)).toString(),
107
+ label: (!(!args.options.label)).toString(),
102
108
  listId: (!(!args.options.listId)).toString(),
103
109
  listTitle: (!(!args.options.listTitle)).toString(),
104
110
  listUrl: (!(!args.options.listUrl)).toString(),
@@ -111,7 +117,9 @@ _SpoListRetentionLabelEnsureCommand_instances = new WeakSet(), _SpoListRetention
111
117
  this.options.unshift({
112
118
  option: '-u, --webUrl <webUrl>'
113
119
  }, {
114
- option: '--label <label>'
120
+ option: '--name [name]'
121
+ }, {
122
+ option: '--label [label]'
115
123
  }, {
116
124
  option: '-t, --listTitle [listTitle]'
117
125
  }, {
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=ListItemRetentionLabel.js.map
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=SiteRetentionLabel.js.map