@pnp/cli-microsoft365 5.3.0 → 5.4.0-beta.1107211

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 (135) hide show
  1. package/.devcontainer/Dockerfile +1 -1
  2. package/.eslintrc.js +1 -0
  3. package/dist/m365/aad/commands/app/app-set.js +4 -1
  4. package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +4 -19
  5. package/dist/m365/aad/commands/o365group/o365group-get.js +3 -9
  6. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-remove.js +129 -0
  7. package/dist/m365/aad/commands.js +1 -0
  8. package/dist/m365/base/PlannerCommand.js +10 -0
  9. package/dist/m365/flow/commands/flow-export.js +3 -3
  10. package/dist/m365/planner/commands/bucket/bucket-add.js +4 -16
  11. package/dist/m365/planner/commands/bucket/bucket-get.js +5 -19
  12. package/dist/m365/planner/commands/bucket/bucket-list.js +4 -17
  13. package/dist/m365/planner/commands/bucket/bucket-remove.js +6 -20
  14. package/dist/m365/planner/commands/bucket/bucket-set.js +5 -19
  15. package/dist/m365/planner/commands/plan/plan-add.js +4 -16
  16. package/dist/m365/planner/commands/plan/plan-details-get.js +4 -19
  17. package/dist/m365/planner/commands/plan/plan-get.js +4 -17
  18. package/dist/m365/planner/commands/plan/plan-list.js +4 -17
  19. package/dist/m365/planner/commands/task/task-add.js +60 -23
  20. package/dist/m365/planner/commands/task/task-checklistitem-add.js +89 -0
  21. package/dist/m365/planner/commands/task/{task-details-get.js → task-checklistitem-list.js} +21 -13
  22. package/dist/m365/planner/commands/task/task-checklistitem-remove.js +85 -0
  23. package/dist/m365/planner/commands/task/task-get.js +61 -34
  24. package/dist/m365/planner/commands/task/task-list.js +4 -16
  25. package/dist/m365/planner/commands/task/task-reference-remove.js +125 -0
  26. package/dist/m365/planner/commands/task/task-remove.js +201 -0
  27. package/dist/m365/planner/commands/task/task-set.js +21 -17
  28. package/dist/m365/planner/commands/tenant/tenant-settings-list.js +33 -0
  29. package/dist/m365/planner/commands.js +8 -2
  30. package/dist/m365/planner/taskPriority.js +27 -0
  31. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002009_DEVDEP_microsoft_sp_tslint_rules.js +2 -2
  32. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002018_DEVDEP_microsoft_rush_stack_compiler_3_9.js +2 -2
  33. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5.js +17 -0
  34. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002021_DEVDEP_rushstack_eslint_config.js +14 -0
  35. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002022_DEVDEP_microsoft_eslint_plugin_spfx.js +14 -0
  36. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002023_DEVDEP_microsoft_eslint_config_spfx.js +14 -0
  37. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002024_DEVDEP_eslint.js +14 -0
  38. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002025_DEVDEP_eslint_plugin_react_hooks.js +18 -0
  39. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN015008_FILE_eslintrc_js.js +14 -0
  40. package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.15.0-beta.6.js → upgrade-1.15.0.js} +50 -26
  41. package/dist/m365/spfx/commands/project/project-upgrade.js +13 -15
  42. package/dist/m365/spo/commands/contenttype/contenttype-add.js +1 -1
  43. package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +1 -1
  44. package/dist/m365/spo/commands/contenttype/contenttype-get.js +1 -1
  45. package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +3 -3
  46. package/dist/m365/spo/commands/eventreceiver/eventreceiver-list.js +102 -0
  47. package/dist/m365/spo/commands/field/field-add.js +1 -1
  48. package/dist/m365/spo/commands/field/field-get.js +5 -5
  49. package/dist/m365/spo/commands/field/field-list.js +3 -3
  50. package/dist/m365/spo/commands/field/field-remove.js +5 -5
  51. package/dist/m365/spo/commands/file/file-sharinginfo-get.js +1 -1
  52. package/dist/m365/spo/commands/hubsite/hubsite-list.js +1 -1
  53. package/dist/m365/spo/commands/list/ListPrincipalType.js +13 -0
  54. package/dist/m365/spo/commands/list/list-contenttype-add.js +3 -3
  55. package/dist/m365/spo/commands/list/list-contenttype-default-set.js +2 -2
  56. package/dist/m365/spo/commands/list/list-contenttype-list.js +3 -3
  57. package/dist/m365/spo/commands/list/list-contenttype-remove.js +3 -3
  58. package/dist/m365/spo/commands/list/list-get.js +8 -2
  59. package/dist/m365/spo/commands/list/list-label-get.js +3 -3
  60. package/dist/m365/spo/commands/list/list-label-set.js +2 -2
  61. package/dist/m365/spo/commands/list/list-list.js +10 -1
  62. package/dist/m365/spo/commands/list/list-remove.js +2 -2
  63. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +2 -2
  64. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +2 -2
  65. package/dist/m365/spo/commands/list/list-sitescript-get.js +3 -3
  66. package/dist/m365/spo/commands/list/list-view-add.js +6 -3
  67. package/dist/m365/spo/commands/list/list-view-field-add.js +2 -2
  68. package/dist/m365/spo/commands/list/list-view-field-remove.js +2 -2
  69. package/dist/m365/spo/commands/list/list-view-field-set.js +2 -2
  70. package/dist/m365/spo/commands/list/list-view-get.js +4 -4
  71. package/dist/m365/spo/commands/list/list-view-list.js +3 -3
  72. package/dist/m365/spo/commands/list/list-view-remove.js +3 -3
  73. package/dist/m365/spo/commands/list/list-view-set.js +3 -3
  74. package/dist/m365/spo/commands/list/list-webhook-add.js +3 -3
  75. package/dist/m365/spo/commands/list/list-webhook-get.js +3 -3
  76. package/dist/m365/spo/commands/list/list-webhook-list.js +5 -5
  77. package/dist/m365/spo/commands/list/list-webhook-remove.js +4 -4
  78. package/dist/m365/spo/commands/list/list-webhook-set.js +3 -3
  79. package/dist/m365/spo/commands/listitem/listitem-add.js +2 -2
  80. package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +2 -2
  81. package/dist/m365/spo/commands/listitem/listitem-get.js +2 -2
  82. package/dist/m365/spo/commands/listitem/listitem-isrecord.js +2 -2
  83. package/dist/m365/spo/commands/listitem/listitem-list.js +31 -11
  84. package/dist/m365/spo/commands/listitem/listitem-record-declare.js +2 -2
  85. package/dist/m365/spo/commands/listitem/listitem-record-undeclare.js +2 -2
  86. package/dist/m365/spo/commands/listitem/listitem-remove.js +2 -2
  87. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +2 -2
  88. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +2 -2
  89. package/dist/m365/spo/commands/listitem/listitem-set.js +2 -2
  90. package/dist/m365/spo/commands/roledefinition/roledefinition-remove.js +82 -0
  91. package/dist/m365/spo/commands/site/site-remove.js +23 -37
  92. package/dist/m365/spo/commands.js +2 -0
  93. package/dist/m365/teams/commands/app/app-list.js +6 -20
  94. package/dist/m365/teams/commands/channel/channel-get.js +6 -19
  95. package/dist/m365/teams/commands/channel/channel-list.js +6 -18
  96. package/dist/m365/teams/commands/channel/channel-member-add.js +7 -18
  97. package/dist/m365/teams/commands/channel/channel-member-list.js +6 -19
  98. package/dist/m365/teams/commands/channel/channel-member-remove.js +6 -19
  99. package/dist/m365/teams/commands/channel/channel-member-set.js +6 -19
  100. package/dist/m365/teams/commands/tab/tab-get.js +6 -19
  101. package/dist/m365/teams/commands/team/team-add.js +2 -7
  102. package/dist/m365/teams/commands/team/team-get.js +6 -19
  103. package/dist/utils/aadGroup.js +57 -0
  104. package/dist/utils/index.js +2 -0
  105. package/dist/utils/validation.js +12 -2
  106. package/docs/docs/cmd/aad/app/app-set.md +1 -1
  107. package/docs/docs/cmd/aad/o365group/o365group-recyclebinitem-remove.md +45 -0
  108. package/docs/docs/cmd/file/file-list.md +4 -4
  109. package/docs/docs/cmd/planner/bucket/bucket-get.md +1 -1
  110. package/docs/docs/cmd/planner/bucket/bucket-remove.md +2 -2
  111. package/docs/docs/cmd/planner/bucket/bucket-set.md +5 -5
  112. package/docs/docs/cmd/planner/plan/plan-details-get.md +2 -2
  113. package/docs/docs/cmd/planner/plan/plan-get.md +4 -4
  114. package/docs/docs/cmd/planner/task/task-add.md +40 -4
  115. package/docs/docs/cmd/planner/task/task-checklistitem-add.md +36 -0
  116. package/docs/docs/cmd/planner/task/task-checklistitem-list.md +24 -0
  117. package/docs/docs/cmd/planner/task/task-checklistitem-remove.md +36 -0
  118. package/docs/docs/cmd/planner/task/task-get.md +7 -9
  119. package/docs/docs/cmd/planner/task/task-list.md +2 -2
  120. package/docs/docs/cmd/planner/task/task-reference-remove.md +39 -0
  121. package/docs/docs/cmd/planner/task/task-remove.md +78 -0
  122. package/docs/docs/cmd/planner/task/task-set.md +13 -3
  123. package/docs/docs/cmd/planner/tenant/tenant-settings-list.md +28 -0
  124. package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
  125. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-list.md +64 -0
  126. package/docs/docs/cmd/spo/file/file-checkout.md +1 -1
  127. package/docs/docs/cmd/spo/hubsite/hubsite-list.md +1 -4
  128. package/docs/docs/cmd/spo/list/list-list.md +3 -0
  129. package/docs/docs/cmd/spo/list/list-view-add.md +13 -4
  130. package/docs/docs/cmd/spo/listitem/listitem-list.md +16 -10
  131. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +2 -2
  132. package/docs/docs/cmd/spo/roledefinition/roledefinition-remove.md +36 -0
  133. package/npm-shrinkwrap.json +257 -1104
  134. package/package.json +25 -21
  135. package/docs/docs/cmd/planner/task/task-details-get.md +0 -24
@@ -0,0 +1,125 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const cli_1 = require("../../../../cli");
4
+ const request_1 = require("../../../../request");
5
+ const utils_1 = require("../../../../utils");
6
+ const GraphCommand_1 = require("../../../base/GraphCommand");
7
+ const commands_1 = require("../../commands");
8
+ class PlannerTaskReferenceRemoveCommand extends GraphCommand_1.default {
9
+ get name() {
10
+ return commands_1.default.TASK_REFERENCE_REMOVE;
11
+ }
12
+ get description() {
13
+ return 'Removes the reference from the Planner task';
14
+ }
15
+ getTelemetryProperties(args) {
16
+ const telemetryProps = super.getTelemetryProperties(args);
17
+ telemetryProps.url = typeof args.options.url !== 'undefined';
18
+ telemetryProps.alias = typeof args.options.alias !== 'undefined';
19
+ telemetryProps.confirm = (!(!args.options.confirm)).toString();
20
+ return telemetryProps;
21
+ }
22
+ commandAction(logger, args, cb) {
23
+ if (args.options.confirm) {
24
+ this.removeReference(logger, args, cb);
25
+ }
26
+ else {
27
+ cli_1.Cli.prompt({
28
+ type: 'confirm',
29
+ name: 'continue',
30
+ default: false,
31
+ message: `Are you sure you want to remove the reference from the Planner task?`
32
+ }, (result) => {
33
+ if (!result.continue) {
34
+ cb();
35
+ }
36
+ else {
37
+ this.removeReference(logger, args, cb);
38
+ }
39
+ });
40
+ }
41
+ }
42
+ removeReference(logger, args, cb) {
43
+ this
44
+ .getTaskDetailsEtagAndUrl(args.options)
45
+ .then(({ etag, url }) => {
46
+ const requestOptionsTaskDetails = {
47
+ url: `${this.resource}/v1.0/planner/tasks/${args.options.taskId}/details`,
48
+ headers: {
49
+ 'accept': 'application/json;odata.metadata=none',
50
+ 'If-Match': etag,
51
+ 'Prefer': 'return=representation'
52
+ },
53
+ responseType: 'json',
54
+ data: {
55
+ references: {
56
+ [utils_1.formatting.openTypesEncoder(url)]: null
57
+ }
58
+ }
59
+ };
60
+ return request_1.default.patch(requestOptionsTaskDetails);
61
+ })
62
+ .then(() => {
63
+ cb();
64
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
65
+ }
66
+ getTaskDetailsEtagAndUrl(options) {
67
+ const requestOptions = {
68
+ url: `${this.resource}/v1.0/planner/tasks/${encodeURIComponent(options.taskId)}/details`,
69
+ headers: {
70
+ accept: 'application/json'
71
+ },
72
+ responseType: 'json'
73
+ };
74
+ let url = options.url;
75
+ return request_1.default
76
+ .get(requestOptions)
77
+ .then((response) => {
78
+ const etag = response ? response['@odata.etag'] : undefined;
79
+ if (!etag) {
80
+ return Promise.reject(`Error fetching task details`);
81
+ }
82
+ if (options.alias) {
83
+ const alias = options.alias;
84
+ const urls = [];
85
+ Object.entries(response.references).forEach((ref) => {
86
+ var _a;
87
+ if (((_a = ref[1].alias) === null || _a === void 0 ? void 0 : _a.toLocaleLowerCase()) === alias.toLocaleLowerCase()) {
88
+ urls.push(decodeURIComponent(ref[0]));
89
+ }
90
+ });
91
+ if (!urls.length) {
92
+ return Promise.reject(`The specified reference with alias ${options.alias} does not exist`);
93
+ }
94
+ if (urls.length > 1) {
95
+ return Promise.reject(`Multiple references with alias ${options.alias} found. Pass one of the following urls within the "--url" option : ${urls}`);
96
+ }
97
+ url = urls[0];
98
+ }
99
+ return Promise.resolve({ etag, url });
100
+ });
101
+ }
102
+ options() {
103
+ const options = [
104
+ { option: '-u, --url [url]' },
105
+ { option: '--alias [alias]' },
106
+ { option: '-i, --taskId <taskId>' },
107
+ { option: '--confirm' }
108
+ ];
109
+ const parentOptions = super.options();
110
+ return options.concat(parentOptions);
111
+ }
112
+ optionSets() {
113
+ return [
114
+ ['url', 'alias']
115
+ ];
116
+ }
117
+ validate(args) {
118
+ if (args.options.url && args.options.url.indexOf('https://') !== 0 && args.options.url.indexOf('http://') !== 0) {
119
+ return 'The url option should contain a valid URL. A valid URL starts with http(s)://';
120
+ }
121
+ return true;
122
+ }
123
+ }
124
+ module.exports = new PlannerTaskReferenceRemoveCommand();
125
+ //# sourceMappingURL=task-reference-remove.js.map
@@ -0,0 +1,201 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const os = require("os");
4
+ const cli_1 = require("../../../../cli");
5
+ const request_1 = require("../../../../request");
6
+ const utils_1 = require("../../../../utils");
7
+ const planner_1 = require("../../../../utils/planner");
8
+ const GraphCommand_1 = require("../../../base/GraphCommand");
9
+ const commands_1 = require("../../commands");
10
+ class PlannerTaskRemoveCommand extends GraphCommand_1.default {
11
+ get name() {
12
+ return commands_1.default.TASK_REMOVE;
13
+ }
14
+ get description() {
15
+ return 'Removes the Microsoft Planner task from a plan';
16
+ }
17
+ commandAction(logger, args, cb) {
18
+ const removeTask = () => {
19
+ this
20
+ .getTask(args.options)
21
+ .then(task => {
22
+ const requestOptions = {
23
+ url: `${this.resource}/v1.0/planner/tasks/${task.id}`,
24
+ headers: {
25
+ accept: 'application/json;odata.metadata=none',
26
+ 'if-match': task['@odata.etag']
27
+ },
28
+ responseType: 'json'
29
+ };
30
+ return request_1.default.delete(requestOptions);
31
+ })
32
+ .then(_ => cb(), (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
33
+ };
34
+ if (args.options.confirm) {
35
+ removeTask();
36
+ }
37
+ else {
38
+ cli_1.Cli.prompt({
39
+ type: 'confirm',
40
+ name: 'continue',
41
+ default: false,
42
+ message: `Are you sure you want to remove the task ${args.options.id || args.options.title}?`
43
+ }, (result) => {
44
+ if (!result.continue) {
45
+ cb();
46
+ }
47
+ else {
48
+ removeTask();
49
+ }
50
+ });
51
+ }
52
+ }
53
+ getTask(options) {
54
+ const { id, title } = options;
55
+ if (id) {
56
+ const requestOptions = {
57
+ url: `${this.resource}/v1.0/planner/tasks/${id}`,
58
+ headers: {
59
+ accept: 'application/json'
60
+ },
61
+ responseType: 'json'
62
+ };
63
+ return request_1.default.get(requestOptions);
64
+ }
65
+ return this
66
+ .getBucketId(options)
67
+ .then(bucketId => {
68
+ // $filter is not working on the buckets/{bucketId}/tasks endpoint, hence it is not being used.
69
+ return utils_1.odata.getAllItems(`${this.resource}/v1.0/planner/buckets/${bucketId}/tasks?$select=title,id`, 'minimal');
70
+ })
71
+ .then(tasks => {
72
+ const filteredtasks = tasks.filter(b => title.toLocaleLowerCase() === b.title.toLocaleLowerCase());
73
+ if (filteredtasks.length === 0) {
74
+ return Promise.reject(`The specified task ${title} does not exist`);
75
+ }
76
+ if (filteredtasks.length > 1) {
77
+ return Promise.reject(`Multiple tasks with title ${title} found: Please disambiguate: ${os.EOL}${filteredtasks.map(f => `- ${f.id}`).join(os.EOL)}`);
78
+ }
79
+ return Promise.resolve(filteredtasks[0]);
80
+ });
81
+ }
82
+ getBucketId(options) {
83
+ const { bucketId, bucketName } = options;
84
+ if (bucketId) {
85
+ return Promise.resolve(bucketId);
86
+ }
87
+ return this
88
+ .getPlanId(options)
89
+ .then(planId => {
90
+ const requestOptions = {
91
+ url: `${this.resource}/v1.0/planner/plans/${planId}/buckets?$select=id,name`,
92
+ headers: {
93
+ accept: 'application/json;odata.metadata=none'
94
+ },
95
+ responseType: 'json'
96
+ };
97
+ return request_1.default.get(requestOptions);
98
+ })
99
+ .then((buckets) => {
100
+ const filteredBuckets = buckets.value.filter(b => bucketName.toLocaleLowerCase() === b.name.toLocaleLowerCase());
101
+ if (filteredBuckets.length === 0) {
102
+ return Promise.reject(`The specified bucket ${bucketName} does not exist`);
103
+ }
104
+ if (filteredBuckets.length > 1) {
105
+ return Promise.reject(`Multiple buckets with name ${bucketName} found: Please disambiguate:${os.EOL}${filteredBuckets.map(f => `- ${f.id}`).join(os.EOL)}`);
106
+ }
107
+ return Promise.resolve(filteredBuckets[0].id);
108
+ });
109
+ }
110
+ getPlanId(options) {
111
+ const { planId, planTitle } = options;
112
+ if (planId) {
113
+ return Promise.resolve(planId);
114
+ }
115
+ return this
116
+ .getGroupId(options)
117
+ .then(groupId => planner_1.planner.getPlanByName(planTitle, groupId))
118
+ .then(plan => plan.id);
119
+ }
120
+ getGroupId(options) {
121
+ const { ownerGroupId, ownerGroupName } = options;
122
+ if (ownerGroupId) {
123
+ return Promise.resolve(ownerGroupId);
124
+ }
125
+ const requestOptions = {
126
+ url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(ownerGroupName)}'`,
127
+ headers: {
128
+ accept: 'application/json;odata.metadata=none'
129
+ },
130
+ responseType: 'json'
131
+ };
132
+ return request_1.default
133
+ .get(requestOptions)
134
+ .then(response => {
135
+ if (response.value.length === 0) {
136
+ return Promise.reject(`The specified owner group ${ownerGroupName} does not exist`);
137
+ }
138
+ if (response.value.length > 1) {
139
+ return Promise.reject(`Multiple owner groups with name ${ownerGroupName} found: ${response.value.map(x => x.id)}`);
140
+ }
141
+ return Promise.resolve(response.value[0].id);
142
+ });
143
+ }
144
+ options() {
145
+ const options = [
146
+ { option: '-i, --id [id]' },
147
+ { option: '-t, --title [title]' },
148
+ { option: '--bucketId [bucketId]' },
149
+ { option: '--bucketName [bucketName]' },
150
+ { option: '--planId [planId]' },
151
+ { option: '--planTitle [planTitle]' },
152
+ { option: '--ownerGroupId [ownerGroupId]' },
153
+ { option: '--ownerGroupName [ownerGroupName]' },
154
+ { option: '--confirm' }
155
+ ];
156
+ const parentOptions = super.options();
157
+ return options.concat(parentOptions);
158
+ }
159
+ optionSets() {
160
+ return [
161
+ ['id', 'title']
162
+ ];
163
+ }
164
+ validate(args) {
165
+ if (args.options.id) {
166
+ if (args.options.bucketId || args.options.bucketName || args.options.planId || args.options.planTitle || args.options.ownerGroupId || args.options.ownerGroupName) {
167
+ return 'Don\'t specify bucketId,bucketName, planId, planTitle, ownerGroupId or ownerGroupName when using id';
168
+ }
169
+ }
170
+ if (args.options.title) {
171
+ if (!args.options.bucketId && !args.options.bucketName) {
172
+ return 'Specify either bucketId or bucketName when using title';
173
+ }
174
+ if (args.options.bucketId && args.options.bucketName) {
175
+ return 'Specify either bucketId or bucketName when using title but not both';
176
+ }
177
+ if (args.options.bucketName) {
178
+ if (!args.options.planId && !args.options.planTitle) {
179
+ return 'Specify either planId or planTitle when using bucketName';
180
+ }
181
+ if (args.options.planId && args.options.planTitle) {
182
+ return 'Specify either planId or planTitle when using bucketName but not both';
183
+ }
184
+ }
185
+ if (args.options.planTitle) {
186
+ if (!args.options.ownerGroupId && !args.options.ownerGroupName) {
187
+ return 'Specify either ownerGroupId or ownerGroupName when using planTitle';
188
+ }
189
+ if (args.options.ownerGroupId && args.options.ownerGroupName) {
190
+ return 'Specify either ownerGroupId or ownerGroupName when using planTitle but not both';
191
+ }
192
+ }
193
+ if (args.options.ownerGroupId && !utils_1.validation.isValidGuid(args.options.ownerGroupId)) {
194
+ return `${args.options.ownerGroupId} is not a valid GUID`;
195
+ }
196
+ }
197
+ return true;
198
+ }
199
+ }
200
+ module.exports = new PlannerTaskRemoveCommand();
201
+ //# sourceMappingURL=task-remove.js.map
@@ -6,6 +6,8 @@ const request_1 = require("../../../../request");
6
6
  const planner_1 = require("../../../../utils/planner");
7
7
  const GraphCommand_1 = require("../../../base/GraphCommand");
8
8
  const commands_1 = require("../../commands");
9
+ const aadGroup_1 = require("../../../../utils/aadGroup");
10
+ const taskPriority_1 = require("../../taskPriority");
9
11
  class PlannerTaskSetCommand extends GraphCommand_1.default {
10
12
  constructor() {
11
13
  super(...arguments);
@@ -35,6 +37,7 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
35
37
  telemetryProps.description = typeof args.options.description !== 'undefined';
36
38
  telemetryProps.appliedCategories = typeof args.options.appliedCategories !== 'undefined';
37
39
  telemetryProps.orderHint = typeof args.options.orderHint !== 'undefined';
40
+ telemetryProps.priority = typeof args.options.priority !== 'undefined';
38
41
  return telemetryProps;
39
42
  }
40
43
  commandAction(logger, args, cb) {
@@ -230,22 +233,9 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
230
233
  if (options.ownerGroupId) {
231
234
  return Promise.resolve(options.ownerGroupId);
232
235
  }
233
- const requestOptions = {
234
- url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(options.ownerGroupName)}'&$select=id`,
235
- headers: {
236
- accept: 'application/json;odata.metadata=none'
237
- },
238
- responseType: 'json'
239
- };
240
- return request_1.default
241
- .get(requestOptions)
242
- .then(response => {
243
- const group = response.value[0];
244
- if (!group) {
245
- return Promise.reject(`The specified owner group does not exist`);
246
- }
247
- return Promise.resolve(group.id);
248
- });
236
+ return aadGroup_1.aadGroup
237
+ .getGroupByDisplayName(options.ownerGroupName)
238
+ .then(group => group.id);
249
239
  }
250
240
  mapRequestBody(options, appliedCategories) {
251
241
  const requestBody = {};
@@ -276,6 +266,9 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
276
266
  if (options.orderHint) {
277
267
  requestBody.orderHint = options.orderHint;
278
268
  }
269
+ if (options.priority !== undefined) {
270
+ requestBody.priority = taskPriority_1.taskPriority.getPriorityValue(options.priority);
271
+ }
279
272
  return requestBody;
280
273
  }
281
274
  options() {
@@ -296,7 +289,8 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
296
289
  { option: '--assigneePriority [assigneePriority]' },
297
290
  { option: '--description [description]' },
298
291
  { option: '--appliedCategories [appliedCategories]' },
299
- { option: '--orderHint [orderHint]' }
292
+ { option: '--orderHint [orderHint]' },
293
+ { option: '--priority [priority]', autocomplete: taskPriority_1.taskPriority.priorityValues }
300
294
  ];
301
295
  const parentOptions = super.options();
302
296
  return options.concat(parentOptions);
@@ -341,6 +335,16 @@ class PlannerTaskSetCommand extends GraphCommand_1.default {
341
335
  if (args.options.appliedCategories && args.options.appliedCategories.split(',').filter(category => this.allowedAppliedCategories.indexOf(category.toLocaleLowerCase()) < 0).length !== 0) {
342
336
  return 'The appliedCategories contains invalid value. Specify either category1, category2, category3, category4, category5 and/or category6 as properties';
343
337
  }
338
+ if (args.options.priority !== undefined) {
339
+ if (typeof args.options.priority === "number") {
340
+ if (isNaN(args.options.priority) || args.options.priority < 0 || args.options.priority > 10 || !Number.isInteger(args.options.priority)) {
341
+ return 'priority should be an integer between 0 and 10.';
342
+ }
343
+ }
344
+ else if (taskPriority_1.taskPriority.priorityValues.map(l => l.toLowerCase()).indexOf(args.options.priority.toString().toLowerCase()) === -1) {
345
+ return `${args.options.priority} is not a valid priority value. Allowed values are ${taskPriority_1.taskPriority.priorityValues.join('|')}.`;
346
+ }
347
+ }
344
348
  return true;
345
349
  }
346
350
  }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const request_1 = require("../../../../request");
4
+ const PlannerCommand_1 = require("../../../base/PlannerCommand");
5
+ const commands_1 = require("../../commands");
6
+ class PlannerTenantSettingsListCommand extends PlannerCommand_1.default {
7
+ get name() {
8
+ return commands_1.default.TENANT_SETTINGS_LIST;
9
+ }
10
+ get description() {
11
+ return 'Lists the Microsoft Planner configuration of the tenant';
12
+ }
13
+ defaultProperties() {
14
+ return ['isPlannerAllowed', 'allowCalendarSharing', 'allowTenantMoveWithDataLoss', 'allowTenantMoveWithDataMigration', 'allowRosterCreation', 'allowPlannerMobilePushNotifications'];
15
+ }
16
+ commandAction(logger, args, cb) {
17
+ const requestOptions = {
18
+ url: `${this.resource}/taskAPI/tenantAdminSettings/Settings`,
19
+ headers: {
20
+ accept: 'application/json;odata.metadata=none'
21
+ },
22
+ responseType: 'json'
23
+ };
24
+ request_1.default
25
+ .get(requestOptions)
26
+ .then((result) => {
27
+ logger.log(result);
28
+ cb();
29
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
30
+ }
31
+ }
32
+ module.exports = new PlannerTenantSettingsListCommand();
33
+ //# sourceMappingURL=tenant-settings-list.js.map
@@ -3,20 +3,26 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const prefix = 'planner';
4
4
  exports.default = {
5
5
  BUCKET_ADD: `${prefix} bucket add`,
6
+ BUCKET_GET: `${prefix} bucket get`,
6
7
  BUCKET_LIST: `${prefix} bucket list`,
7
8
  BUCKET_SET: `${prefix} bucket set`,
8
9
  BUCKET_REMOVE: `${prefix} bucket remove`,
9
- BUCKET_GET: `${prefix} bucket get`,
10
10
  PLAN_ADD: `${prefix} plan add`,
11
11
  PLAN_DETAILS_GET: `${prefix} plan details get`,
12
12
  PLAN_GET: `${prefix} plan get`,
13
13
  PLAN_LIST: `${prefix} plan list`,
14
14
  TASK_ADD: `${prefix} task add`,
15
+ TASK_CHECKLISTITEM_ADD: `${prefix} task checklistitem add`,
16
+ TASK_CHECKLISTITEM_LIST: `${prefix} task checklistitem list`,
17
+ TASK_CHECKLISTITEM_REMOVE: `${prefix} task checklistitem remove`,
15
18
  TASK_DETAILS_GET: `${prefix} task details get`,
16
19
  TASK_GET: `${prefix} task get`,
17
20
  TASK_LIST: `${prefix} task list`,
18
21
  TASK_REFERENCE_ADD: `${prefix} task reference add`,
19
22
  TASK_REFERENCE_LIST: `${prefix} task reference list`,
20
- TASK_SET: `${prefix} task set`
23
+ TASK_REFERENCE_REMOVE: `${prefix} task reference remove`,
24
+ TASK_REMOVE: `${prefix} task remove`,
25
+ TASK_SET: `${prefix} task set`,
26
+ TENANT_SETTINGS_LIST: `${prefix} tenant settings list`
21
27
  };
22
28
  //# sourceMappingURL=commands.js.map
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.taskPriority = void 0;
4
+ exports.taskPriority = {
5
+ /** Priority labels used in Planner. */
6
+ priorityValues: ["Urgent", "Important", "Medium", "Low"],
7
+ /**
8
+ * Transform priority label to the corresponding number value.
9
+ * @param priority Priority label or number.
10
+ */
11
+ getPriorityValue(priority) {
12
+ if (typeof priority === "string") {
13
+ switch (priority.toLowerCase()) {
14
+ case "urgent":
15
+ return 1;
16
+ case "important":
17
+ return 3;
18
+ case "medium":
19
+ return 5;
20
+ case "low":
21
+ return 9;
22
+ }
23
+ }
24
+ return priority;
25
+ }
26
+ };
27
+ //# sourceMappingURL=taskPriority.js.map
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FN002009_DEVDEP_microsoft_sp_tslint_rules = void 0;
4
4
  const DependencyRule_1 = require("./DependencyRule");
5
5
  class FN002009_DEVDEP_microsoft_sp_tslint_rules extends DependencyRule_1.DependencyRule {
6
- constructor(packageVersion) {
7
- super('@microsoft/sp-tslint-rules', packageVersion, true);
6
+ constructor(packageVersion, add = true) {
7
+ super('@microsoft/sp-tslint-rules', packageVersion, true, false, add);
8
8
  }
9
9
  get id() {
10
10
  return 'FN002009';
@@ -3,8 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FN002018_DEVDEP_microsoft_rush_stack_compiler_3_9 = void 0;
4
4
  const DependencyRule_1 = require("./DependencyRule");
5
5
  class FN002018_DEVDEP_microsoft_rush_stack_compiler_3_9 extends DependencyRule_1.DependencyRule {
6
- constructor(packageVersion) {
7
- super('@microsoft/rush-stack-compiler-3.9', packageVersion, true);
6
+ constructor(packageVersion, add = true) {
7
+ super('@microsoft/rush-stack-compiler-3.9', packageVersion, true, false, add);
8
8
  }
9
9
  get id() {
10
10
  return 'FN002018';
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5 = void 0;
4
+ const DependencyRule_1 = require("./DependencyRule");
5
+ class FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5 extends DependencyRule_1.DependencyRule {
6
+ constructor(packageVersion) {
7
+ super('@microsoft/rush-stack-compiler-4.5', packageVersion, true);
8
+ }
9
+ get id() {
10
+ return 'FN002020';
11
+ }
12
+ get supersedes() {
13
+ return ['FN002010', 'FN002011', 'FN002012', 'FN002017', 'FN002018'];
14
+ }
15
+ }
16
+ exports.FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5 = FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5;
17
+ //# sourceMappingURL=FN002020_DEVDEP_microsoft_rush_stack_compiler_4_5.js.map
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002021_DEVDEP_rushstack_eslint_config = void 0;
4
+ const DependencyRule_1 = require("./DependencyRule");
5
+ class FN002021_DEVDEP_rushstack_eslint_config extends DependencyRule_1.DependencyRule {
6
+ constructor(packageVersion) {
7
+ super('@rushstack/eslint-config', packageVersion, true);
8
+ }
9
+ get id() {
10
+ return 'FN002021';
11
+ }
12
+ }
13
+ exports.FN002021_DEVDEP_rushstack_eslint_config = FN002021_DEVDEP_rushstack_eslint_config;
14
+ //# sourceMappingURL=FN002021_DEVDEP_rushstack_eslint_config.js.map
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002022_DEVDEP_microsoft_eslint_plugin_spfx = void 0;
4
+ const DependencyRule_1 = require("./DependencyRule");
5
+ class FN002022_DEVDEP_microsoft_eslint_plugin_spfx extends DependencyRule_1.DependencyRule {
6
+ constructor(packageVersion) {
7
+ super('@microsoft/eslint-plugin-spfx', packageVersion, true);
8
+ }
9
+ get id() {
10
+ return 'FN002022';
11
+ }
12
+ }
13
+ exports.FN002022_DEVDEP_microsoft_eslint_plugin_spfx = FN002022_DEVDEP_microsoft_eslint_plugin_spfx;
14
+ //# sourceMappingURL=FN002022_DEVDEP_microsoft_eslint_plugin_spfx.js.map
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002023_DEVDEP_microsoft_eslint_config_spfx = void 0;
4
+ const DependencyRule_1 = require("./DependencyRule");
5
+ class FN002023_DEVDEP_microsoft_eslint_config_spfx extends DependencyRule_1.DependencyRule {
6
+ constructor(packageVersion) {
7
+ super('@microsoft/eslint-config-spfx', packageVersion, true);
8
+ }
9
+ get id() {
10
+ return 'FN002023';
11
+ }
12
+ }
13
+ exports.FN002023_DEVDEP_microsoft_eslint_config_spfx = FN002023_DEVDEP_microsoft_eslint_config_spfx;
14
+ //# sourceMappingURL=FN002023_DEVDEP_microsoft_eslint_config_spfx.js.map
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002024_DEVDEP_eslint = void 0;
4
+ const DependencyRule_1 = require("./DependencyRule");
5
+ class FN002024_DEVDEP_eslint extends DependencyRule_1.DependencyRule {
6
+ constructor(packageVersion) {
7
+ super('eslint', packageVersion, true);
8
+ }
9
+ get id() {
10
+ return 'FN002024';
11
+ }
12
+ }
13
+ exports.FN002024_DEVDEP_eslint = FN002024_DEVDEP_eslint;
14
+ //# sourceMappingURL=FN002024_DEVDEP_eslint.js.map
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN002025_DEVDEP_eslint_plugin_react_hooks = void 0;
4
+ const utils_1 = require("../../../../../../utils");
5
+ const DependencyRule_1 = require("./DependencyRule");
6
+ class FN002025_DEVDEP_eslint_plugin_react_hooks extends DependencyRule_1.DependencyRule {
7
+ constructor(packageVersion) {
8
+ super('eslint-plugin-react-hooks', packageVersion, true, true);
9
+ }
10
+ get id() {
11
+ return 'FN002025';
12
+ }
13
+ customCondition(project) {
14
+ return utils_1.spfx.isReactProject(project);
15
+ }
16
+ }
17
+ exports.FN002025_DEVDEP_eslint_plugin_react_hooks = FN002025_DEVDEP_eslint_plugin_react_hooks;
18
+ //# sourceMappingURL=FN002025_DEVDEP_eslint_plugin_react_hooks.js.map
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FN015008_FILE_eslintrc_js = void 0;
4
+ const FileAddRemoveRule_1 = require("./FileAddRemoveRule");
5
+ class FN015008_FILE_eslintrc_js extends FileAddRemoveRule_1.FileAddRemoveRule {
6
+ constructor(add, contents) {
7
+ super('./.eslintrc.js', add, contents);
8
+ }
9
+ get id() {
10
+ return 'FN015008';
11
+ }
12
+ }
13
+ exports.FN015008_FILE_eslintrc_js = FN015008_FILE_eslintrc_js;
14
+ //# sourceMappingURL=FN015008_FILE_eslintrc_js.js.map