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

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 (108) 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/search/commands/externalconnection/externalconnection-list.js +26 -0
  49. package/dist/m365/search/commands.js +2 -1
  50. package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +119 -0
  51. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +84 -0
  52. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +76 -0
  53. package/dist/m365/spo/commands/list/list-view-add.js +113 -0
  54. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +83 -0
  55. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +79 -0
  56. package/dist/m365/spo/commands/roledefinition/roledefinition-list.js +49 -0
  57. package/dist/m365/spo/commands.js +7 -0
  58. package/dist/m365/teams/commands/app/app-list.js +1 -1
  59. package/dist/m365/teams/commands/channel/channel-list.js +1 -1
  60. package/dist/m365/teams/commands/channel/channel-member-add.js +4 -1
  61. package/dist/m365/teams/commands/channel/channel-member-list.js +1 -1
  62. package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -0
  63. package/dist/m365/teams/commands/channel/channel-member-set.js +3 -0
  64. package/dist/m365/teams/commands/chat/chat-get.js +8 -8
  65. package/dist/m365/teams/commands/chat/chat-list.js +1 -1
  66. package/dist/m365/teams/commands/chat/chat-member-list.js +1 -1
  67. package/dist/m365/teams/commands/chat/chat-message-list.js +1 -1
  68. package/dist/m365/teams/commands/chat/chat-message-send.js +6 -6
  69. package/dist/m365/teams/commands/chat/chatUtil.js +4 -4
  70. package/dist/m365/teams/commands/message/message-list.js +1 -1
  71. package/dist/m365/teams/commands/message/message-reply-list.js +1 -1
  72. package/dist/m365/teams/commands/tab/tab-list.js +1 -1
  73. package/dist/m365/teams/commands/team/team-list.js +1 -1
  74. package/dist/m365/teams/commands/user/user-app-list.js +1 -1
  75. package/dist/m365/teams/commands/user/user-list.js +2 -2
  76. package/dist/m365/tenant/commands/security/security-alerts-list.js +71 -0
  77. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +1 -1
  78. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +1 -1
  79. package/dist/m365/tenant/commands.js +1 -0
  80. package/dist/m365/todo/commands/list/list-list.js +1 -1
  81. package/dist/m365/todo/commands/task/task-list.js +1 -1
  82. package/dist/utils/accessToken.js +18 -0
  83. package/dist/utils/formatting.js +11 -2
  84. package/dist/utils/odata.js +2 -2
  85. package/dist/utils/planner.js +65 -0
  86. package/docs/docs/cmd/aad/app/app-add.md +15 -0
  87. package/docs/docs/cmd/aad/app/app-set.md +17 -0
  88. package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.md +1 -1
  89. package/docs/docs/cmd/app/app-open.md +45 -0
  90. package/docs/docs/cmd/planner/bucket/bucket-get.md +57 -0
  91. package/docs/docs/cmd/planner/task/task-get.md +30 -3
  92. package/docs/docs/cmd/planner/task/task-reference-add.md +45 -0
  93. package/docs/docs/cmd/planner/task/task-reference-list.md +24 -0
  94. package/docs/docs/cmd/pp/gateway/gateway-list.md +21 -0
  95. package/docs/docs/cmd/search/externalconnection/externalconnection-list.md +21 -0
  96. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +70 -0
  97. package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +55 -0
  98. package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +36 -0
  99. package/docs/docs/cmd/spo/list/list-view-add.md +67 -0
  100. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +58 -0
  101. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +39 -0
  102. package/docs/docs/cmd/spo/roledefinition/roledefinition-list.md +24 -0
  103. package/docs/docs/cmd/spo/userprofile/userprofile-get.md +1 -1
  104. package/docs/docs/cmd/teams/channel/channel-member-list.md +4 -4
  105. package/docs/docs/cmd/teams/channel/channel-member-remove.md +2 -2
  106. package/docs/docs/cmd/teams/channel/channel-member-set.md +2 -2
  107. package/docs/docs/cmd/tenant/security/security-alerts-list.md +30 -0
  108. package/package.json +2 -1
@@ -40,7 +40,7 @@ class TeamsChannelMemberListCommand extends GraphCommand_1.default {
40
40
  })
41
41
  .then((channelId) => {
42
42
  const endpoint = `${this.resource}/v1.0/teams/${this.teamId}/channels/${channelId}/members`;
43
- return utils_1.odata.getAllItems(endpoint, logger);
43
+ return utils_1.odata.getAllItems(endpoint);
44
44
  })
45
45
  .then((memberships) => {
46
46
  if (args.options.role) {
@@ -135,6 +135,9 @@ class TeamsChannelMemberRemoveCommand extends GraphCommand_1.default {
135
135
  if (!channelItem) {
136
136
  return Promise.reject(`The specified channel does not exist in the Microsoft Teams team`);
137
137
  }
138
+ if (channelItem.membershipType !== "private") {
139
+ return Promise.reject(`The specified channel is not a private channel`);
140
+ }
138
141
  return Promise.resolve(channelItem.id);
139
142
  });
140
143
  }
@@ -103,6 +103,9 @@ class TeamsChannelMemberSetCommand extends GraphCommand_1.default {
103
103
  if (!channelItem) {
104
104
  return Promise.reject(`The specified channel does not exist in the Microsoft Teams team`);
105
105
  }
106
+ if (channelItem.membershipType !== "private") {
107
+ return Promise.reject(`The specified channel is not a private channel`);
108
+ }
106
109
  return Promise.resolve(channelItem.id);
107
110
  });
108
111
  }
@@ -33,7 +33,7 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
33
33
  }
34
34
  commandAction(logger, args, cb) {
35
35
  this
36
- .getChatId(logger, args)
36
+ .getChatId(args)
37
37
  .then(chatId => this.getChatDetailsById(chatId))
38
38
  .then((chat) => {
39
39
  logger.log(chat);
@@ -83,14 +83,14 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
83
83
  }
84
84
  return true;
85
85
  }
86
- getChatId(logger, args) {
86
+ getChatId(args) {
87
87
  return __awaiter(this, void 0, void 0, function* () {
88
88
  if (args.options.id) {
89
89
  return args.options.id;
90
90
  }
91
91
  return args.options.participants
92
- ? this.getChatIdByParticipants(args.options.participants, logger)
93
- : this.getChatIdByName(args.options.name, logger);
92
+ ? this.getChatIdByParticipants(args.options.participants)
93
+ : this.getChatIdByName(args.options.name);
94
94
  });
95
95
  }
96
96
  getChatDetailsById(id) {
@@ -105,11 +105,11 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
105
105
  return request_1.default.get(requestOptions);
106
106
  });
107
107
  }
108
- getChatIdByParticipants(participantsString, logger) {
108
+ getChatIdByParticipants(participantsString) {
109
109
  return __awaiter(this, void 0, void 0, function* () {
110
110
  const participants = chatUtil_1.chatUtil.convertParticipantStringToArray(participantsString);
111
111
  const currentUserEmail = accessToken_1.accessToken.getUserNameFromAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken).toLowerCase();
112
- const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...participants], logger);
112
+ const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...participants]);
113
113
  if (!existingChats || existingChats.length === 0) {
114
114
  throw new Error('No chat conversation was found with these participants.');
115
115
  }
@@ -122,9 +122,9 @@ class TeamsChatGetCommand extends GraphCommand_1.default {
122
122
  throw new Error(`Multiple chat conversations with these participants found. Please disambiguate:${os.EOL}${disambiguationText}`);
123
123
  });
124
124
  }
125
- getChatIdByName(name, logger) {
125
+ getChatIdByName(name) {
126
126
  return __awaiter(this, void 0, void 0, function* () {
127
- const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(name, logger);
127
+ const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(name);
128
128
  if (!existingChats || existingChats.length === 0) {
129
129
  throw new Error('No chat conversation was found with this name.');
130
130
  }
@@ -17,7 +17,7 @@ class TeamsChatListCommand extends GraphCommand_1.default {
17
17
  const filter = args.options.type !== undefined ? `?$filter=chatType eq '${args.options.type}'` : '';
18
18
  const endpoint = `${this.resource}/v1.0/chats${filter}`;
19
19
  utils_1.odata
20
- .getAllItems(endpoint, logger)
20
+ .getAllItems(endpoint)
21
21
  .then((items) => {
22
22
  logger.log(items);
23
23
  cb();
@@ -16,7 +16,7 @@ class TeamsChatMemberListCommand extends GraphCommand_1.default {
16
16
  commandAction(logger, args, cb) {
17
17
  const endpoint = `${this.resource}/v1.0/chats/${args.options.chatId}/members`;
18
18
  utils_1.odata
19
- .getAllItems(endpoint, logger)
19
+ .getAllItems(endpoint)
20
20
  .then((items) => {
21
21
  logger.log(items);
22
22
  cb();
@@ -16,7 +16,7 @@ class TeamsChatMessageListCommand extends GraphCommand_1.default {
16
16
  commandAction(logger, args, cb) {
17
17
  const endpoint = `${this.resource}/v1.0/chats/${args.options.chatId}/messages`;
18
18
  utils_1.odata
19
- .getAllItems(endpoint, logger)
19
+ .getAllItems(endpoint)
20
20
  .then((items) => {
21
21
  if (args.options.output !== 'json') {
22
22
  items.forEach(i => {
@@ -93,15 +93,15 @@ class TeamsChatMessageSendCommand extends GraphCommand_1.default {
93
93
  return args.options.chatId;
94
94
  }
95
95
  return args.options.userEmails
96
- ? this.ensureChatIdByUserEmails(args.options.userEmails, logger)
97
- : this.getChatIdByName(args.options.chatName, logger);
96
+ ? this.ensureChatIdByUserEmails(args.options.userEmails)
97
+ : this.getChatIdByName(args.options.chatName);
98
98
  });
99
99
  }
100
- ensureChatIdByUserEmails(userEmailsOption, logger) {
100
+ ensureChatIdByUserEmails(userEmailsOption) {
101
101
  return __awaiter(this, void 0, void 0, function* () {
102
102
  const userEmails = chatUtil_1.chatUtil.convertParticipantStringToArray(userEmailsOption);
103
103
  const currentUserEmail = utils_1.accessToken.getUserNameFromAccessToken(Auth_1.default.service.accessTokens[this.resource].accessToken).toLowerCase();
104
- const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...userEmails], logger);
104
+ const existingChats = yield chatUtil_1.chatUtil.findExistingChatsByParticipants([currentUserEmail, ...userEmails]);
105
105
  if (!existingChats || existingChats.length === 0) {
106
106
  const chat = yield this.createConversation([currentUserEmail, ...userEmails]);
107
107
  return chat.id;
@@ -115,9 +115,9 @@ class TeamsChatMessageSendCommand extends GraphCommand_1.default {
115
115
  throw new Error(`Multiple chat conversations with this name found. Please disambiguate:${os.EOL}${disambiguationText}`);
116
116
  });
117
117
  }
118
- getChatIdByName(chatName, logger) {
118
+ getChatIdByName(chatName) {
119
119
  return __awaiter(this, void 0, void 0, function* () {
120
- const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(chatName, logger);
120
+ const existingChats = yield chatUtil_1.chatUtil.findExistingGroupChatsByName(chatName);
121
121
  if (!existingChats || existingChats.length === 0) {
122
122
  throw new Error('No chat conversation was found with this name.');
123
123
  }
@@ -17,12 +17,12 @@ exports.chatUtil = {
17
17
  * @param expectedMemberEmails a string array of participant emailaddresses
18
18
  * @param logger a logger to pipe into the graph request odata helper.
19
19
  */
20
- findExistingChatsByParticipants(expectedMemberEmails, logger) {
20
+ findExistingChatsByParticipants(expectedMemberEmails) {
21
21
  return __awaiter(this, void 0, void 0, function* () {
22
22
  const chatType = expectedMemberEmails.length === 2 ? 'oneOnOne' : 'group';
23
23
  const endpoint = `https://graph.microsoft.com/v1.0/chats?$filter=chatType eq '${chatType}'&$expand=members&$select=id,topic,createdDateTime,members`;
24
24
  const foundChats = [];
25
- const chats = yield odata_1.odata.getAllItems(endpoint, logger);
25
+ const chats = yield odata_1.odata.getAllItems(endpoint);
26
26
  for (const chat of chats) {
27
27
  const chatMembers = chat.members;
28
28
  if (chatMembers.length === expectedMemberEmails.length) {
@@ -40,10 +40,10 @@ exports.chatUtil = {
40
40
  * @param name the name of the chat conversation to find
41
41
  * @param logger a logger to pipe into the graph request odata helper.
42
42
  */
43
- findExistingGroupChatsByName(name, logger) {
43
+ findExistingGroupChatsByName(name) {
44
44
  return __awaiter(this, void 0, void 0, function* () {
45
45
  const endpoint = `https://graph.microsoft.com/v1.0/chats?$filter=topic eq '${encodeURIComponent(name).replace("'", "''")}'&$expand=members&$select=id,topic,createdDateTime,chatType`;
46
- return odata_1.odata.getAllItems(endpoint, logger);
46
+ return odata_1.odata.getAllItems(endpoint);
47
47
  });
48
48
  },
49
49
  /**
@@ -17,7 +17,7 @@ class TeamsMessageListCommand extends GraphCommand_1.default {
17
17
  const deltaExtension = args.options.since !== undefined ? `/delta?$filter=lastModifiedDateTime gt ${args.options.since}` : '';
18
18
  const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${args.options.channelId}/messages${deltaExtension}`;
19
19
  utils_1.odata
20
- .getAllItems(endpoint, logger)
20
+ .getAllItems(endpoint)
21
21
  .then((items) => {
22
22
  if (args.options.output !== 'json') {
23
23
  items.forEach(i => {
@@ -16,7 +16,7 @@ class TeamsMessageReplyListCommand extends GraphCommand_1.default {
16
16
  commandAction(logger, args, cb) {
17
17
  const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${args.options.channelId}/messages/${args.options.messageId}/replies`;
18
18
  utils_1.odata
19
- .getAllItems(endpoint, logger)
19
+ .getAllItems(endpoint)
20
20
  .then((items) => {
21
21
  if (args.options.output !== 'json') {
22
22
  items.forEach(i => {
@@ -16,7 +16,7 @@ class TeamsTabListCommand extends GraphCommand_1.default {
16
16
  commandAction(logger, args, cb) {
17
17
  const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${encodeURIComponent(args.options.channelId)}/tabs?$expand=teamsApp`;
18
18
  utils_1.odata
19
- .getAllItems(endpoint, logger)
19
+ .getAllItems(endpoint)
20
20
  .then((items) => {
21
21
  items.forEach(i => {
22
22
  i.teamsAppTabId = i.teamsApp.id;
@@ -22,7 +22,7 @@ class TeamsTeamListCommand extends GraphCommand_1.default {
22
22
  endpoint = `${this.resource}/v1.0/me/joinedTeams`;
23
23
  }
24
24
  utils_1.odata
25
- .getAllItems(endpoint, logger)
25
+ .getAllItems(endpoint)
26
26
  .then((items) => {
27
27
  if (args.options.joined) {
28
28
  return Promise.resolve(items);
@@ -24,7 +24,7 @@ class TeamsUserAppListCommand extends GraphCommand_1.default {
24
24
  .then((_userId) => {
25
25
  userId = _userId.value;
26
26
  const endpoint = `${this.resource}/v1.0/users/${encodeURIComponent(userId)}/teamwork/installedApps?$expand=teamsAppDefinition`;
27
- return utils_1.odata.getAllItems(endpoint, logger);
27
+ return utils_1.odata.getAllItems(endpoint);
28
28
  })
29
29
  .then((items) => {
30
30
  items.forEach(i => {
@@ -42,7 +42,7 @@ class TeamsUserListCommand extends GraphCommand_1.default {
42
42
  }
43
43
  getOwners(logger, groupId) {
44
44
  const endpoint = `${this.resource}/v1.0/groups/${groupId}/owners?$select=id,displayName,userPrincipalName,userType`;
45
- return utils_1.odata.getAllItems(endpoint, logger).then((items) => {
45
+ return utils_1.odata.getAllItems(endpoint).then((items) => {
46
46
  this.items = this.items.concat(items);
47
47
  // Currently there is a bug in the Microsoft Graph that returns Owners as
48
48
  // userType 'member'. We therefore update all returned user as owner
@@ -53,7 +53,7 @@ class TeamsUserListCommand extends GraphCommand_1.default {
53
53
  }
54
54
  getMembersAndGuests(logger, groupId) {
55
55
  const endpoint = `${this.resource}/v1.0/groups/${groupId}/members?$select=id,displayName,userPrincipalName,userType`;
56
- return utils_1.odata.getAllItems(endpoint, logger);
56
+ return utils_1.odata.getAllItems(endpoint);
57
57
  }
58
58
  options() {
59
59
  const options = [
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const GraphCommand_1 = require("../../../base/GraphCommand");
4
+ const request_1 = require("../../../../request");
5
+ const commands_1 = require("../../commands");
6
+ class TenantSecurityAlertsListCommand extends GraphCommand_1.default {
7
+ get name() {
8
+ return commands_1.default.SECURITY_ALERTS_LIST;
9
+ }
10
+ get description() {
11
+ return 'Gets the security alerts for a tenant';
12
+ }
13
+ getTelemetryProperties(args) {
14
+ const telemetryProps = super.getTelemetryProperties(args);
15
+ telemetryProps.vendor = typeof args.options.vendor !== 'undefined';
16
+ return telemetryProps;
17
+ }
18
+ defaultProperties() {
19
+ return ['id', 'title', 'severity'];
20
+ }
21
+ commandAction(logger, args, cb) {
22
+ this
23
+ .listAlert(args.options)
24
+ .then((res) => {
25
+ logger.log(res);
26
+ cb();
27
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
28
+ }
29
+ listAlert(options) {
30
+ let queryFilter = '';
31
+ if (options.vendor) {
32
+ let vendorName = options.vendor;
33
+ switch (options.vendor.toLowerCase()) {
34
+ case 'azure security center':
35
+ vendorName = 'ASC';
36
+ break;
37
+ case 'microsoft cloud app security':
38
+ vendorName = 'MCAS';
39
+ break;
40
+ case 'azure active directory identity protection':
41
+ vendorName = 'IPC';
42
+ }
43
+ queryFilter = `?$filter=vendorInformation/provider eq '${encodeURIComponent(vendorName)}'`;
44
+ }
45
+ const requestOptions = {
46
+ url: `${this.resource}/v1.0/security/alerts${queryFilter}`,
47
+ headers: {
48
+ accept: 'application/json;odata.metadata=none'
49
+ },
50
+ responseType: 'json'
51
+ };
52
+ return request_1.default
53
+ .get(requestOptions)
54
+ .then(response => {
55
+ const alertList = response.value;
56
+ if (!alertList) {
57
+ return Promise.reject(`Error fetching security alerts`);
58
+ }
59
+ return Promise.resolve(alertList);
60
+ });
61
+ }
62
+ options() {
63
+ const options = [
64
+ { option: '--vendor [vendor]' }
65
+ ];
66
+ const parentOptions = super.options();
67
+ return options.concat(parentOptions);
68
+ }
69
+ }
70
+ module.exports = new TenantSecurityAlertsListCommand();
71
+ //# sourceMappingURL=security-alerts-list.js.map
@@ -19,7 +19,7 @@ class TenantServiceAnnouncementHealthIssueListCommand extends GraphCommand_1.def
19
19
  endpoint += `?$filter=service eq '${encodeURIComponent(args.options.service)}'`;
20
20
  }
21
21
  utils_1.odata
22
- .getAllItems(endpoint, logger)
22
+ .getAllItems(endpoint)
23
23
  .then((items) => {
24
24
  logger.log(items);
25
25
  cb();
@@ -19,7 +19,7 @@ class TenantServiceAnnouncementMessageListCommand extends GraphCommand_1.default
19
19
  endpoint += `?$filter=services/any(c:c+eq+'${encodeURIComponent(args.options.service)}')`;
20
20
  }
21
21
  utils_1.odata
22
- .getAllItems(endpoint, logger)
22
+ .getAllItems(endpoint)
23
23
  .then((items) => {
24
24
  logger.log(items);
25
25
  cb();
@@ -9,6 +9,7 @@ exports.default = {
9
9
  REPORT_OFFICE365ACTIVATIONSUSERDETAIL: `${prefix} report office365activationsuserdetail`,
10
10
  REPORT_OFFICE365ACTIVATIONSUSERCOUNTS: `${prefix} report office365activationsusercounts`,
11
11
  REPORT_SERVICESUSERCOUNTS: `${prefix} report servicesusercounts`,
12
+ SECURITY_ALERTS_LIST: `${prefix} security alerts list`,
12
13
  SERVICEANNOUNCEMENT_HEALTHISSUE_GET: `${prefix} serviceannouncement healthissue get`,
13
14
  SERVICEANNOUNCEMENT_HEALTH_GET: `${prefix} serviceannouncement health get`,
14
15
  SERVICEANNOUNCEMENT_HEALTH_LIST: `${prefix} serviceannouncement health list`,
@@ -15,7 +15,7 @@ class TodoListListCommand extends GraphCommand_1.default {
15
15
  }
16
16
  commandAction(logger, args, cb) {
17
17
  utils_1.odata
18
- .getAllItems(`${this.resource}/v1.0/me/todo/lists`, logger)
18
+ .getAllItems(`${this.resource}/v1.0/me/todo/lists`)
19
19
  .then((items) => {
20
20
  logger.log(items);
21
21
  cb();
@@ -45,7 +45,7 @@ class TodoTaskListCommand extends GraphCommand_1.default {
45
45
  .getTodoListId(args)
46
46
  .then((listId) => {
47
47
  const endpoint = `${this.resource}/v1.0/me/todo/lists/${listId}/tasks`;
48
- return utils_1.odata.getAllItems(endpoint, logger);
48
+ return utils_1.odata.getAllItems(endpoint);
49
49
  })
50
50
  .then((items) => {
51
51
  if (args.options.output === 'json') {
@@ -2,6 +2,24 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.accessToken = void 0;
4
4
  exports.accessToken = {
5
+ isAppOnlyAccessToken(accessToken) {
6
+ let isAppOnlyAccessToken = false;
7
+ if (!accessToken || accessToken.length === 0) {
8
+ return isAppOnlyAccessToken;
9
+ }
10
+ const chunks = accessToken.split('.');
11
+ if (chunks.length !== 3) {
12
+ return isAppOnlyAccessToken;
13
+ }
14
+ const tokenString = Buffer.from(chunks[1], 'base64').toString();
15
+ try {
16
+ const token = JSON.parse(tokenString);
17
+ isAppOnlyAccessToken = token.idtyp === 'app';
18
+ }
19
+ catch (_a) {
20
+ }
21
+ return isAppOnlyAccessToken;
22
+ },
5
23
  getTenantIdFromAccessToken(accessToken) {
6
24
  let tenantId = '';
7
25
  if (!accessToken || accessToken.length === 0) {
@@ -30,8 +30,9 @@ exports.formatting = {
30
30
  return JSON.parse(s.replace(/^\uFEFF/, ''));
31
31
  },
32
32
  filterObject(obj, propertiesToInclude) {
33
- return Object.keys(obj)
34
- .filter(key => propertiesToInclude.includes(key))
33
+ const objKeys = Object.keys(obj);
34
+ return propertiesToInclude
35
+ .filter(prop => objKeys.includes(prop))
35
36
  .reduce((filtered, key) => {
36
37
  filtered[key] = obj[key];
37
38
  return filtered;
@@ -64,6 +65,14 @@ exports.formatting = {
64
65
  },
65
66
  splitAndTrim(s) {
66
67
  return s.split(',').map(c => c.trim());
68
+ },
69
+ openTypesEncoder(value) {
70
+ return value
71
+ .replace(/\%/g, '%25')
72
+ .replace(/\./g, '%2E')
73
+ .replace(/:/g, '%3A')
74
+ .replace(/@/g, '%40')
75
+ .replace(/#/g, '%23');
67
76
  }
68
77
  };
69
78
  //# sourceMappingURL=formatting.js.map
@@ -12,7 +12,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.odata = void 0;
13
13
  const request_1 = require("../request");
14
14
  exports.odata = {
15
- getAllItems(url, logger, metadata) {
15
+ getAllItems(url, metadata) {
16
16
  var _a;
17
17
  return __awaiter(this, void 0, void 0, function* () {
18
18
  let items = [];
@@ -27,7 +27,7 @@ exports.odata = {
27
27
  items = res.value;
28
28
  const nextLink = (_a = res['@odata.nextLink']) !== null && _a !== void 0 ? _a : res.nextLink;
29
29
  if (nextLink) {
30
- const nextPageItems = yield exports.odata.getAllItems(nextLink, logger, metadata);
30
+ const nextPageItems = yield exports.odata.getAllItems(nextLink, metadata);
31
31
  items = items.concat(nextPageItems);
32
32
  }
33
33
  return items;
@@ -0,0 +1,65 @@
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
+ exports.planner = void 0;
13
+ const request_1 = require("../request");
14
+ const odata_1 = require("./odata");
15
+ const graphResource = 'https://graph.microsoft.com';
16
+ const getRequestOptions = (url, metadata) => ({
17
+ url: url,
18
+ headers: {
19
+ accept: `application/json;odata.metadata=${metadata}`
20
+ },
21
+ responseType: 'json'
22
+ });
23
+ exports.planner = {
24
+ /**
25
+ * Get Planner plan by ID.
26
+ * @param id Planner ID.
27
+ */
28
+ getPlanById(id) {
29
+ return __awaiter(this, void 0, void 0, function* () {
30
+ const requestOptions = getRequestOptions(`${graphResource}/v1.0/planner/plans/${id}`, 'none');
31
+ try {
32
+ return yield request_1.default.get(requestOptions);
33
+ }
34
+ catch (ex) {
35
+ throw Error(`Planner plan with id '${id}' was not found.`);
36
+ }
37
+ });
38
+ },
39
+ /**
40
+ * Get all Planner plans for a specific group.
41
+ * @param groupId Group ID.
42
+ */
43
+ getPlansByGroupId(groupId) {
44
+ return odata_1.odata.getAllItems(`${graphResource}/v1.0/groups/${groupId}/planner/plans`, 'none');
45
+ },
46
+ /**
47
+ * Get Planner plan by name in a specific group.
48
+ * @param name Name of the Planner plan. Case insensitive.
49
+ * @param groupId Owner group ID .
50
+ */
51
+ getPlanByName(name, groupId) {
52
+ return __awaiter(this, void 0, void 0, function* () {
53
+ const plans = yield this.getPlansByGroupId(groupId);
54
+ const filteredPlans = plans.filter(p => p.title && p.title.toLowerCase() === name.toLowerCase());
55
+ if (!filteredPlans.length) {
56
+ throw Error(`The specified plan '${name}' does not exist.`);
57
+ }
58
+ if (filteredPlans.length > 1) {
59
+ throw Error(`Multiple plans with name '${name}' found: ${filteredPlans.map(x => x.id)}.`);
60
+ }
61
+ return filteredPlans[0];
62
+ });
63
+ }
64
+ };
65
+ //# sourceMappingURL=planner.js.map
@@ -49,6 +49,15 @@ m365 aad app add [options]
49
49
  `--scopeAdminConsentDescription [scopeAdminConsentDescription]`
50
50
  : Scope admin consent description
51
51
 
52
+ `--certificateFile [certificateFile]`
53
+ : Path to the file with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
54
+
55
+ `--certificateBase64Encoded [certificateBase64Encoded]`
56
+ : Base64-encoded string with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
57
+
58
+ `--certificateDisplayName [certificateDisplayName]`
59
+ : Display name for the certificate. If not given, the displayName will be set to the certificate subject. When specified, also specify either `certificateFile` or `certificateBase64Encoded`
60
+
52
61
  `--manifest [manifest]`
53
62
  : Azure AD app manifest as retrieved from the Azure Portal to create the app registration from
54
63
 
@@ -152,3 +161,9 @@ Create new Azure AD app registration with the specified name. Store information
152
161
  ```sh
153
162
  m365 aad app add --name 'My AAD app' --save
154
163
  ```
164
+
165
+ Create new Azure AD app registration with a certificate
166
+
167
+ ```sh
168
+ m365 aad app add --name 'My AAD app' --certificateDisplayName "Some certificate name" --certificateFile c:\temp\some-certificate.cer
169
+ ```
@@ -31,6 +31,15 @@ m365 aad app set [options]
31
31
  `--redirectUrisToRemove [redirectUrisToRemove]`
32
32
  : Comma-separated list of existing redirect URIs to remove. Specify, when you want to replace existing redirect URIs with another
33
33
 
34
+ `--certificateFile [certificateFile]`
35
+ : Path to the file with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
36
+
37
+ `--certificateBase64Encoded [certificateBase64Encoded]`
38
+ : Base64-encoded string with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
39
+
40
+ `--certificateDisplayName [certificateDisplayName]`
41
+ : Display name for the certificate. If not given, the displayName will be set to the certificate subject. When specified, also specify either `certificateFile` or `certificateBase64Encoded`
42
+
34
43
  --8<-- "docs/cmd/_global.md"
35
44
 
36
45
  ## Remarks
@@ -39,6 +48,8 @@ For best performance use the `objectId` option to reference the Azure AD applica
39
48
 
40
49
  If the command finds multiple Azure AD application registrations with the specified app name, it will prompt you to disambiguate which app it should use, listing the discovered object IDs.
41
50
 
51
+ When a certificate is specified it will be added to the list of certificates of the app without changing existing certificates.
52
+
42
53
  ## Examples
43
54
 
44
55
  Update the app URI of the Azure AD application registration specified by its object ID
@@ -70,3 +81,9 @@ Replace one redirect URI with another for SPA authentication
70
81
  ```sh
71
82
  m365 aad app set --objectId 95cfe30d-ed44-4f9d-b73d-c66560f72e83 --redirectUris https://contoso.com/auth --platform spa --redirectUrisToRemove https://contoso.com/old-auth
72
83
  ```
84
+
85
+ Add a certificate to the app
86
+
87
+ ```sh
88
+ m365 aad app set --certificateDisplayName "Some certificate name" --certificateFile c:\temp\some-certificate.cer
89
+ ```
@@ -1,4 +1,4 @@
1
- # aad approleassignment add
1
+ # aad approleassignment remove
2
2
 
3
3
  Deletes an app role assignment for the specified Azure AD Application Registration
4
4
 
@@ -0,0 +1,45 @@
1
+ # aad app open
2
+
3
+ Returns deep link of the current AD app to open the Azure portal on the Azure AD app registration management page.
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 app open [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `--appId [appId]`
14
+ : Optional Application (client) ID of the Azure AD application registration to open. Uses the app from the `.m365rc.json` file corresponding to the `appId`. If multiple apps are available, this will evade the prompt to choose an app. If the `appId` is not available in the list of apps, an error is thrown.
15
+
16
+ `--preview`
17
+ : Use to open the url of the Azure AD preview portal.
18
+
19
+ --8<-- "docs/cmd/_global.md"
20
+
21
+ ## Remarks
22
+
23
+ If config setting `autoOpenLinksInBrowser` is configured to true, the command will automatically open the link to the Azure Portal in the browser.
24
+
25
+ Gets the app from the `.m365rc.json` file in the current directory. If the `--appId` option is not used and multiple apps are available, it will prompt the user to choose one.
26
+
27
+ ## Examples
28
+
29
+ Prints the URL to the Azure AD application registration management page on the Azure Portal.
30
+
31
+ ```sh
32
+ m365 app open
33
+ ```
34
+
35
+ Prints the url of the Azure AD application registration management page on the preview Azure Portal.
36
+
37
+ ```sh
38
+ m365 app open --preview
39
+ ```
40
+
41
+ Prints the URL to the Azure AD application registration management page on the Azure Portal, evading a possible choice prompt in the case of multiple saved apps in the `.m365rc.json` file.
42
+
43
+ ```sh
44
+ m365 app open --appId d75be2e1-0204-4f95-857d-51a37cf40be8
45
+ ```