@pnp/cli-microsoft365 6.0.0-beta.42305df → 6.0.0-beta.49b3c0a

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