@pnp/cli-microsoft365 7.0.0-beta.093ef31 → 7.0.0-beta.18ce559

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 (188) hide show
  1. package/README.md +4 -4
  2. package/dist/Auth.js +10 -1
  3. package/dist/Command.js +2 -2
  4. package/dist/cli/Cli.js +4 -4
  5. package/dist/m365/aad/commands/app/app-get.js +4 -1
  6. package/dist/m365/aad/commands/app/app-remove.js +3 -1
  7. package/dist/m365/aad/commands/app/app-role-add.js +4 -1
  8. package/dist/m365/aad/commands/app/app-role-list.js +4 -1
  9. package/dist/m365/aad/commands/app/app-role-remove.js +5 -2
  10. package/dist/m365/aad/commands/app/app-set.js +8 -5
  11. package/dist/m365/aad/commands/approleassignment/approleassignment-add.js +11 -6
  12. package/dist/m365/aad/commands/approleassignment/approleassignment-remove.js +4 -4
  13. package/dist/m365/aad/commands/group/group-get.js +4 -4
  14. package/dist/m365/aad/commands/group/group-list.js +1 -23
  15. package/dist/m365/aad/commands/group/group-remove.js +98 -0
  16. package/dist/m365/aad/commands/m365group/m365group-add.js +21 -12
  17. package/dist/m365/aad/commands/m365group/m365group-conversation-list.js +5 -0
  18. package/dist/m365/aad/commands/m365group/m365group-conversation-post-list.js +4 -0
  19. package/dist/m365/aad/commands/m365group/m365group-get.js +4 -3
  20. package/dist/m365/aad/commands/m365group/m365group-recyclebinitem-remove.js +3 -1
  21. package/dist/m365/aad/commands/m365group/m365group-recyclebinitem-restore.js +4 -1
  22. package/dist/m365/aad/commands/m365group/m365group-remove.js +5 -0
  23. package/dist/m365/aad/commands/m365group/m365group-renew.js +5 -0
  24. package/dist/m365/aad/commands/m365group/m365group-set.js +5 -0
  25. package/dist/m365/aad/commands/m365group/m365group-teamify.js +14 -6
  26. package/dist/m365/aad/commands/m365group/m365group-user-add.js +5 -0
  27. package/dist/m365/aad/commands/m365group/m365group-user-list.js +5 -0
  28. package/dist/m365/aad/commands/m365group/m365group-user-remove.js +5 -0
  29. package/dist/m365/aad/commands/m365group/m365group-user-set.js +5 -0
  30. package/dist/m365/aad/commands/sp/sp-add.js +4 -1
  31. package/dist/m365/aad/commands/sp/sp-get.js +4 -1
  32. package/dist/m365/aad/commands/user/user-get.js +7 -2
  33. package/dist/m365/aad/commands.js +1 -0
  34. package/dist/m365/booking/commands/business/business-get.js +4 -1
  35. package/dist/m365/commands/login.js +2 -2
  36. package/dist/m365/flow/commands/flow-export.js +13 -13
  37. package/dist/m365/graph/commands/subscription/subscription-add.js +5 -5
  38. package/dist/m365/outlook/commands/message/message-list.js +4 -2
  39. package/dist/m365/outlook/commands/message/message-move.js +4 -2
  40. package/dist/m365/pa/commands/app/app-export.js +7 -7
  41. package/dist/m365/pa/commands/connector/connector-export.js +5 -5
  42. package/dist/m365/planner/commands/bucket/bucket-add.js +4 -1
  43. package/dist/m365/planner/commands/bucket/bucket-get.js +9 -2
  44. package/dist/m365/planner/commands/bucket/bucket-list.js +4 -1
  45. package/dist/m365/planner/commands/bucket/bucket-remove.js +7 -2
  46. package/dist/m365/planner/commands/bucket/bucket-set.js +8 -2
  47. package/dist/m365/planner/commands/plan/plan-add.js +4 -1
  48. package/dist/m365/planner/commands/plan/plan-get.js +4 -1
  49. package/dist/m365/planner/commands/plan/plan-list.js +4 -1
  50. package/dist/m365/planner/commands/plan/plan-remove.js +4 -1
  51. package/dist/m365/planner/commands/plan/plan-set.js +4 -1
  52. package/dist/m365/planner/commands/roster/roster-get.js +4 -1
  53. package/dist/m365/planner/commands/roster/roster-member-add.js +4 -1
  54. package/dist/m365/planner/commands/roster/roster-member-get.js +4 -1
  55. package/dist/m365/planner/commands/roster/roster-member-list.js +4 -1
  56. package/dist/m365/planner/commands/roster/roster-member-remove.js +4 -1
  57. package/dist/m365/planner/commands/roster/roster-plan-list.js +4 -1
  58. package/dist/m365/planner/commands/roster/roster-remove.js +4 -1
  59. package/dist/m365/planner/commands/task/task-add.js +4 -1
  60. package/dist/m365/planner/commands/task/task-checklistitem-add.js +4 -1
  61. package/dist/m365/planner/commands/task/task-checklistitem-list.js +4 -1
  62. package/dist/m365/planner/commands/task/task-checklistitem-remove.js +4 -1
  63. package/dist/m365/planner/commands/task/task-get.js +11 -3
  64. package/dist/m365/planner/commands/task/task-list.js +10 -2
  65. package/dist/m365/planner/commands/task/task-reference-add.js +4 -1
  66. package/dist/m365/planner/commands/task/task-reference-list.js +4 -1
  67. package/dist/m365/planner/commands/task/task-reference-remove.js +4 -1
  68. package/dist/m365/planner/commands/task/task-remove.js +10 -4
  69. package/dist/m365/planner/commands/task/task-set.js +4 -1
  70. package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-get.js +4 -1
  71. package/dist/m365/pp/commands/card/card-get.js +3 -5
  72. package/dist/m365/pp/commands/chatbot/chatbot-get.js +3 -1
  73. package/dist/m365/pp/commands/chatbot/chatbot-list.js +2 -2
  74. package/dist/m365/pp/commands/managementapp/managementapp-add.js +4 -1
  75. package/dist/m365/search/commands/externalconnection/externalconnection-remove.js +3 -1
  76. package/dist/m365/spfx/commands/project/project-doctor/{doctor-1.18.0-beta.5.js → doctor-1.18.0.js} +2 -2
  77. package/dist/m365/spfx/commands/project/project-doctor.js +1 -1
  78. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN001022_DEP_office_ui_fabric_react.js +1 -1
  79. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002028_DEVDEP_microsoft_rush_stack_compiler_4_7.js +13 -0
  80. package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.18.0-beta.5.js → upgrade-1.18.0.js} +35 -27
  81. package/dist/m365/spfx/commands/project/project-upgrade.js +13 -15
  82. package/dist/m365/spfx/commands/spfx-doctor.js +3 -3
  83. package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-get.js +5 -3
  84. package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-remove.js +2 -2
  85. package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-set.js +3 -2
  86. package/dist/m365/spo/commands/commandset/commandset-get.js +4 -2
  87. package/dist/m365/spo/commands/commandset/commandset-remove.js +2 -1
  88. package/dist/m365/spo/commands/commandset/commandset-set.js +3 -1
  89. package/dist/m365/spo/commands/customaction/customaction-get.js +5 -2
  90. package/dist/m365/spo/commands/customaction/customaction-remove.js +3 -1
  91. package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +3 -1
  92. package/dist/m365/spo/commands/file/file-get.js +11 -8
  93. package/dist/m365/spo/commands/file/file-remove.js +2 -2
  94. package/dist/m365/spo/commands/file/file-version-clear.js +2 -2
  95. package/dist/m365/spo/commands/file/file-version-get.js +2 -2
  96. package/dist/m365/spo/commands/file/file-version-list.js +2 -2
  97. package/dist/m365/spo/commands/file/file-version-remove.js +2 -2
  98. package/dist/m365/spo/commands/file/file-version-restore.js +2 -2
  99. package/dist/m365/spo/commands/group/group-member-add.js +24 -24
  100. package/dist/m365/spo/commands/hubsite/hubsite-connect.js +7 -4
  101. package/dist/m365/spo/commands/hubsite/hubsite-disconnect.js +4 -1
  102. package/dist/m365/spo/commands/hubsite/hubsite-get.js +3 -1
  103. package/dist/m365/spo/commands/listitem/listitem-add.js +1 -0
  104. package/dist/m365/spo/commands/listitem/listitem-attachment-add.js +127 -0
  105. package/dist/m365/spo/commands/listitem/listitem-attachment-get.js +97 -0
  106. package/dist/m365/spo/commands/listitem/listitem-attachment-remove.js +121 -0
  107. package/dist/m365/spo/commands/listitem/listitem-attachment-set.js +115 -0
  108. package/dist/m365/spo/commands/listitem/listitem-set.js +3 -2
  109. package/dist/m365/spo/commands/page/clientsidepages.js +18 -0
  110. package/dist/m365/spo/commands/page/page-get.js +1 -0
  111. package/dist/m365/spo/commands/page/page-list.js +4 -3
  112. package/dist/m365/spo/commands/page/page-section-add.js +56 -21
  113. package/dist/m365/spo/commands/page/page-set.js +13 -2
  114. package/dist/m365/spo/commands/site/site-commsite-enable.js +34 -5
  115. package/dist/m365/spo/commands/site/site-list.js +5 -7
  116. package/dist/m365/spo/commands/tenant/tenant-appcatalog-add.js +1 -1
  117. package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-get.js +8 -3
  118. package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-list.js +3 -2
  119. package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-remove.js +2 -1
  120. package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-set.js +3 -2
  121. package/dist/m365/spo/commands/tenant/tenant-commandset-get.js +8 -3
  122. package/dist/m365/spo/commands/tenant/tenant-commandset-list.js +3 -2
  123. package/dist/m365/spo/commands/tenant/tenant-commandset-remove.js +3 -1
  124. package/dist/m365/spo/commands/term/term-get.js +6 -6
  125. package/dist/m365/spo/commands/user/user-get.js +10 -10
  126. package/dist/m365/spo/commands.js +4 -0
  127. package/dist/m365/teams/commands/app/app-remove.js +49 -15
  128. package/dist/m365/teams/commands/channel/channel-add.js +5 -1
  129. package/dist/m365/teams/commands/channel/channel-member-add.js +12 -10
  130. package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -1
  131. package/dist/m365/teams/commands/channel/channel-member-set.js +4 -1
  132. package/dist/m365/teams/commands/chat/chat-get.js +7 -10
  133. package/dist/m365/teams/commands/chat/chat-message-send.js +8 -10
  134. package/dist/m365/teams/commands/team/team-clone.js +5 -10
  135. package/dist/m365/teams/commands/team/team-list.js +94 -30
  136. package/dist/m365/tenant/commands/info/info-get.js +83 -0
  137. package/dist/m365/tenant/commands.js +1 -0
  138. package/dist/utils/aadGroup.js +21 -3
  139. package/dist/utils/formatting.js +7 -0
  140. package/dist/utils/powerPlatform.js +1 -1
  141. package/docs/docs/_clisettings.mdx +1 -1
  142. package/docs/docs/cmd/aad/app/app-set.mdx +15 -15
  143. package/docs/docs/cmd/aad/approleassignment/approleassignment-add.mdx +9 -9
  144. package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.mdx +10 -10
  145. package/docs/docs/cmd/aad/group/group-get.mdx +5 -5
  146. package/docs/docs/cmd/aad/group/group-list.mdx +0 -11
  147. package/docs/docs/cmd/aad/group/group-remove.mdx +44 -0
  148. package/docs/docs/cmd/aad/m365group/m365group-add.mdx +13 -3
  149. package/docs/docs/cmd/aad/policy/policy-list.mdx +5 -5
  150. package/docs/docs/cmd/cli/config/config-list.mdx +1 -1
  151. package/docs/docs/cmd/flow/flow-export.mdx +11 -11
  152. package/docs/docs/cmd/graph/subscription/subscription-add.mdx +10 -10
  153. package/docs/docs/cmd/pa/app/app-export.mdx +5 -5
  154. package/docs/docs/cmd/pa/connector/connector-export.mdx +3 -3
  155. package/docs/docs/cmd/pp/chatbot/chatbot-list.mdx +4 -4
  156. package/docs/docs/cmd/pp/solution/solution-publisher-get.mdx +2 -2
  157. package/docs/docs/cmd/pp/solution/solution-publisher-remove.mdx +2 -2
  158. package/docs/docs/cmd/spfx/project/project-upgrade.mdx +1 -1
  159. package/docs/docs/cmd/spo/file/file-get.mdx +2 -2
  160. package/docs/docs/cmd/spo/file/file-remove.mdx +2 -2
  161. package/docs/docs/cmd/spo/file/file-version-clear.mdx +2 -2
  162. package/docs/docs/cmd/spo/file/file-version-get.mdx +2 -2
  163. package/docs/docs/cmd/spo/file/file-version-list.mdx +2 -2
  164. package/docs/docs/cmd/spo/file/file-version-remove.mdx +2 -2
  165. package/docs/docs/cmd/spo/file/file-version-restore.mdx +2 -2
  166. package/docs/docs/cmd/spo/group/group-member-add.mdx +27 -27
  167. package/docs/docs/cmd/spo/list/list-contenttype-remove.mdx +1 -1
  168. package/docs/docs/cmd/spo/listitem/listitem-add.mdx +2 -5
  169. package/docs/docs/cmd/spo/listitem/listitem-attachment-add.mdx +110 -0
  170. package/docs/docs/cmd/spo/listitem/listitem-attachment-get.mdx +104 -0
  171. package/docs/docs/cmd/spo/listitem/listitem-attachment-remove.mdx +58 -0
  172. package/docs/docs/cmd/spo/listitem/listitem-attachment-set.mdx +58 -0
  173. package/docs/docs/cmd/spo/listitem/listitem-set.mdx +2 -5
  174. package/docs/docs/cmd/spo/page/page-get.mdx +0 -1
  175. package/docs/docs/cmd/spo/page/page-list.mdx +0 -1
  176. package/docs/docs/cmd/spo/page/page-section-add.mdx +25 -1
  177. package/docs/docs/cmd/spo/page/page-set.mdx +23 -0
  178. package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +11 -2
  179. package/docs/docs/cmd/spo/tenant/tenant-applicationcustomizer-list.mdx +2 -4
  180. package/docs/docs/cmd/spo/tenant/tenant-commandset-list.mdx +2 -4
  181. package/docs/docs/cmd/spo/user/user-get.mdx +8 -8
  182. package/docs/docs/cmd/teams/app/app-remove.mdx +9 -6
  183. package/docs/docs/cmd/teams/channel/channel-member-add.mdx +4 -4
  184. package/docs/docs/cmd/teams/team/team-clone.mdx +3 -3
  185. package/docs/docs/cmd/teams/team/team-list.mdx +47 -22
  186. package/docs/docs/cmd/tenant/info/info-get.mdx +101 -0
  187. package/npm-shrinkwrap.json +24 -24
  188. package/package.json +8 -12
@@ -3,7 +3,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
3
3
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
- var _SpoSiteCommSiteEnableCommand_instances, _SpoSiteCommSiteEnableCommand_initTelemetry, _SpoSiteCommSiteEnableCommand_initOptions, _SpoSiteCommSiteEnableCommand_initValidators;
6
+ var _SpoSiteCommSiteEnableCommand_instances, _SpoSiteCommSiteEnableCommand_initTelemetry, _SpoSiteCommSiteEnableCommand_initOptions, _SpoSiteCommSiteEnableCommand_initOptionSets, _SpoSiteCommSiteEnableCommand_initValidators;
7
7
  import request from '../../../../request.js';
8
8
  import { validation } from '../../../../utils/validation.js';
9
9
  import SpoCommand from '../../../base/SpoCommand.js';
@@ -21,11 +21,12 @@ class SpoSiteCommSiteEnableCommand extends SpoCommand {
21
21
  __classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initTelemetry).call(this);
22
22
  __classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initOptions).call(this);
23
23
  __classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initValidators).call(this);
24
+ __classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initOptionSets).call(this);
24
25
  }
25
26
  async commandAction(logger, args) {
26
- const designPackageId = args.options.designPackageId || '96c933ac-3698-44c7-9f4a-5fd17d71af9e';
27
+ const designPackageId = this.getDesignPackageId(args.options);
27
28
  if (this.verbose) {
28
- logger.logToStderr(`Enabling communication site at ${args.options.url}...`);
29
+ logger.logToStderr(`Enabling communication site with design package '${designPackageId}' at '${args.options.url}'...`);
29
30
  }
30
31
  try {
31
32
  const requestOptions = {
@@ -42,11 +43,26 @@ class SpoSiteCommSiteEnableCommand extends SpoCommand {
42
43
  this.handleRejectedODataJsonPromise(err);
43
44
  }
44
45
  }
46
+ getDesignPackageId(options) {
47
+ if (options.designPackageId) {
48
+ return options.designPackageId;
49
+ }
50
+ switch (options.designPackage) {
51
+ case 'Blank':
52
+ return 'f6cc5403-0d63-442e-96c0-285923709ffc';
53
+ case 'Showcase':
54
+ return '6142d2a0-63a5-4ba0-aede-d9fefca2c767';
55
+ case 'Topic':
56
+ default:
57
+ return '96c933ac-3698-44c7-9f4a-5fd17d71af9e';
58
+ }
59
+ }
45
60
  }
46
61
  _SpoSiteCommSiteEnableCommand_instances = new WeakSet(), _SpoSiteCommSiteEnableCommand_initTelemetry = function _SpoSiteCommSiteEnableCommand_initTelemetry() {
47
62
  this.telemetry.push((args) => {
48
63
  Object.assign(this.telemetryProperties, {
49
- designPackageId: typeof args.options.designPackageId !== 'undefined'
64
+ designPackageId: typeof args.options.designPackageId !== 'undefined',
65
+ designPackage: typeof args.options.designPackage !== 'undefined'
50
66
  });
51
67
  });
52
68
  }, _SpoSiteCommSiteEnableCommand_initOptions = function _SpoSiteCommSiteEnableCommand_initOptions() {
@@ -54,12 +70,25 @@ _SpoSiteCommSiteEnableCommand_instances = new WeakSet(), _SpoSiteCommSiteEnableC
54
70
  option: '-u, --url <url>'
55
71
  }, {
56
72
  option: '-i, --designPackageId [designPackageId]'
73
+ }, {
74
+ option: '-p, --designPackage [designPackage]',
75
+ autocomplete: ["Topic", "Showcase", "Blank"]
76
+ });
77
+ }, _SpoSiteCommSiteEnableCommand_initOptionSets = function _SpoSiteCommSiteEnableCommand_initOptionSets() {
78
+ this.optionSets.push({
79
+ options: ['designPackageId', 'designPackage'],
80
+ runsWhen: (args) => args.options.designPackageId || args.options.designPackage
57
81
  });
58
82
  }, _SpoSiteCommSiteEnableCommand_initValidators = function _SpoSiteCommSiteEnableCommand_initValidators() {
59
83
  this.validators.push(async (args) => {
60
84
  if (args.options.designPackageId &&
61
85
  !validation.isValidGuid(args.options.designPackageId)) {
62
- return `${args.options.designPackageId} is not a valid GUID`;
86
+ return `${args.options.designPackageId} is not a valid GUID.`;
87
+ }
88
+ if (args.options.designPackage) {
89
+ if (['Topic', 'Showcase', 'Blank'].indexOf(args.options.designPackage) === -1) {
90
+ return `${args.options.designPackage} is not a valid designPackage. Allowed values are Topic|Showcase|Blank`;
91
+ }
63
92
  }
64
93
  return validation.isValidSharePointUrl(args.options.url);
65
94
  });
@@ -54,16 +54,14 @@ class SpoSiteListCommand extends SpoCommand {
54
54
  },
55
55
  data: requestBody
56
56
  };
57
- const res1 = await request.post(requestOptions);
58
- const json = JSON.parse(res1);
59
- const response = json[0];
60
- logger.log(response);
61
- if (response.ErrorInfo) {
62
- throw response.ErrorInfo.ErrorMessage;
57
+ const response = await request.post(requestOptions);
58
+ const json = JSON.parse(response);
59
+ const responseContent = json[0];
60
+ if (responseContent.ErrorInfo) {
61
+ throw responseContent.ErrorInfo.ErrorMessage;
63
62
  }
64
63
  else {
65
64
  const sites = json[json.length - 1];
66
- logger.log(sites);
67
65
  this.allSites.push(...sites._Child_Items_);
68
66
  if (sites.NextStartIndexFromSharePoint) {
69
67
  await this.getAllSites(spoAdminUrl, filter, sites.NextStartIndexFromSharePoint, personalSite, webTemplate, formDigest, logger);
@@ -75,7 +75,7 @@ class SpoTenantAppCatalogAddCommand extends SpoCommand {
75
75
  url: url,
76
76
  skipRecycleBin: true,
77
77
  wait: true,
78
- confirm: true,
78
+ force: true,
79
79
  verbose: this.verbose,
80
80
  debug: this.debug
81
81
  };
@@ -11,6 +11,7 @@ import { urlUtil } from '../../../../utils/urlUtil.js';
11
11
  import { validation } from '../../../../utils/validation.js';
12
12
  import SpoCommand from '../../../base/SpoCommand.js';
13
13
  import commands from '../../commands.js';
14
+ import { Cli } from '../../../../cli/Cli.js';
14
15
  class SpoTenantApplicationCustomizerGetCommand extends SpoCommand {
15
16
  get name() {
16
17
  return commands.TENANT_APPLICATIONCUSTOMIZER_GET;
@@ -48,11 +49,15 @@ class SpoTenantApplicationCustomizerGetCommand extends SpoCommand {
48
49
  if (listItemInstances.length === 0) {
49
50
  throw 'The specified application customizer was not found';
50
51
  }
52
+ listItemInstances.forEach(v => delete v['ID']);
51
53
  if (listItemInstances.length > 1) {
52
- throw `Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found. Please disambiguate (IDs): ${listItemInstances.map(item => item.GUID).join(', ')}`;
54
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
55
+ const result = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
56
+ await logger.log(result);
57
+ }
58
+ else {
59
+ await logger.log(listItemInstances[0]);
53
60
  }
54
- listItemInstances.forEach(v => delete v['ID']);
55
- await logger.log(listItemInstances[0]);
56
61
  }
57
62
  else {
58
63
  throw 'The specified application customizer was not found';
@@ -22,8 +22,9 @@ class SpoTenantApplicationCustomizerListCommand extends SpoCommand {
22
22
  }
23
23
  const listServerRelativeUrl = urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
24
24
  try {
25
- const response = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=TenantWideExtensionLocation eq 'ClientSideExtension.ApplicationCustomizer'`);
26
- await logger.log(response);
25
+ const listItems = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=TenantWideExtensionLocation eq 'ClientSideExtension.ApplicationCustomizer'`);
26
+ listItems.forEach(i => delete i.ID);
27
+ await logger.log(listItems);
27
28
  }
28
29
  catch (err) {
29
30
  this.handleRejectedODataJsonPromise(err);
@@ -66,7 +66,8 @@ class SpoTenantApplicationCustomizerRemoveCommand extends SpoCommand {
66
66
  throw 'The specified application customizer was not found';
67
67
  }
68
68
  if (listItemInstances.length > 1) {
69
- throw `Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found. Please disambiguate (IDs): ${listItemInstances.map(item => item.Id).join(', ')}`;
69
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
70
+ listItemInstances[0] = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
70
71
  }
71
72
  return listItemInstances[0].Id;
72
73
  }
@@ -4,7 +4,6 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
6
  var _SpoTenantApplicationCustomizerSetCommand_instances, _SpoTenantApplicationCustomizerSetCommand_initTelemetry, _SpoTenantApplicationCustomizerSetCommand_initOptions, _SpoTenantApplicationCustomizerSetCommand_initValidators, _SpoTenantApplicationCustomizerSetCommand_initOptionSets;
7
- import os from 'os';
8
7
  import { Cli } from '../../../../cli/Cli.js';
9
8
  import request from '../../../../request.js';
10
9
  import { formatting } from '../../../../utils/formatting.js';
@@ -69,7 +68,9 @@ class SpoTenantApplicationCustomizerSetCommand extends SpoCommand {
69
68
  throw 'The specified application customizer was not found';
70
69
  }
71
70
  if (listItemInstances.length > 1) {
72
- throw `Multiple application customizers with ${title ? `title '${title}'` : `ClientSideComponentId '${clientSideComponentId}'`} found. Please disambiguate using IDs: ${os.EOL}${listItemInstances.map(item => `- ${item.Id}`).join(os.EOL)}`;
71
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
72
+ const result = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${title ? `title '${title}'` : `ClientSideComponentId '${clientSideComponentId}'`} found.`, resultAsKeyValuePair);
73
+ return result.Id;
73
74
  }
74
75
  return listItemInstances[0].Id;
75
76
  }
@@ -4,6 +4,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
6
  var _SpoTenantCommandSetGetCommand_instances, _SpoTenantCommandSetGetCommand_initTelemetry, _SpoTenantCommandSetGetCommand_initOptions, _SpoTenantCommandSetGetCommand_initValidators, _SpoTenantCommandSetGetCommand_initOptionSets;
7
+ import { Cli } from '../../../../cli/Cli.js';
7
8
  import { CommandError } from '../../../../Command.js';
8
9
  import request from '../../../../request.js';
9
10
  import { formatting } from '../../../../utils/formatting.js';
@@ -53,11 +54,15 @@ class SpoTenantCommandSetGetCommand extends SpoCommand {
53
54
  try {
54
55
  const listItemInstances = await request.get(reqOptions);
55
56
  if (listItemInstances?.value.length > 0) {
57
+ listItemInstances.value.forEach(v => delete v['ID']);
56
58
  if (listItemInstances.value.length > 1) {
57
- throw `Multiple ListView Command Sets with ${args.options.title || args.options.clientSideComponentId} were found. Please disambiguate (IDs): ${listItemInstances.value.map(item => item.Id).join(', ')}`;
59
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances.value);
60
+ const result = await Cli.handleMultipleResultsFound(`Multiple ListView Command Sets with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
61
+ await logger.log(result);
62
+ }
63
+ else {
64
+ await logger.log(listItemInstances.value[0]);
58
65
  }
59
- listItemInstances.value.forEach(v => delete v['ID']);
60
- await logger.log(listItemInstances.value[0]);
61
66
  }
62
67
  else {
63
68
  throw 'The specified ListView Command Set was not found';
@@ -25,8 +25,9 @@ class SpoTenantCommandSetListCommand extends SpoCommand {
25
25
  }
26
26
  const listServerRelativeUrl = urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
27
27
  try {
28
- const response = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=startswith(TenantWideExtensionLocation, 'ClientSideExtension.ListViewCommandSet')`);
29
- await logger.log(response);
28
+ const listItems = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=startswith(TenantWideExtensionLocation, 'ClientSideExtension.ListViewCommandSet')`);
29
+ listItems.forEach(i => delete i.ID);
30
+ await logger.log(listItems);
30
31
  }
31
32
  catch (err) {
32
33
  this.handleRejectedODataJsonPromise(err);
@@ -90,7 +90,9 @@ class SpoTenantCommandSetRemoveCommand extends SpoCommand {
90
90
  throw 'The specified command set was not found';
91
91
  }
92
92
  if (listItemInstances.length > 1) {
93
- throw `Multiple command sets with ${args.options.title || args.options.clientSideComponentId} were found. Please disambiguate (IDs): ${listItemInstances.map(item => item.Id).join(', ')}`;
93
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
94
+ const result = await Cli.handleMultipleResultsFound(`Multiple command sets with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
95
+ return result.Id;
94
96
  }
95
97
  return listItemInstances[0].Id;
96
98
  }
@@ -4,7 +4,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
6
  var _SpoTermGetCommand_instances, _SpoTermGetCommand_initTelemetry, _SpoTermGetCommand_initOptions, _SpoTermGetCommand_initValidators, _SpoTermGetCommand_initOptionSets;
7
- import os from 'os';
7
+ import { Cli } from '../../../../cli/Cli.js';
8
8
  import config from '../../../../config.js';
9
9
  import request from '../../../../request.js';
10
10
  import { formatting } from '../../../../utils/formatting.js';
@@ -52,12 +52,12 @@ class SpoTermGetCommand extends SpoCommand {
52
52
  throw `Term with name '${args.options.name}' could not be found.`;
53
53
  }
54
54
  if (terms._Child_Items_.length > 1) {
55
- const disambiguationText = terms._Child_Items_.map(c => {
56
- return `- ${this.getTermId(c.Id)} - ${c.PathOfTerm}`;
57
- }).join(os.EOL);
58
- throw new Error(`Multiple terms with the specific term name found. Please disambiguate:${os.EOL}${disambiguationText}`);
55
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', terms._Child_Items_);
56
+ term = await Cli.handleMultipleResultsFound(`Multiple terms with the specific term name found.`, resultAsKeyValuePair);
57
+ }
58
+ else {
59
+ term = terms._Child_Items_[0];
59
60
  }
60
- term = terms._Child_Items_[0];
61
61
  }
62
62
  else {
63
63
  term = csomResponse;
@@ -26,23 +26,23 @@ class SpoUserGetCommand extends SpoCommand {
26
26
  }
27
27
  async commandAction(logger, args) {
28
28
  if (this.verbose) {
29
- await logger.logToStderr(`Retrieving information for list in site at ${args.options.webUrl}...`);
29
+ await logger.logToStderr(`Retrieving information for user in site '${args.options.webUrl}'...`);
30
30
  }
31
31
  let requestUrl = '';
32
32
  if (args.options.id) {
33
- requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetById('${formatting.encodeQueryParameter(args.options.id)}')`;
33
+ requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetById('${formatting.encodeQueryParameter(args.options.id.toString())}')`;
34
34
  }
35
35
  else if (args.options.email) {
36
36
  requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByEmail('${formatting.encodeQueryParameter(args.options.email)}')`;
37
37
  }
38
- else if (args.options.userName) {
39
- requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.userName)}')`;
38
+ else if (args.options.loginName) {
39
+ requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.loginName)}')`;
40
40
  }
41
41
  const requestOptions = {
42
42
  url: requestUrl,
43
43
  method: 'GET',
44
44
  headers: {
45
- 'accept': 'application/json;odata=nometadata'
45
+ accept: 'application/json;odata=nometadata'
46
46
  },
47
47
  responseType: 'json'
48
48
  };
@@ -58,9 +58,9 @@ class SpoUserGetCommand extends SpoCommand {
58
58
  _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry = function _SpoUserGetCommand_initTelemetry() {
59
59
  this.telemetry.push((args) => {
60
60
  Object.assign(this.telemetryProperties, {
61
- id: (!(!args.options.id)).toString(),
62
- email: (!(!args.options.email)).toString(),
63
- userName: (!(!args.options.userName)).toString()
61
+ id: typeof args.options.id !== 'undefined',
62
+ email: typeof args.options.email !== 'undefined',
63
+ loginName: typeof args.options.loginName !== 'undefined'
64
64
  });
65
65
  });
66
66
  }, _SpoUserGetCommand_initOptions = function _SpoUserGetCommand_initOptions() {
@@ -71,7 +71,7 @@ _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry =
71
71
  }, {
72
72
  option: '--email [email]'
73
73
  }, {
74
- option: '--userName [userName]'
74
+ option: '--loginName [loginName]'
75
75
  });
76
76
  }, _SpoUserGetCommand_initValidators = function _SpoUserGetCommand_initValidators() {
77
77
  this.validators.push(async (args) => {
@@ -82,7 +82,7 @@ _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry =
82
82
  return validation.isValidSharePointUrl(args.options.webUrl);
83
83
  });
84
84
  }, _SpoUserGetCommand_initOptionSets = function _SpoUserGetCommand_initOptionSets() {
85
- this.optionSets.push({ options: ['id', 'email', 'userName'] });
85
+ this.optionSets.push({ options: ['id', 'email', 'loginName'] });
86
86
  };
87
87
  export default new SpoUserGetCommand();
88
88
  //# sourceMappingURL=user-get.js.map
@@ -156,7 +156,11 @@ export default {
156
156
  LIST_WEBHOOK_REMOVE: `${prefix} list webhook remove`,
157
157
  LIST_WEBHOOK_SET: `${prefix} list webhook set`,
158
158
  LISTITEM_ADD: `${prefix} listitem add`,
159
+ LISTITEM_ATTACHMENT_ADD: `${prefix} listitem attachment add`,
160
+ LISTITEM_ATTACHMENT_GET: `${prefix} listitem attachment get`,
159
161
  LISTITEM_ATTACHMENT_LIST: `${prefix} listitem attachment list`,
162
+ LISTITEM_ATTACHMENT_REMOVE: `${prefix} listitem attachment remove`,
163
+ LISTITEM_ATTACHMENT_SET: `${prefix} listitem attachment set`,
160
164
  LISTITEM_BATCH_ADD: `${prefix} listitem batch add`,
161
165
  LISTITEM_BATCH_SET: `${prefix} listitem batch set`,
162
166
  LISTITEM_GET: `${prefix} listitem get`,
@@ -3,9 +3,10 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
3
3
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
- var _TeamsAppRemoveCommand_instances, _TeamsAppRemoveCommand_initTelemetry, _TeamsAppRemoveCommand_initOptions, _TeamsAppRemoveCommand_initValidators;
6
+ var _TeamsAppRemoveCommand_instances, _TeamsAppRemoveCommand_initTelemetry, _TeamsAppRemoveCommand_initOptions, _TeamsAppRemoveCommand_initValidators, _TeamsAppRemoveCommand_initOptionSets;
7
7
  import { Cli } from '../../../../cli/Cli.js';
8
8
  import request from '../../../../request.js';
9
+ import { formatting } from '../../../../utils/formatting.js';
9
10
  import { validation } from '../../../../utils/validation.js';
10
11
  import GraphCommand from '../../../base/GraphCommand.js';
11
12
  import commands from '../../commands.js';
@@ -22,20 +23,21 @@ class TeamsAppRemoveCommand extends GraphCommand {
22
23
  __classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initTelemetry).call(this);
23
24
  __classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initOptions).call(this);
24
25
  __classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initValidators).call(this);
26
+ __classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initOptionSets).call(this);
25
27
  }
26
28
  async commandAction(logger, args) {
27
- const { id: appId } = args.options;
28
29
  const removeApp = async () => {
29
- if (this.verbose) {
30
- await logger.logToStderr(`Removing app with ID ${args.options.id}`);
31
- }
32
- const requestOptions = {
33
- url: `${this.resource}/v1.0/appCatalogs/teamsApps/${appId}`,
34
- headers: {
35
- accept: 'application/json;odata.metadata=none'
36
- }
37
- };
38
30
  try {
31
+ const appId = await this.getAppId(args.options, logger);
32
+ if (this.verbose) {
33
+ await logger.logToStderr(`Removing app with ID ${appId}`);
34
+ }
35
+ const requestOptions = {
36
+ url: `${this.resource}/v1.0/appCatalogs/teamsApps/${appId}`,
37
+ headers: {
38
+ accept: 'application/json;odata.metadata=none'
39
+ }
40
+ };
39
41
  await request.delete(requestOptions);
40
42
  }
41
43
  catch (err) {
@@ -50,33 +52,65 @@ class TeamsAppRemoveCommand extends GraphCommand {
50
52
  type: 'confirm',
51
53
  name: 'continue',
52
54
  default: false,
53
- message: `Are you sure you want to remove the Teams app ${appId} from the app catalog?`
55
+ message: `Are you sure you want to remove the Teams app ${args.options.id || args.options.name} from the app catalog?`
54
56
  });
55
57
  if (result.continue) {
56
58
  await removeApp();
57
59
  }
58
60
  }
59
61
  }
62
+ async getAppId(options, logger) {
63
+ if (options.id) {
64
+ return options.id;
65
+ }
66
+ if (this.verbose) {
67
+ await logger.logToStderr(`Retrieving app Id...`);
68
+ }
69
+ const requestOptions = {
70
+ url: `${this.resource}/v1.0/appCatalogs/teamsApps?$filter=displayName eq '${formatting.encodeQueryParameter(options.name)}'&$select=id`,
71
+ headers: {
72
+ accept: 'application/json;odata.metadata=none'
73
+ },
74
+ responseType: 'json'
75
+ };
76
+ const response = await request.get(requestOptions);
77
+ const app = response.value[0];
78
+ if (!app) {
79
+ throw `The specified Teams app does not exist`;
80
+ }
81
+ if (response.value.length > 1) {
82
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
83
+ const result = await Cli.handleMultipleResultsFound(`Multiple Teams apps with name '${options.name}' found.`, resultAsKeyValuePair);
84
+ return result.id;
85
+ }
86
+ return app.id;
87
+ }
60
88
  }
61
89
  _TeamsAppRemoveCommand_instances = new WeakSet(), _TeamsAppRemoveCommand_initTelemetry = function _TeamsAppRemoveCommand_initTelemetry() {
62
90
  this.telemetry.push((args) => {
63
91
  Object.assign(this.telemetryProperties, {
64
- force: (!(!args.options.force)).toString()
92
+ force: (!(!args.options.force)).toString(),
93
+ id: typeof args.options.id !== 'undefined',
94
+ name: typeof args.options.name !== 'undefined'
65
95
  });
66
96
  });
67
97
  }, _TeamsAppRemoveCommand_initOptions = function _TeamsAppRemoveCommand_initOptions() {
68
98
  this.options.unshift({
69
- option: '-i, --id <id>'
99
+ option: '-i, --id [id]'
100
+ }, {
101
+ option: '-n, --name [name]'
70
102
  }, {
71
103
  option: '-f, --force'
72
104
  });
73
105
  }, _TeamsAppRemoveCommand_initValidators = function _TeamsAppRemoveCommand_initValidators() {
74
106
  this.validators.push(async (args) => {
75
- if (!validation.isValidGuid(args.options.id)) {
107
+ if (args.options.id && !validation.isValidGuid(args.options.id)) {
76
108
  return `${args.options.id} is not a valid GUID`;
77
109
  }
78
110
  return true;
79
111
  });
112
+ }, _TeamsAppRemoveCommand_initOptionSets = function _TeamsAppRemoveCommand_initOptionSets() {
113
+ this.optionSets.push({ options: ['id', 'name'] });
80
114
  };
81
115
  export default new TeamsAppRemoveCommand();
82
116
  //# sourceMappingURL=app-remove.js.map
@@ -8,6 +8,8 @@ import request from '../../../../request.js';
8
8
  import { validation } from '../../../../utils/validation.js';
9
9
  import GraphCommand from "../../../base/GraphCommand.js";
10
10
  import commands from '../../commands.js';
11
+ import { Cli } from '../../../../cli/Cli.js';
12
+ import { formatting } from '../../../../utils/formatting.js';
11
13
  class TeamsChannelAddCommand extends GraphCommand {
12
14
  get name() {
13
15
  return commands.CHANNEL_ADD;
@@ -42,7 +44,9 @@ class TeamsChannelAddCommand extends GraphCommand {
42
44
  throw `The specified team does not exist in the Microsoft Teams`;
43
45
  }
44
46
  if (matchingTeams.length > 1) {
45
- throw `Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${matchingTeams.join(', ')}`;
47
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
48
+ const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams teams with name ${args.options.teamName} found.`, resultAsKeyValuePair);
49
+ return result.id;
46
50
  }
47
51
  return matchingTeams[0];
48
52
  }
@@ -4,13 +4,13 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
6
  var _TeamsChannelMemberAddCommand_instances, _TeamsChannelMemberAddCommand_initTelemetry, _TeamsChannelMemberAddCommand_initOptions, _TeamsChannelMemberAddCommand_initValidators, _TeamsChannelMemberAddCommand_initOptionSets;
7
- import os from 'os';
8
7
  import request from '../../../../request.js';
9
8
  import { aadGroup } from '../../../../utils/aadGroup.js';
10
9
  import { formatting } from '../../../../utils/formatting.js';
11
10
  import { validation } from '../../../../utils/validation.js';
12
11
  import GraphCommand from '../../../base/GraphCommand.js';
13
12
  import commands from '../../commands.js';
13
+ import { Cli } from '../../../../cli/Cli.js';
14
14
  class TeamsChannelMemberAddCommand extends GraphCommand {
15
15
  get name() {
16
16
  return commands.CHANNEL_MEMBER_ADD;
@@ -91,11 +91,11 @@ class TeamsChannelMemberAddCommand extends GraphCommand {
91
91
  return channelItem.id;
92
92
  }
93
93
  async getUserId(args) {
94
- if (args.options.userId) {
95
- return args.options.userId.split(',').map(u => u.trim());
94
+ if (args.options.userIds) {
95
+ return args.options.userIds.split(',').map(u => u.trim());
96
96
  }
97
97
  const tasks = [];
98
- const userDisplayNames = args.options.userDisplayName && args.options.userDisplayName.split(',').map(u => u.trim());
98
+ const userDisplayNames = args.options.userDisplayNames && args.options.userDisplayNames.split(',').map(u => u.trim());
99
99
  for (const userName of userDisplayNames) {
100
100
  tasks.push(this.getSingleUser(userName));
101
101
  }
@@ -115,7 +115,9 @@ class TeamsChannelMemberAddCommand extends GraphCommand {
115
115
  throw `The specified user '${userDisplayName}' does not exist`;
116
116
  }
117
117
  if (response.value.length > 1) {
118
- throw `Multiple users with display name '${userDisplayName}' found. Please disambiguate:${os.EOL}${response.value.map(x => `- ${x.id}`).join(os.EOL)}`;
118
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
119
+ const result = await Cli.handleMultipleResultsFound(`Multiple users with display name '${userDisplayName}' found.`, resultAsKeyValuePair);
120
+ return result.id;
119
121
  }
120
122
  return userItem.id;
121
123
  }
@@ -127,8 +129,8 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
127
129
  teamName: typeof args.options.teamName !== 'undefined',
128
130
  channelId: typeof args.options.channelId !== 'undefined',
129
131
  channelName: typeof args.options.channelName !== 'undefined',
130
- userId: typeof args.options.userId !== 'undefined',
131
- userDisplayName: typeof args.options.userDisplayName !== 'undefined',
132
+ userIds: typeof args.options.userIds !== 'undefined',
133
+ userDisplayNames: typeof args.options.userDisplayNames !== 'undefined',
132
134
  owner: args.options.owner
133
135
  });
134
136
  });
@@ -142,9 +144,9 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
142
144
  }, {
143
145
  option: '--channelName [channelName]'
144
146
  }, {
145
- option: '--userId [userId]'
147
+ option: '--userIds [userIds]'
146
148
  }, {
147
- option: '--userDisplayName [userDisplayName]'
149
+ option: '--userDisplayNames [userDisplayNames]'
148
150
  }, {
149
151
  option: '--owner'
150
152
  });
@@ -159,7 +161,7 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
159
161
  return true;
160
162
  });
161
163
  }, _TeamsChannelMemberAddCommand_initOptionSets = function _TeamsChannelMemberAddCommand_initOptionSets() {
162
- this.optionSets.push({ options: ['teamId', 'teamName'] }, { options: ['channelId', 'channelName'] }, { options: ['userId', 'userDisplayName'] });
164
+ this.optionSets.push({ options: ['teamId', 'teamName'] }, { options: ['channelId', 'channelName'] }, { options: ['userIds', 'userDisplayNames'] });
163
165
  };
164
166
  export default new TeamsChannelMemberAddCommand();
165
167
  //# sourceMappingURL=channel-member-add.js.map
@@ -123,7 +123,9 @@ class TeamsChannelMemberRemoveCommand extends GraphCommand {
123
123
  throw 'The specified member does not exist in the Microsoft Teams channel';
124
124
  }
125
125
  if (conversationMembers.length > 1) {
126
- throw `Multiple Microsoft Teams channel members with name ${args.options.userName} found: ${response.value.map(x => x.userId)}`;
126
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', conversationMembers);
127
+ const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams channel members with name ${args.options.userName} found.`, resultAsKeyValuePair);
128
+ return result.id;
127
129
  }
128
130
  return conversationMember.id;
129
131
  }
@@ -10,6 +10,7 @@ import { formatting } from '../../../../utils/formatting.js';
10
10
  import { validation } from '../../../../utils/validation.js';
11
11
  import GraphCommand from '../../../base/GraphCommand.js';
12
12
  import commands from '../../commands.js';
13
+ import { Cli } from '../../../../cli/Cli.js';
13
14
  class TeamsChannelMemberSetCommand extends GraphCommand {
14
15
  get name() {
15
16
  return commands.CHANNEL_MEMBER_SET;
@@ -101,7 +102,9 @@ class TeamsChannelMemberSetCommand extends GraphCommand {
101
102
  throw 'The specified member does not exist in the Microsoft Teams channel';
102
103
  }
103
104
  if (conversationMembers.length > 1) {
104
- throw `Multiple Microsoft Teams channel members with name ${args.options.userName} found: ${response.value.map(x => x.userId)}`;
105
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', conversationMembers);
106
+ const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams channel members with name ${args.options.userName} found.`, resultAsKeyValuePair);
107
+ return result.id;
105
108
  }
106
109
  return conversationMember.id;
107
110
  }
@@ -4,7 +4,6 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
4
4
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
5
  };
6
6
  var _TeamsChatGetCommand_instances, _TeamsChatGetCommand_initTelemetry, _TeamsChatGetCommand_initOptions, _TeamsChatGetCommand_initValidators, _TeamsChatGetCommand_initOptionSets;
7
- import os from 'os';
8
7
  import auth from '../../../../Auth.js';
9
8
  import request from '../../../../request.js';
10
9
  import { accessToken } from '../../../../utils/accessToken.js';
@@ -13,6 +12,7 @@ import { validation } from '../../../../utils/validation.js';
13
12
  import GraphCommand from '../../../base/GraphCommand.js';
14
13
  import commands from '../../commands.js';
15
14
  import { chatUtil } from './chatUtil.js';
15
+ import { Cli } from '../../../../cli/Cli.js';
16
16
  class TeamsChatGetCommand extends GraphCommand {
17
17
  get name() {
18
18
  return commands.CHAT_GET;
@@ -66,10 +66,9 @@ class TeamsChatGetCommand extends GraphCommand {
66
66
  if (existingChats.length === 1) {
67
67
  return existingChats[0].id;
68
68
  }
69
- const disambiguationText = existingChats.map(c => {
70
- return `- ${c.id}${c.topic && ' - '}${c.topic} - ${c.createdDateTime && new Date(c.createdDateTime).toLocaleString()}`;
71
- }).join(os.EOL);
72
- throw `Multiple chat conversations with these participants found. Please disambiguate:${os.EOL}${disambiguationText}`;
69
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', existingChats);
70
+ const result = await Cli.handleMultipleResultsFound(`Multiple chat conversations with these participants found.`, resultAsKeyValuePair);
71
+ return result.id;
73
72
  }
74
73
  async getChatIdByName(name) {
75
74
  const existingChats = await chatUtil.findExistingGroupChatsByName(name);
@@ -79,11 +78,9 @@ class TeamsChatGetCommand extends GraphCommand {
79
78
  if (existingChats.length === 1) {
80
79
  return existingChats[0].id;
81
80
  }
82
- const disambiguationText = existingChats.map(c => {
83
- const memberstring = c.members.map(m => m.email).join(', ');
84
- return `- ${c.id} - ${c.createdDateTime && new Date(c.createdDateTime).toLocaleString()} - ${memberstring}`;
85
- }).join(os.EOL);
86
- throw `Multiple chat conversations with this name found. Please disambiguate:${os.EOL}${disambiguationText}`;
81
+ const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', existingChats);
82
+ const result = await Cli.handleMultipleResultsFound(`Multiple chat conversations with this name found.`, resultAsKeyValuePair);
83
+ return result.id;
87
84
  }
88
85
  }
89
86
  _TeamsChatGetCommand_instances = new WeakSet(), _TeamsChatGetCommand_initTelemetry = function _TeamsChatGetCommand_initTelemetry() {