@pnp/cli-microsoft365 5.3.0-beta.d2ec1f4 → 5.3.0-beta.ebb13d0

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 (101) hide show
  1. package/.eslintrc.js +1 -0
  2. package/dist/Auth.js +5 -0
  3. package/dist/m365/aad/commands/app/app-add.js +91 -35
  4. package/dist/m365/aad/commands/app/app-role-list.js +1 -1
  5. package/dist/m365/aad/commands/app/app-set.js +91 -0
  6. package/dist/m365/aad/commands/approleassignment/approleassignment-list.js +55 -22
  7. package/dist/m365/aad/commands/group/group-list.js +1 -1
  8. package/dist/m365/aad/commands/groupsetting/groupsetting-list.js +1 -1
  9. package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-get.js +1 -1
  10. package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-list.js +1 -1
  11. package/dist/m365/aad/commands/o365group/o365group-conversation-list.js +1 -1
  12. package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +1 -1
  13. package/dist/m365/aad/commands/o365group/o365group-list.js +1 -1
  14. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-clear.js +3 -3
  15. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-list.js +1 -1
  16. package/dist/m365/aad/commands/o365group/o365group-user-list.js +2 -2
  17. package/dist/m365/aad/commands/o365group/o365group-user-set.js +2 -2
  18. package/dist/m365/aad/commands/user/user-list.js +1 -1
  19. package/dist/m365/aad/commands/user/user-signin-list.js +1 -1
  20. package/dist/m365/aad/commands.js +1 -1
  21. package/dist/m365/app/commands/app-open.js +64 -0
  22. package/dist/m365/app/commands.js +1 -0
  23. package/dist/m365/base/PowerBICommand.js +10 -0
  24. package/dist/m365/file/commands/file-list.js +1 -1
  25. package/dist/m365/outlook/commands/message/message-list.js +1 -1
  26. package/dist/m365/outlook/commands/room/room-list.js +1 -1
  27. package/dist/m365/outlook/commands/roomlist/roomlist-list.js +1 -1
  28. package/dist/m365/planner/commands/bucket/bucket-add.js +8 -16
  29. package/dist/m365/planner/commands/bucket/bucket-get.js +186 -0
  30. package/dist/m365/planner/commands/bucket/bucket-list.js +10 -19
  31. package/dist/m365/planner/commands/bucket/bucket-remove.js +8 -20
  32. package/dist/m365/planner/commands/bucket/bucket-set.js +9 -21
  33. package/dist/m365/planner/commands/plan/plan-add.js +6 -1
  34. package/dist/m365/planner/commands/plan/plan-details-get.js +12 -15
  35. package/dist/m365/planner/commands/plan/plan-get.js +13 -18
  36. package/dist/m365/planner/commands/plan/plan-list.js +10 -13
  37. package/dist/m365/planner/commands/task/task-add.js +8 -16
  38. package/dist/m365/planner/commands/task/task-details-get.js +6 -0
  39. package/dist/m365/planner/commands/task/task-get.js +138 -7
  40. package/dist/m365/planner/commands/task/task-list.js +15 -24
  41. package/dist/m365/planner/commands/task/task-reference-add.js +75 -0
  42. package/dist/m365/planner/commands/task/task-reference-list.js +45 -0
  43. package/dist/m365/planner/commands/task/task-set.js +9 -18
  44. package/dist/m365/planner/commands.js +4 -1
  45. package/dist/m365/pp/commands/gateway/gateway-list.js +36 -0
  46. package/dist/m365/pp/commands/managementapp/managementapp-list.js +1 -1
  47. package/dist/m365/pp/commands.js +1 -0
  48. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +84 -0
  49. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +76 -0
  50. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +83 -0
  51. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +79 -0
  52. package/dist/m365/spo/commands/roledefinition/roledefinition-list.js +49 -0
  53. package/dist/m365/spo/commands.js +5 -0
  54. package/dist/m365/teams/commands/app/app-list.js +1 -1
  55. package/dist/m365/teams/commands/channel/channel-list.js +1 -1
  56. package/dist/m365/teams/commands/channel/channel-member-add.js +4 -1
  57. package/dist/m365/teams/commands/channel/channel-member-list.js +1 -1
  58. package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -0
  59. package/dist/m365/teams/commands/channel/channel-member-set.js +3 -0
  60. package/dist/m365/teams/commands/chat/chat-get.js +8 -8
  61. package/dist/m365/teams/commands/chat/chat-list.js +1 -1
  62. package/dist/m365/teams/commands/chat/chat-member-list.js +1 -1
  63. package/dist/m365/teams/commands/chat/chat-message-list.js +1 -1
  64. package/dist/m365/teams/commands/chat/chat-message-send.js +6 -6
  65. package/dist/m365/teams/commands/chat/chatUtil.js +4 -4
  66. package/dist/m365/teams/commands/message/message-list.js +1 -1
  67. package/dist/m365/teams/commands/message/message-reply-list.js +1 -1
  68. package/dist/m365/teams/commands/tab/tab-list.js +1 -1
  69. package/dist/m365/teams/commands/team/team-list.js +1 -1
  70. package/dist/m365/teams/commands/user/user-app-list.js +1 -1
  71. package/dist/m365/teams/commands/user/user-list.js +2 -2
  72. package/dist/m365/tenant/commands/security/security-alerts-list.js +71 -0
  73. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +1 -1
  74. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +1 -1
  75. package/dist/m365/tenant/commands.js +1 -0
  76. package/dist/m365/todo/commands/list/list-list.js +1 -1
  77. package/dist/m365/todo/commands/task/task-list.js +1 -1
  78. package/dist/utils/accessToken.js +18 -0
  79. package/dist/utils/formatting.js +11 -2
  80. package/dist/utils/odata.js +2 -2
  81. package/dist/utils/planner.js +65 -0
  82. package/docs/docs/cmd/aad/app/app-add.md +15 -0
  83. package/docs/docs/cmd/aad/app/app-set.md +17 -0
  84. package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.md +1 -1
  85. package/docs/docs/cmd/app/app-open.md +45 -0
  86. package/docs/docs/cmd/planner/bucket/bucket-get.md +57 -0
  87. package/docs/docs/cmd/planner/task/task-get.md +30 -3
  88. package/docs/docs/cmd/planner/task/task-reference-add.md +45 -0
  89. package/docs/docs/cmd/planner/task/task-reference-list.md +24 -0
  90. package/docs/docs/cmd/pp/gateway/gateway-list.md +21 -0
  91. package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +55 -0
  92. package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +36 -0
  93. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +58 -0
  94. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +39 -0
  95. package/docs/docs/cmd/spo/roledefinition/roledefinition-list.md +24 -0
  96. package/docs/docs/cmd/spo/userprofile/userprofile-get.md +1 -1
  97. package/docs/docs/cmd/teams/channel/channel-member-list.md +4 -4
  98. package/docs/docs/cmd/teams/channel/channel-member-remove.md +2 -2
  99. package/docs/docs/cmd/teams/channel/channel-member-set.md +2 -2
  100. package/docs/docs/cmd/tenant/security/security-alerts-list.md +30 -0
  101. package/package.json +1 -1
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const cli_1 = require("../../../cli");
4
+ const validation_1 = require("../../../utils/validation");
5
+ const settingsNames_1 = require("../../../settingsNames");
6
+ const AppCommand_1 = require("../../base/AppCommand");
7
+ const commands_1 = require("../commands");
8
+ class AppOpenCommand extends AppCommand_1.default {
9
+ get name() {
10
+ return commands_1.default.OPEN;
11
+ }
12
+ get description() {
13
+ return 'Opens Azure AD app in the Azure AD portal';
14
+ }
15
+ getTelemetryProperties(args) {
16
+ const telemetryProps = super.getTelemetryProperties(args);
17
+ telemetryProps.appId = typeof args.options.appId !== 'undefined';
18
+ telemetryProps.preview = typeof args.options.preview !== 'undefined';
19
+ return telemetryProps;
20
+ }
21
+ commandAction(logger, args, cb) {
22
+ this.logOrOpenUrl(args, logger)
23
+ .then(_ => cb(), (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
24
+ }
25
+ logOrOpenUrl(args, logger) {
26
+ return new Promise((resolve, reject) => {
27
+ const previewPrefix = args.options.preview === true ? "preview." : "";
28
+ const url = `https://${previewPrefix}portal.azure.com/#blade/Microsoft_AAD_RegisteredApps/ApplicationMenuBlade/Overview/appId/${this.appId}/isMSAApp/`;
29
+ if (cli_1.Cli.getInstance().getSettingWithDefaultValue(settingsNames_1.settingsNames.autoOpenLinksInBrowser, false) === false) {
30
+ logger.log(`Use a web browser to open the page ${url}`);
31
+ return resolve();
32
+ }
33
+ logger.log(`Opening the following page in your browser: ${url}`);
34
+ // 'open' is required here so we can lazy load the dependency.
35
+ // _open is never set before hitting this line, but this check
36
+ // is implemented so that we can stub it when testing.
37
+ /* c8 ignore next 3 */
38
+ if (!this._open) {
39
+ this._open = require('open');
40
+ }
41
+ this._open(url).then(() => {
42
+ resolve();
43
+ }, (error) => {
44
+ reject(error);
45
+ });
46
+ });
47
+ }
48
+ options() {
49
+ const options = [
50
+ { option: '--appId [appId]' },
51
+ { option: '--preview' }
52
+ ];
53
+ const parentOptions = super.options();
54
+ return options.concat(parentOptions);
55
+ }
56
+ validate(args) {
57
+ if (args.options.appId && !validation_1.validation.isValidGuid(args.options.appId)) {
58
+ return `${args.options.appId} is not a valid GUID`;
59
+ }
60
+ return true;
61
+ }
62
+ }
63
+ module.exports = new AppOpenCommand();
64
+ //# sourceMappingURL=app-open.js.map
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const prefix = 'app';
4
4
  exports.default = {
5
5
  GET: `${prefix} get`,
6
+ OPEN: `${prefix} open`,
6
7
  PERMISSION_LIST: `${prefix} permission list`
7
8
  };
8
9
  //# sourceMappingURL=commands.js.map
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const Command_1 = require("../../Command");
4
+ class PowerBICommand extends Command_1.default {
5
+ get resource() {
6
+ return 'https://api.powerbi.com';
7
+ }
8
+ }
9
+ exports.default = PowerBICommand;
10
+ //# sourceMappingURL=PowerBICommand.js.map
@@ -156,7 +156,7 @@ class FileListCommand extends GraphCommand_1.default {
156
156
  .all(folderIds.map((folderId) =>
157
157
  // get items from folder. Because we can't filter out folders here
158
158
  // we need to get all items from the folder and filter them out later
159
- utils_1.odata.getAllItems(`${this.resource}/v1.0/drives/${driveId}/items/${folderId}/children`, logger)))
159
+ utils_1.odata.getAllItems(`${this.resource}/v1.0/drives/${driveId}/items/${folderId}/children`)))
160
160
  .then(res => {
161
161
  // flatten data from all promises
162
162
  files = files.concat(...res);
@@ -27,7 +27,7 @@ class OutlookMessageListCommand extends GraphCommand_1.default {
27
27
  .getFolderId(args)
28
28
  .then((folderId) => {
29
29
  const url = folderId ? `me/mailFolders/${folderId}/messages` : 'me/messages';
30
- return utils_1.odata.getAllItems(`${this.resource}/v1.0/${url}?$top=50`, logger);
30
+ return utils_1.odata.getAllItems(`${this.resource}/v1.0/${url}?$top=50`);
31
31
  })
32
32
  .then((messages) => {
33
33
  logger.log(messages);
@@ -24,7 +24,7 @@ class OutlookRoomListCommand extends GraphCommand_1.default {
24
24
  endpoint = `${this.resource}/v1.0/places/${args.options.roomlistEmail}/microsoft.graph.roomlist/rooms`;
25
25
  }
26
26
  utils_1.odata
27
- .getAllItems(endpoint, logger)
27
+ .getAllItems(endpoint)
28
28
  .then((rooms) => {
29
29
  logger.log(rooms);
30
30
  cb();
@@ -15,7 +15,7 @@ class OutlookRoomListListCommand extends GraphCommand_1.default {
15
15
  }
16
16
  commandAction(logger, args, cb) {
17
17
  utils_1.odata
18
- .getAllItems(`${this.resource}/v1.0/places/microsoft.graph.roomlist`, logger)
18
+ .getAllItems(`${this.resource}/v1.0/places/microsoft.graph.roomlist`)
19
19
  .then((roomLists) => {
20
20
  logger.log(roomLists);
21
21
  cb();
@@ -1,7 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ const Auth_1 = require("../../../../Auth");
3
4
  const request_1 = require("../../../../request");
4
5
  const utils_1 = require("../../../../utils");
6
+ const planner_1 = require("../../../../utils/planner");
5
7
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
8
  const commands_1 = require("../../commands");
7
9
  class PlannerBucketAddCommand extends GraphCommand_1.default {
@@ -24,6 +26,10 @@ class PlannerBucketAddCommand extends GraphCommand_1.default {
24
26
  return ['id', 'name', 'planId', 'orderHint'];
25
27
  }
26
28
  commandAction(logger, args, cb) {
29
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
30
+ this.handleError('This command does not support application permissions.', logger, cb);
31
+ return;
32
+ }
27
33
  this
28
34
  .getPlanId(args)
29
35
  .then((planId) => {
@@ -52,22 +58,8 @@ class PlannerBucketAddCommand extends GraphCommand_1.default {
52
58
  }
53
59
  return this
54
60
  .getGroupId(args)
55
- .then((groupId) => {
56
- const requestOptions = {
57
- url: `${this.resource}/v1.0/planner/plans?$filter=(owner eq '${groupId}')`,
58
- headers: {
59
- accept: 'application/json;odata.metadata=none'
60
- },
61
- responseType: 'json'
62
- };
63
- return request_1.default.get(requestOptions);
64
- }).then((response) => {
65
- const plan = response.value.find(val => val.title === args.options.planName);
66
- if (!plan) {
67
- return Promise.reject(`The specified plan does not exist`);
68
- }
69
- return Promise.resolve(plan.id);
70
- });
61
+ .then(groupId => planner_1.planner.getPlanByName(args.options.planName, groupId))
62
+ .then(plan => plan.id);
71
63
  }
72
64
  getGroupId(args) {
73
65
  if (args.options.ownerGroupId) {
@@ -0,0 +1,186 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const request_1 = require("../../../../request");
13
+ const utils_1 = require("../../../../utils");
14
+ const GraphCommand_1 = require("../../../base/GraphCommand");
15
+ const commands_1 = require("../../commands");
16
+ const Auth_1 = require("../../../../Auth");
17
+ const planner_1 = require("../../../../utils/planner");
18
+ class PlannerBucketGetCommand extends GraphCommand_1.default {
19
+ get name() {
20
+ return commands_1.default.BUCKET_GET;
21
+ }
22
+ get description() {
23
+ return 'Gets the Microsoft Planner bucket in a plan';
24
+ }
25
+ getTelemetryProperties(args) {
26
+ const telemetryProps = super.getTelemetryProperties(args);
27
+ telemetryProps.id = typeof args.options.id !== 'undefined';
28
+ telemetryProps.name = typeof args.options.name !== 'undefined';
29
+ telemetryProps.planId = typeof args.options.planId !== 'undefined';
30
+ telemetryProps.planName = typeof args.options.planName !== 'undefined';
31
+ telemetryProps.ownerGroupId = typeof args.options.ownerGroupId !== 'undefined';
32
+ telemetryProps.ownerGroupName = typeof args.options.ownerGroupName !== 'undefined';
33
+ return telemetryProps;
34
+ }
35
+ commandAction(logger, args, cb) {
36
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
37
+ this.handleError('This command does not support application permissions.', logger, cb);
38
+ return;
39
+ }
40
+ this
41
+ .getBucketId(args)
42
+ .then((bucketId) => this.getBucketById(bucketId))
43
+ .then((bucket) => {
44
+ logger.log(bucket);
45
+ cb();
46
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
47
+ }
48
+ getBucketId(args) {
49
+ const { id, name } = args.options;
50
+ if (id) {
51
+ return Promise.resolve(id);
52
+ }
53
+ return this
54
+ .getPlanId(args)
55
+ .then((planId) => {
56
+ const requestOptions = {
57
+ url: `${this.resource}/v1.0/planner/plans/${planId}/buckets`,
58
+ headers: {
59
+ accept: 'application/json;odata.metadata=none'
60
+ },
61
+ responseType: 'json'
62
+ };
63
+ return request_1.default.get(requestOptions);
64
+ })
65
+ .then(buckets => {
66
+ const filteredBuckets = buckets.value.filter(b => name.toLowerCase() === b.name.toLowerCase());
67
+ if (!filteredBuckets.length) {
68
+ return Promise.reject(`The specified bucket ${name} does not exist`);
69
+ }
70
+ if (filteredBuckets.length > 1) {
71
+ return Promise.reject(`Multiple buckets with name ${name} found: ${filteredBuckets.map(x => x.id)}`);
72
+ }
73
+ return Promise.resolve(filteredBuckets[0].id.toString());
74
+ });
75
+ }
76
+ getPlanId(args) {
77
+ const { planId, planName } = args.options;
78
+ if (planId) {
79
+ return Promise.resolve(planId);
80
+ }
81
+ return this
82
+ .getGroupId(args)
83
+ .then(groupId => planner_1.planner.getPlanByName(planName, groupId))
84
+ .then(plan => plan.id);
85
+ }
86
+ getBucketById(id) {
87
+ return __awaiter(this, void 0, void 0, function* () {
88
+ const requestOptions = {
89
+ url: `${this.resource}/v1.0/planner/buckets/${id}`,
90
+ headers: {
91
+ accept: 'application/json'
92
+ },
93
+ responseType: 'json'
94
+ };
95
+ return request_1.default.get(requestOptions);
96
+ });
97
+ }
98
+ getGroupId(args) {
99
+ const { ownerGroupId, ownerGroupName } = args.options;
100
+ if (ownerGroupId) {
101
+ return Promise.resolve(ownerGroupId);
102
+ }
103
+ const requestOptions = {
104
+ url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(ownerGroupName)}'`,
105
+ headers: {
106
+ accept: 'application/json;odata.metadata=none'
107
+ },
108
+ responseType: 'json'
109
+ };
110
+ return request_1.default
111
+ .get(requestOptions)
112
+ .then(response => {
113
+ if (!response.value.length) {
114
+ return Promise.reject(`The specified owner group ${ownerGroupName} does not exist`);
115
+ }
116
+ if (response.value.length > 1) {
117
+ return Promise.reject(`Multiple owner groups with name ${ownerGroupName} found: ${response.value.map(x => x.id)}`);
118
+ }
119
+ return Promise.resolve(response.value[0].id);
120
+ });
121
+ }
122
+ options() {
123
+ const options = [
124
+ {
125
+ option: '-i, --id [id]'
126
+ },
127
+ {
128
+ option: '--name [name]'
129
+ },
130
+ {
131
+ option: '--planId [planId]'
132
+ },
133
+ {
134
+ option: '--planName [planName]'
135
+ },
136
+ {
137
+ option: '--ownerGroupId [ownerGroupId]'
138
+ },
139
+ {
140
+ option: '--ownerGroupName [ownerGroupName]'
141
+ }
142
+ ];
143
+ const parentOptions = super.options();
144
+ return options.concat(parentOptions);
145
+ }
146
+ validate(args) {
147
+ if (args.options.id) {
148
+ if (args.options.planId || args.options.planName || args.options.ownerGroupId || args.options.ownerGroupName) {
149
+ return 'Don\'t specify planId, planName, ownerGroupId or ownerGroupName when using id';
150
+ }
151
+ if (args.options.name) {
152
+ return 'Specify either id or name';
153
+ }
154
+ }
155
+ if (args.options.name) {
156
+ if (!args.options.planId && !args.options.planName) {
157
+ return 'Specify either planId or planName when using name';
158
+ }
159
+ if (args.options.planId && args.options.planName) {
160
+ return 'Specify either planId or planName when using name but not both';
161
+ }
162
+ if (args.options.planName) {
163
+ if (!args.options.ownerGroupId && !args.options.ownerGroupName) {
164
+ return 'Specify either ownerGroupId or ownerGroupName when using planName';
165
+ }
166
+ if (args.options.ownerGroupId && args.options.ownerGroupName) {
167
+ return 'Specify either ownerGroupId or ownerGroupName when using planName but not both';
168
+ }
169
+ if (args.options.ownerGroupId && !utils_1.validation.isValidGuid(args.options.ownerGroupId)) {
170
+ return `${args.options.ownerGroupId} is not a valid GUID`;
171
+ }
172
+ }
173
+ if (args.options.planId) {
174
+ if (args.options.ownerGroupId || args.options.ownerGroupName) {
175
+ return 'Don\'t specify ownerGroupId or ownerGroupName when using planId';
176
+ }
177
+ }
178
+ }
179
+ if (!args.options.id && !args.options.name) {
180
+ return 'Please specify id or name';
181
+ }
182
+ return true;
183
+ }
184
+ }
185
+ module.exports = new PlannerBucketGetCommand();
186
+ //# sourceMappingURL=bucket-get.js.map
@@ -1,7 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const request_1 = require("../../../../request");
5
+ const planner_1 = require("../../../../utils/planner");
6
+ const Auth_1 = require("../../../../Auth");
5
7
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
8
  const commands_1 = require("../../commands");
7
9
  class PlannerBucketListCommand extends GraphCommand_1.default {
@@ -23,9 +25,13 @@ class PlannerBucketListCommand extends GraphCommand_1.default {
23
25
  return ['id', 'name', 'planId', 'orderHint'];
24
26
  }
25
27
  commandAction(logger, args, cb) {
28
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
29
+ this.handleError('This command does not support application permissions.', logger, cb);
30
+ return;
31
+ }
26
32
  this
27
33
  .getPlanId(args)
28
- .then((planId) => utils_1.odata.getAllItems(`${this.resource}/v1.0/planner/plans/${planId}/buckets`, logger))
34
+ .then((planId) => utils_1.odata.getAllItems(`${this.resource}/v1.0/planner/plans/${planId}/buckets`))
29
35
  .then((buckets) => {
30
36
  logger.log(buckets);
31
37
  cb();
@@ -37,23 +43,8 @@ class PlannerBucketListCommand extends GraphCommand_1.default {
37
43
  }
38
44
  return this
39
45
  .getGroupId(args)
40
- .then((groupId) => {
41
- const requestOptions = {
42
- url: `${this.resource}/v1.0/planner/plans?$filter=(owner eq '${groupId}')`,
43
- headers: {
44
- accept: 'application/json;odata.metadata=none'
45
- },
46
- responseType: 'json'
47
- };
48
- return request_1.default.get(requestOptions);
49
- })
50
- .then(response => {
51
- const plan = response.value.find(val => val.title === args.options.planName);
52
- if (!plan) {
53
- return Promise.reject(`The specified plan does not exist`);
54
- }
55
- return Promise.resolve(plan.id);
56
- });
46
+ .then(groupId => planner_1.planner.getPlanByName(args.options.planName, groupId))
47
+ .then(plan => plan.id);
57
48
  }
58
49
  getGroupId(args) {
59
50
  if (args.options.ownerGroupId) {
@@ -5,6 +5,8 @@ const utils_1 = require("../../../../utils");
5
5
  const request_1 = require("../../../../request");
6
6
  const GraphCommand_1 = require("../../../base/GraphCommand");
7
7
  const commands_1 = require("../../commands");
8
+ const planner_1 = require("../../../../utils/planner");
9
+ const Auth_1 = require("../../../../Auth");
8
10
  class PlannerBucketRemoveCommand extends GraphCommand_1.default {
9
11
  get name() {
10
12
  return commands_1.default.BUCKET_REMOVE;
@@ -24,6 +26,10 @@ class PlannerBucketRemoveCommand extends GraphCommand_1.default {
24
26
  return telemetryProps;
25
27
  }
26
28
  commandAction(logger, args, cb) {
29
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
30
+ this.handleError('This command does not support application permissions.', logger, cb);
31
+ return;
32
+ }
27
33
  const removeBucket = () => {
28
34
  this
29
35
  .getBucket(args)
@@ -100,26 +106,8 @@ class PlannerBucketRemoveCommand extends GraphCommand_1.default {
100
106
  }
101
107
  return this
102
108
  .getGroupId(args)
103
- .then(groupId => {
104
- const requestOptions = {
105
- url: `${this.resource}/v1.0/planner/plans?$filter=owner eq '${groupId}'`,
106
- headers: {
107
- accept: 'application/json;odata.metadata=none'
108
- },
109
- responseType: 'json'
110
- };
111
- return request_1.default.get(requestOptions);
112
- })
113
- .then(plans => {
114
- const filteredPlans = plans.value.filter(p => p.title.toLowerCase() === planName.toLowerCase());
115
- if (!filteredPlans.length) {
116
- return Promise.reject(`The specified plan ${planName} does not exist`);
117
- }
118
- if (filteredPlans.length > 1) {
119
- return Promise.reject(`Multiple plans with name ${planName} found: ${filteredPlans.map(x => x.id)}`);
120
- }
121
- return Promise.resolve(filteredPlans[0].id);
122
- });
109
+ .then(groupId => planner_1.planner.getPlanByName(planName, groupId))
110
+ .then(plan => plan.id);
123
111
  }
124
112
  getGroupId(args) {
125
113
  const { ownerGroupId, ownerGroupName } = args.options;
@@ -1,8 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
5
4
  const GraphCommand_1 = require("../../../base/GraphCommand");
5
+ const Auth_1 = require("../../../../Auth");
6
+ const request_1 = require("../../../../request");
7
+ const planner_1 = require("../../../../utils/planner");
6
8
  const commands_1 = require("../../commands");
7
9
  class PlannerBucketSetCommand extends GraphCommand_1.default {
8
10
  get name() {
@@ -24,6 +26,10 @@ class PlannerBucketSetCommand extends GraphCommand_1.default {
24
26
  return telemetryProps;
25
27
  }
26
28
  commandAction(logger, args, cb) {
29
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
30
+ this.handleError('This command does not support application permissions.', logger, cb);
31
+ return;
32
+ }
27
33
  this
28
34
  .getBucket(args)
29
35
  .then(bucket => {
@@ -88,26 +94,8 @@ class PlannerBucketSetCommand extends GraphCommand_1.default {
88
94
  }
89
95
  return this
90
96
  .getGroupId(args)
91
- .then(groupId => {
92
- const requestOptions = {
93
- url: `${this.resource}/v1.0/planner/plans?$filter=owner eq '${groupId}'`,
94
- headers: {
95
- accept: 'application/json;odata.metadata=none'
96
- },
97
- responseType: 'json'
98
- };
99
- return request_1.default.get(requestOptions);
100
- })
101
- .then(plans => {
102
- const filteredPlans = plans.value.filter(p => p.title.toLowerCase() === planName.toLowerCase());
103
- if (filteredPlans.length === 0) {
104
- return Promise.reject(`The specified plan ${planName} does not exist`);
105
- }
106
- if (filteredPlans.length > 1) {
107
- return Promise.reject(`Multiple plans with name ${planName} found: ${filteredPlans.map(x => x.id)}`);
108
- }
109
- return Promise.resolve(filteredPlans[0].id);
110
- });
97
+ .then(groupId => planner_1.planner.getPlanByName(planName, groupId))
98
+ .then(plan => plan.id);
111
99
  }
112
100
  getGroupId(args) {
113
101
  const { ownerGroupId, ownerGroupName } = args.options;
@@ -1,7 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const Auth_1 = require("../../../../Auth");
5
+ const request_1 = require("../../../../request");
5
6
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
7
  const commands_1 = require("../../commands");
7
8
  class PlannerPlanAddCommand extends GraphCommand_1.default {
@@ -21,6 +22,10 @@ class PlannerPlanAddCommand extends GraphCommand_1.default {
21
22
  return ['id', 'title', 'createdDateTime', 'owner'];
22
23
  }
23
24
  commandAction(logger, args, cb) {
25
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
26
+ this.handleError('This command does not support application permissions.', logger, cb);
27
+ return;
28
+ }
24
29
  this
25
30
  .getGroupId(args)
26
31
  .then((groupId) => {
@@ -1,7 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const Auth_1 = require("../../../../Auth");
5
+ const request_1 = require("../../../../request");
6
+ const planner_1 = require("../../../../utils/planner");
5
7
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
8
  const commands_1 = require("../../commands");
7
9
  class PlannerPlanDetailsGetCommand extends GraphCommand_1.default {
@@ -24,11 +26,15 @@ class PlannerPlanDetailsGetCommand extends GraphCommand_1.default {
24
26
  return telemetryProps;
25
27
  }
26
28
  commandAction(logger, args, cb) {
29
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
30
+ this.handleError('This command does not support application permissions.', logger, cb);
31
+ return;
32
+ }
27
33
  this
28
34
  .getGroupId(args)
29
35
  .then((groupId) => {
30
36
  this.groupId = groupId;
31
- return this.getPlanId(args, logger);
37
+ return this.getPlanId(args);
32
38
  })
33
39
  .then((planId) => {
34
40
  args.options.planId = planId;
@@ -66,22 +72,13 @@ class PlannerPlanDetailsGetCommand extends GraphCommand_1.default {
66
72
  return Promise.resolve(groupItem.id);
67
73
  });
68
74
  }
69
- getPlanId(args, logger) {
75
+ getPlanId(args) {
70
76
  if (args.options.planId) {
71
77
  return Promise.resolve(args.options.planId);
72
78
  }
73
- return utils_1.odata
74
- .getAllItems(`${this.resource}/v1.0/groups/${this.groupId}/planner/plans`, logger)
75
- .then((plans) => {
76
- const plansMatchingName = plans.filter((plan) => plan.title === args.options.planTitle);
77
- if (plansMatchingName && plansMatchingName.length > 0) {
78
- if (plansMatchingName.length > 1) {
79
- return Promise.reject(`Multiple plans with name ${args.options.planTitle} found: ${plansMatchingName.map(x => x.id)}`);
80
- }
81
- return Promise.resolve(plansMatchingName[0].id);
82
- }
83
- return Promise.reject(`The specified plan title does not exist`);
84
- });
79
+ return planner_1.planner
80
+ .getPlanByName(args.options.planTitle, this.groupId)
81
+ .then(plan => plan.id);
85
82
  }
86
83
  getPlanDetails(args) {
87
84
  const requestOptions = {
@@ -1,9 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const request_1 = require("../../../../request");
4
3
  const utils_1 = require("../../../../utils");
4
+ const request_1 = require("../../../../request");
5
+ const planner_1 = require("../../../../utils/planner");
5
6
  const GraphCommand_1 = require("../../../base/GraphCommand");
6
7
  const commands_1 = require("../../commands");
8
+ const Auth_1 = require("../../../../Auth");
7
9
  class PlannerPlanGetCommand extends GraphCommand_1.default {
8
10
  get name() {
9
11
  return commands_1.default.PLAN_GET;
@@ -23,9 +25,13 @@ class PlannerPlanGetCommand extends GraphCommand_1.default {
23
25
  return ['id', 'title', 'createdDateTime', 'owner', '@odata.etag'];
24
26
  }
25
27
  commandAction(logger, args, cb) {
28
+ if (utils_1.accessToken.isAppOnlyAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken)) {
29
+ this.handleError('This command does not support application permissions.', logger, cb);
30
+ return;
31
+ }
26
32
  if (args.options.id) {
27
- this
28
- .getPlan(args)
33
+ planner_1.planner
34
+ .getPlanById(args.options.id)
29
35
  .then((res) => {
30
36
  logger.log(res);
31
37
  cb();
@@ -34,11 +40,10 @@ class PlannerPlanGetCommand extends GraphCommand_1.default {
34
40
  else {
35
41
  this
36
42
  .getGroupId(args)
37
- .then((groupId) => utils_1.odata.getAllItems(`${this.resource}/v1.0/groups/${groupId}/planner/plans`, logger, 'minimal'))
38
- .then((plans) => {
39
- const filteredPlan = plans.filter((plan) => plan.title === args.options.title);
40
- if (filteredPlan && filteredPlan.length > 0) {
41
- logger.log(filteredPlan);
43
+ .then(groupId => planner_1.planner.getPlanByName(args.options.title, groupId))
44
+ .then((plan) => {
45
+ if (plan) {
46
+ logger.log(plan);
42
47
  }
43
48
  cb();
44
49
  }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
@@ -65,16 +70,6 @@ class PlannerPlanGetCommand extends GraphCommand_1.default {
65
70
  return Promise.resolve(group.id);
66
71
  });
67
72
  }
68
- getPlan(args) {
69
- const requestOptions = {
70
- url: `${this.resource}/v1.0/planner/plans/${args.options.id}`,
71
- headers: {
72
- 'accept': 'application/json'
73
- },
74
- responseType: 'json'
75
- };
76
- return request_1.default.get(requestOptions);
77
- }
78
73
  options() {
79
74
  const options = [
80
75
  {