@pnp/cli-microsoft365 10.0.0-beta.7dfc31a → 10.0.0-beta.a0367997

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 (173) hide show
  1. package/allCommands.json +1 -1
  2. package/allCommandsFull.json +1 -1
  3. package/dist/Auth.js +17 -16
  4. package/dist/AuthServer.js +7 -7
  5. package/dist/Command.js +4 -1
  6. package/dist/api.js +1 -1
  7. package/dist/cli/cli.js +14 -0
  8. package/dist/config.js +61 -5
  9. package/dist/m365/base/PowerAutomateCommand.js +1 -1
  10. package/dist/m365/base/SpoCommand.js +1 -1
  11. package/dist/m365/cli/commands/cli-consent.js +2 -2
  12. package/dist/m365/cli/commands/cli-doctor.js +4 -4
  13. package/dist/m365/cli/commands/config/config-set.js +12 -4
  14. package/dist/m365/cli/commands.js +1 -2
  15. package/dist/m365/commands/login.js +28 -9
  16. package/dist/m365/commands/setup.js +256 -33
  17. package/dist/m365/commands/setupPresets.js +2 -4
  18. package/dist/m365/connection/commands/connection-list.js +4 -4
  19. package/dist/m365/entra/commands/app/app-add.js +52 -288
  20. package/dist/m365/entra/commands/m365group/m365group-set.js +24 -16
  21. package/dist/m365/entra/commands/m365group/m365group-user-add.js +5 -12
  22. package/dist/m365/entra/commands/oauth2grant/oauth2grant-list.js +3 -12
  23. package/dist/m365/external/commands/item/item-add.js +2 -5
  24. package/dist/m365/file/commands/file-move.js +135 -0
  25. package/dist/m365/file/commands.js +2 -1
  26. package/dist/m365/flow/commands/environment/environment-get.js +1 -1
  27. package/dist/m365/flow/commands/environment/environment-list.js +2 -2
  28. package/dist/m365/flow/commands/flow-disable.js +1 -1
  29. package/dist/m365/flow/commands/flow-enable.js +1 -1
  30. package/dist/m365/flow/commands/flow-export.js +17 -16
  31. package/dist/m365/flow/commands/flow-get.js +1 -1
  32. package/dist/m365/flow/commands/flow-list.js +1 -1
  33. package/dist/m365/flow/commands/flow-remove.js +1 -1
  34. package/dist/m365/flow/commands/owner/owner-ensure.js +1 -1
  35. package/dist/m365/flow/commands/owner/owner-list.js +1 -1
  36. package/dist/m365/flow/commands/owner/owner-remove.js +1 -1
  37. package/dist/m365/flow/commands/recyclebinitem/recyclebinitem-list.js +47 -0
  38. package/dist/m365/flow/commands/recyclebinitem/recyclebinitem-restore.js +48 -0
  39. package/dist/m365/flow/commands/run/run-cancel.js +1 -1
  40. package/dist/m365/flow/commands/run/run-get.js +1 -1
  41. package/dist/m365/flow/commands/run/run-list.js +1 -1
  42. package/dist/m365/flow/commands/run/run-resubmit.js +2 -2
  43. package/dist/m365/flow/commands.js +2 -0
  44. package/dist/m365/pa/commands/app/app-list.js +1 -6
  45. package/dist/m365/pa/commands/connector/connector-list.js +1 -6
  46. package/dist/m365/pa/commands/environment/environment-list.js +1 -1
  47. package/dist/m365/pp/commands/environment/environment-list.js +1 -1
  48. package/dist/m365/spfx/commands/project/project-doctor/doctor-1.20.0.js +27 -0
  49. package/dist/m365/spfx/commands/project/project-doctor/rules/FN002021_DEVDEP_rushstack_eslint_config.js +10 -0
  50. package/dist/m365/spfx/commands/project/project-doctor.js +2 -1
  51. package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.20.0.js +59 -0
  52. package/dist/m365/spfx/commands/project/project-upgrade.js +2 -1
  53. package/dist/m365/spfx/commands/spfx-doctor.js +15 -0
  54. package/dist/m365/spo/commands/app/app-instance-list.js +3 -18
  55. package/dist/m365/spo/commands/app/app-list.js +1 -8
  56. package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +8 -8
  57. package/dist/m365/spo/commands/contenttype/contenttype-field-set.js +2 -2
  58. package/dist/m365/spo/commands/feature/feature-list.js +1 -8
  59. package/dist/m365/spo/commands/file/file-copy.js +5 -1
  60. package/dist/m365/spo/commands/file/file-move.js +55 -33
  61. package/dist/m365/spo/commands/file/file-roleassignment-add.js +17 -54
  62. package/dist/m365/spo/commands/file/file-roleassignment-remove.js +13 -40
  63. package/dist/m365/spo/commands/file/file-roleinheritance-break.js +5 -13
  64. package/dist/m365/spo/commands/file/file-roleinheritance-reset.js +5 -13
  65. package/dist/m365/spo/commands/folder/folder-sharinglink-add.js +143 -0
  66. package/dist/m365/spo/commands/folder/folder-sharinglink-clear.js +111 -0
  67. package/dist/m365/spo/commands/folder/folder-sharinglink-remove.js +95 -0
  68. package/dist/m365/spo/commands/list/list-get.js +17 -4
  69. package/dist/m365/spo/commands/list/list-webhook-list.js +1 -6
  70. package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +1 -8
  71. package/dist/m365/spo/commands/page/page-list.js +1 -1
  72. package/dist/m365/spo/commands/page/page-remove.js +37 -16
  73. package/dist/m365/spo/commands/page/page-section-add.js +185 -34
  74. package/dist/m365/spo/commands/page/page-template-list.js +1 -3
  75. package/dist/m365/spo/commands/site/SiteAdmin.js +2 -0
  76. package/dist/m365/spo/commands/site/site-admin-add.js +252 -0
  77. package/dist/m365/spo/commands/site/site-admin-list.js +10 -36
  78. package/dist/m365/spo/commands/site/site-admin-remove.js +194 -0
  79. package/dist/m365/spo/commands/site/site-sharingpermission-set.js +68 -0
  80. package/dist/m365/spo/commands/sitescript/sitescript-get.js +3 -2
  81. package/dist/m365/spo/commands/sitescript/sitescript-list.js +1 -3
  82. package/dist/m365/spo/commands/{site/site-rename.js → tenant/tenant-site-rename.js} +29 -32
  83. package/dist/m365/spo/commands/theme/theme-list.js +1 -1
  84. package/dist/m365/spo/commands/user/user-get.js +67 -9
  85. package/dist/m365/spo/commands/web/web-clientsidewebpart-list.js +1 -6
  86. package/dist/m365/spo/commands.js +7 -1
  87. package/dist/m365/spp/commands/contentcenter/contentcenter-list.js +56 -0
  88. package/dist/m365/spp/commands.js +5 -0
  89. package/dist/m365/teams/MeetingTranscript.js +2 -0
  90. package/dist/m365/teams/commands/meeting/meeting-transcript-get.js +152 -0
  91. package/dist/m365/teams/commands/tab/tab-list.js +5 -3
  92. package/dist/m365/teams/commands.js +1 -0
  93. package/dist/m365/viva/commands/engage/Community.js +2 -0
  94. package/dist/m365/viva/commands/engage/engage-community-list.js +28 -0
  95. package/dist/m365/viva/commands.js +1 -0
  96. package/dist/request.js +46 -61
  97. package/dist/settingsNames.js +6 -1
  98. package/dist/utils/driveUtil.js +51 -0
  99. package/dist/utils/entraApp.js +283 -0
  100. package/dist/utils/spo.js +76 -8
  101. package/dist/utils/timersUtil.js +12 -0
  102. package/dist/utils/urlUtil.js +8 -0
  103. package/dist/utils/zod.js +1 -1
  104. package/docs/docs/_clisettings.mdx +6 -1
  105. package/docs/docs/cmd/cli/cli-doctor.mdx +24 -23
  106. package/docs/docs/cmd/entra/m365group/m365group-report-activitystorage.mdx +2 -2
  107. package/docs/docs/cmd/entra/m365group/m365group-set.mdx +9 -6
  108. package/docs/docs/cmd/entra/m365group/m365group-user-add.mdx +0 -3
  109. package/docs/docs/cmd/external/item/item-add.mdx +3 -3
  110. package/docs/docs/cmd/file/file-move.mdx +79 -0
  111. package/docs/docs/cmd/flow/recyclebinitem/recyclebinitem-list.mdx +132 -0
  112. package/docs/docs/cmd/flow/recyclebinitem/recyclebinitem-restore.mdx +55 -0
  113. package/docs/docs/cmd/setup.mdx +17 -6
  114. package/docs/docs/cmd/spfx/project/project-upgrade.mdx +1 -1
  115. package/docs/docs/cmd/spo/cdn/cdn-get.mdx +1 -1
  116. package/docs/docs/cmd/spo/cdn/cdn-origin-add.mdx +1 -1
  117. package/docs/docs/cmd/spo/cdn/cdn-origin-list.mdx +1 -1
  118. package/docs/docs/cmd/spo/cdn/cdn-origin-remove.mdx +1 -1
  119. package/docs/docs/cmd/spo/cdn/cdn-policy-list.mdx +1 -1
  120. package/docs/docs/cmd/spo/cdn/cdn-policy-set.mdx +1 -1
  121. package/docs/docs/cmd/spo/contenttype/contenttype-field-remove.mdx +7 -7
  122. package/docs/docs/cmd/spo/contenttype/contenttype-field-set.mdx +2 -2
  123. package/docs/docs/cmd/spo/externaluser/externaluser-list.mdx +1 -1
  124. package/docs/docs/cmd/spo/file/file-move.mdx +116 -9
  125. package/docs/docs/cmd/spo/folder/folder-sharinglink-add.mdx +125 -0
  126. package/docs/docs/cmd/spo/folder/folder-sharinglink-clear.mdx +50 -0
  127. package/docs/docs/cmd/spo/folder/folder-sharinglink-remove.mdx +50 -0
  128. package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-get.mdx +1 -1
  129. package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-set.mdx +1 -1
  130. package/docs/docs/cmd/spo/homesite/homesite-remove.mdx +1 -1
  131. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-get.mdx +1 -1
  132. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-remove.mdx +1 -1
  133. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-set.mdx +1 -1
  134. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-add.mdx +1 -1
  135. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-list.mdx +1 -1
  136. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-remove.mdx +1 -1
  137. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-list.mdx +1 -1
  138. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-remove.mdx +1 -1
  139. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-set.mdx +1 -1
  140. package/docs/docs/cmd/spo/page/page-remove.mdx +30 -12
  141. package/docs/docs/cmd/spo/page/page-section-add.mdx +57 -2
  142. package/docs/docs/cmd/spo/site/site-admin-add.mdx +67 -0
  143. package/docs/docs/cmd/spo/site/site-admin-list.mdx +64 -12
  144. package/docs/docs/cmd/spo/site/site-admin-remove.mdx +67 -0
  145. package/docs/docs/cmd/spo/site/site-appcatalog-add.mdx +1 -1
  146. package/docs/docs/cmd/spo/site/site-appcatalog-remove.mdx +1 -1
  147. package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +1 -1
  148. package/docs/docs/cmd/spo/site/site-list.mdx +6 -4
  149. package/docs/docs/cmd/spo/site/site-set.mdx +1 -1
  150. package/docs/docs/cmd/spo/site/site-sharingpermission-set.mdx +58 -0
  151. package/docs/docs/cmd/spo/sitescript/sitescript-get.mdx +14 -1
  152. package/docs/docs/cmd/spo/storageentity/storageentity-remove.mdx +1 -1
  153. package/docs/docs/cmd/spo/storageentity/storageentity-set.mdx +1 -1
  154. package/docs/docs/cmd/spo/tenant/tenant-appcatalog-add.mdx +1 -1
  155. package/docs/docs/cmd/spo/tenant/tenant-appcatalogurl-get.mdx +1 -1
  156. package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-list.mdx +1 -1
  157. package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-remove.mdx +1 -1
  158. package/docs/docs/cmd/spo/tenant/tenant-settings-list.mdx +1 -1
  159. package/docs/docs/cmd/spo/{site/site-rename.mdx → tenant/tenant-site-rename.mdx} +7 -7
  160. package/docs/docs/cmd/spo/theme/theme-apply.mdx +1 -1
  161. package/docs/docs/cmd/spo/theme/theme-get.mdx +1 -1
  162. package/docs/docs/cmd/spo/theme/theme-list.mdx +1 -1
  163. package/docs/docs/cmd/spo/theme/theme-remove.mdx +1 -1
  164. package/docs/docs/cmd/spo/theme/theme-set.mdx +1 -1
  165. package/docs/docs/cmd/spo/user/user-get.mdx +35 -9
  166. package/docs/docs/cmd/spp/contentcenter/contentcenter-list.mdx +287 -0
  167. package/docs/docs/cmd/teams/meeting/meeting-transcript-get.mdx +132 -0
  168. package/docs/docs/cmd/teams/tab/tab-list.mdx +1 -2
  169. package/docs/docs/cmd/viva/engage/engage-community-list.mdx +81 -0
  170. package/npm-shrinkwrap.json +203 -375
  171. package/package.json +16 -17
  172. package/dist/m365/cli/commands/cli-reconsent.js +0 -30
  173. package/docs/docs/cmd/cli/cli-reconsent.mdx +0 -62
@@ -17,6 +17,9 @@ class SpoSiteAdminListCommand extends SpoCommand {
17
17
  get description() {
18
18
  return 'Lists all administrators of a specific SharePoint site';
19
19
  }
20
+ defaultProperties() {
21
+ return ['Id', 'LoginName', 'Title', 'PrincipalTypeString'];
22
+ }
20
23
  constructor() {
21
24
  super();
22
25
  _SpoSiteAdminListCommand_instances.add(this);
@@ -46,20 +49,16 @@ class SpoSiteAdminListCommand extends SpoCommand {
46
49
  const requestOptions = {
47
50
  url: `${adminUrl}/_api/SPO.Tenant/GetSiteAdministrators?siteId='${siteId}'`,
48
51
  headers: {
49
- accept: 'application/json;odata=nometadata',
50
- 'content-type': 'application/json;charset=utf-8'
51
- }
52
+ accept: 'application/json;odata=nometadata'
53
+ },
54
+ responseType: 'json'
52
55
  };
53
56
  const response = await request.post(requestOptions);
54
- const responseContent = JSON.parse(response);
55
- const primaryAdminLoginName = await this.getPrimaryAdminLoginNameFromAdmin(adminUrl, siteId);
56
- const mappedResult = responseContent.value.map((u) => ({
57
- Id: null,
57
+ const primaryAdminLoginName = await spo.getPrimaryAdminLoginNameAsAdmin(adminUrl, siteId, logger, this.verbose);
58
+ const mappedResult = response.value.map((u) => ({
58
59
  Email: u.email,
59
60
  LoginName: u.loginName,
60
61
  Title: u.name,
61
- PrincipalType: null,
62
- PrincipalTypeString: null,
63
62
  IsPrimaryAdmin: u.loginName === primaryAdminLoginName
64
63
  }));
65
64
  await logger.log(mappedResult);
@@ -72,32 +71,19 @@ class SpoSiteAdminListCommand extends SpoCommand {
72
71
  }
73
72
  return match[1];
74
73
  }
75
- async getPrimaryAdminLoginNameFromAdmin(adminUrl, siteId) {
76
- const requestOptions = {
77
- url: `${adminUrl}/_api/SPO.Tenant/sites('${siteId}')?$select=OwnerLoginName`,
78
- headers: {
79
- accept: 'application/json;odata=nometadata',
80
- 'content-type': 'application/json;charset=utf-8'
81
- }
82
- };
83
- const response = await request.get(requestOptions);
84
- const responseContent = JSON.parse(response);
85
- return responseContent.OwnerLoginName;
86
- }
87
74
  async callAction(logger, args) {
88
75
  if (this.verbose) {
89
76
  await logger.logToStderr('Retrieving site administrators...');
90
77
  }
91
78
  const requestOptions = {
92
79
  url: `${args.options.siteUrl}/_api/web/siteusers?$filter=IsSiteAdmin eq true`,
93
- method: 'GET',
94
80
  headers: {
95
81
  'accept': 'application/json;odata=nometadata'
96
82
  },
97
83
  responseType: 'json'
98
84
  };
99
85
  const responseContent = await request.get(requestOptions);
100
- const primaryOwnerLogin = await this.getPrimaryOwnerLoginFromSite(args.options.siteUrl);
86
+ const primaryOwnerLogin = await spo.getPrimaryOwnerLoginFromSite(args.options.siteUrl, logger, this.verbose);
101
87
  const mappedResult = responseContent.value.map((u) => ({
102
88
  Id: u.Id,
103
89
  LoginName: u.LoginName,
@@ -109,23 +95,10 @@ class SpoSiteAdminListCommand extends SpoCommand {
109
95
  }));
110
96
  await logger.log(mappedResult);
111
97
  }
112
- async getPrimaryOwnerLoginFromSite(siteUrl) {
113
- const requestOptions = {
114
- url: `${siteUrl}/_api/site/owner`,
115
- method: 'GET',
116
- headers: {
117
- 'accept': 'application/json;odata=nometadata'
118
- },
119
- responseType: 'json'
120
- };
121
- const responseContent = await request.get(requestOptions);
122
- return responseContent?.LoginName ?? null;
123
- }
124
98
  }
125
99
  _SpoSiteAdminListCommand_instances = new WeakSet(), _SpoSiteAdminListCommand_initTelemetry = function _SpoSiteAdminListCommand_initTelemetry() {
126
100
  this.telemetry.push((args) => {
127
101
  Object.assign(this.telemetryProperties, {
128
- siteUrl: typeof args.options.siteUrl !== 'undefined',
129
102
  asAdmin: !!args.options.asAdmin
130
103
  });
131
104
  });
@@ -139,6 +112,7 @@ _SpoSiteAdminListCommand_instances = new WeakSet(), _SpoSiteAdminListCommand_ini
139
112
  this.validators.push(async (args) => validation.isValidSharePointUrl(args.options.siteUrl));
140
113
  }, _SpoSiteAdminListCommand_initTypes = function _SpoSiteAdminListCommand_initTypes() {
141
114
  this.types.string.push('siteUrl');
115
+ this.types.boolean.push('asAdmin');
142
116
  };
143
117
  export default new SpoSiteAdminListCommand();
144
118
  //# sourceMappingURL=site-admin-list.js.map
@@ -0,0 +1,194 @@
1
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
2
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
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
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
5
+ };
6
+ var _SpoSiteAdminRemoveCommand_instances, _SpoSiteAdminRemoveCommand_initTelemetry, _SpoSiteAdminRemoveCommand_initOptions, _SpoSiteAdminRemoveCommand_initValidators, _SpoSiteAdminRemoveCommand_initOptionSets, _SpoSiteAdminRemoveCommand_initTypes;
7
+ import { cli } from '../../../../cli/cli.js';
8
+ import request from '../../../../request.js';
9
+ import { entraGroup } from '../../../../utils/entraGroup.js';
10
+ import { entraUser } from '../../../../utils/entraUser.js';
11
+ import { formatting } from '../../../../utils/formatting.js';
12
+ import { spo } from '../../../../utils/spo.js';
13
+ import { validation } from '../../../../utils/validation.js';
14
+ import SpoCommand from '../../../base/SpoCommand.js';
15
+ import commands from '../../commands.js';
16
+ class SpoSiteAdminRemoveCommand extends SpoCommand {
17
+ get name() {
18
+ return commands.SITE_ADMIN_REMOVE;
19
+ }
20
+ get description() {
21
+ return 'Removes a user or group as site collection administrator';
22
+ }
23
+ constructor() {
24
+ super();
25
+ _SpoSiteAdminRemoveCommand_instances.add(this);
26
+ __classPrivateFieldGet(this, _SpoSiteAdminRemoveCommand_instances, "m", _SpoSiteAdminRemoveCommand_initTelemetry).call(this);
27
+ __classPrivateFieldGet(this, _SpoSiteAdminRemoveCommand_instances, "m", _SpoSiteAdminRemoveCommand_initOptions).call(this);
28
+ __classPrivateFieldGet(this, _SpoSiteAdminRemoveCommand_instances, "m", _SpoSiteAdminRemoveCommand_initValidators).call(this);
29
+ __classPrivateFieldGet(this, _SpoSiteAdminRemoveCommand_instances, "m", _SpoSiteAdminRemoveCommand_initOptionSets).call(this);
30
+ __classPrivateFieldGet(this, _SpoSiteAdminRemoveCommand_instances, "m", _SpoSiteAdminRemoveCommand_initTypes).call(this);
31
+ }
32
+ async commandAction(logger, args) {
33
+ try {
34
+ if (!args.options.force) {
35
+ const principalToDelete = args.options.groupId || args.options.groupName ? 'group' : 'user';
36
+ const result = await cli.promptForConfirmation({ message: `Are you sure you want to remove specified ${principalToDelete} from the site administrators list ${args.options.siteUrl}?` });
37
+ if (!result) {
38
+ return;
39
+ }
40
+ }
41
+ const loginNameToRemove = await this.getCorrectLoginName(args.options);
42
+ if (args.options.asAdmin) {
43
+ await this.callActionAsAdmin(logger, args, loginNameToRemove);
44
+ return;
45
+ }
46
+ await this.callAction(logger, args, loginNameToRemove);
47
+ }
48
+ catch (err) {
49
+ this.handleRejectedODataJsonPromise(err);
50
+ }
51
+ }
52
+ async callActionAsAdmin(logger, args, loginNameToRemove) {
53
+ if (this.verbose) {
54
+ await logger.logToStderr('Removing site administrator as an administrator...');
55
+ }
56
+ const adminUrl = await spo.getSpoAdminUrl(logger, this.debug);
57
+ const siteId = await this.getSiteId(args.options.siteUrl, logger);
58
+ const primaryAdminLoginName = await spo.getPrimaryAdminLoginNameAsAdmin(adminUrl, siteId, logger, this.verbose);
59
+ if (loginNameToRemove === primaryAdminLoginName) {
60
+ throw 'You cannot remove the primary site collection administrator.';
61
+ }
62
+ const existingAdmins = await this.getSiteAdmins(adminUrl, siteId);
63
+ const adminsToSet = existingAdmins.filter(u => u.loginName.toLowerCase() !== loginNameToRemove.toLowerCase());
64
+ await this.setSiteAdminsAsAdmin(adminUrl, siteId, adminsToSet);
65
+ }
66
+ async getSiteId(siteUrl, logger) {
67
+ const siteGraphId = await spo.getSiteId(siteUrl, logger, this.verbose);
68
+ const match = siteGraphId.match(/,([a-f0-9\-]{36}),/i);
69
+ if (!match) {
70
+ throw `Site with URL ${siteUrl} not found`;
71
+ }
72
+ return match[1];
73
+ }
74
+ async getSiteAdmins(adminUrl, siteId) {
75
+ const requestOptions = {
76
+ url: `${adminUrl}/_api/SPO.Tenant/GetSiteAdministrators?siteId='${siteId}'`,
77
+ headers: {
78
+ accept: 'application/json;odata=nometadata',
79
+ 'content-type': 'application/json;charset=utf-8'
80
+ },
81
+ responseType: 'json'
82
+ };
83
+ const response = await request.post(requestOptions);
84
+ return response.value;
85
+ }
86
+ async getCorrectLoginName(options) {
87
+ if (options.userId || options.userName) {
88
+ const userPrincipalName = options.userName ? options.userName : await entraUser.getUpnByUserId(options.userId);
89
+ if (userPrincipalName) {
90
+ return `i:0#.f|membership|${userPrincipalName}`;
91
+ }
92
+ throw 'User not found.';
93
+ }
94
+ else {
95
+ const group = options.groupId ? await entraGroup.getGroupById(options.groupId) : await entraGroup.getGroupByDisplayName(options.groupName);
96
+ //for entra groups, M365 groups have an associated email and security groups don't
97
+ if (group?.mail) {
98
+ //M365 group is prefixed with c:0o.c|federateddirectoryclaimprovider
99
+ return `c:0o.c|federateddirectoryclaimprovider|${group.id}`;
100
+ }
101
+ else {
102
+ //security group is prefixed with c:0t.c|tenant
103
+ return `c:0t.c|tenant|${group?.id}`;
104
+ }
105
+ }
106
+ }
107
+ async setSiteAdminsAsAdmin(adminUrl, siteId, admins) {
108
+ const requestOptions = {
109
+ url: `${adminUrl}/_api/SPOInternalUseOnly.Tenant/SetSiteSecondaryAdministrators`,
110
+ headers: {
111
+ accept: 'application/json;odata=nometadata',
112
+ 'content-type': 'application/json;charset=utf-8'
113
+ },
114
+ data: {
115
+ secondaryAdministratorsFieldsData: {
116
+ siteId: siteId,
117
+ secondaryAdministratorLoginNames: admins.map(u => u.loginName)
118
+ }
119
+ },
120
+ responseType: 'json'
121
+ };
122
+ await request.post(requestOptions);
123
+ }
124
+ async callAction(logger, args, loginNameToRemove) {
125
+ if (this.verbose) {
126
+ await logger.logToStderr('Removing site administrator...');
127
+ }
128
+ const primaryOwnerLogin = await spo.getPrimaryOwnerLoginFromSite(args.options.siteUrl, logger, this.verbose);
129
+ if (loginNameToRemove === primaryOwnerLogin) {
130
+ throw 'You cannot remove the primary site collection administrator.';
131
+ }
132
+ const requestOptions = {
133
+ url: `${args.options.siteUrl}/_api/web/siteusers('${formatting.encodeQueryParameter(loginNameToRemove)}')`,
134
+ headers: {
135
+ 'accept': 'application/json',
136
+ 'X-Http-Method': 'MERGE',
137
+ 'If-Match': '*'
138
+ },
139
+ data: { IsSiteAdmin: false },
140
+ responseType: 'json'
141
+ };
142
+ await request.post(requestOptions);
143
+ }
144
+ }
145
+ _SpoSiteAdminRemoveCommand_instances = new WeakSet(), _SpoSiteAdminRemoveCommand_initTelemetry = function _SpoSiteAdminRemoveCommand_initTelemetry() {
146
+ this.telemetry.push((args) => {
147
+ Object.assign(this.telemetryProperties, {
148
+ userId: typeof args.options.userId !== 'undefined',
149
+ userName: typeof args.options.userName !== 'undefined',
150
+ groupId: typeof args.options.groupId !== 'undefined',
151
+ groupName: typeof args.options.groupName !== 'undefined',
152
+ force: !!args.options.force,
153
+ asAdmin: !!args.options.asAdmin
154
+ });
155
+ });
156
+ }, _SpoSiteAdminRemoveCommand_initOptions = function _SpoSiteAdminRemoveCommand_initOptions() {
157
+ this.options.unshift({
158
+ option: '-u, --siteUrl <siteUrl>'
159
+ }, {
160
+ option: '--userId [userId]'
161
+ }, {
162
+ option: '--userName [userName]'
163
+ }, {
164
+ option: '--groupId [groupId]'
165
+ }, {
166
+ option: '--groupName [groupName]'
167
+ }, {
168
+ option: '--asAdmin'
169
+ }, {
170
+ option: '-f, --force'
171
+ });
172
+ }, _SpoSiteAdminRemoveCommand_initValidators = function _SpoSiteAdminRemoveCommand_initValidators() {
173
+ this.validators.push(async (args) => {
174
+ if (args.options.userId &&
175
+ !validation.isValidGuid(args.options.userId)) {
176
+ return `${args.options.userId} is not a valid GUID`;
177
+ }
178
+ if (args.options.userName && !validation.isValidUserPrincipalName(args.options.userName)) {
179
+ return `${args.options.userName} is not a valid userName`;
180
+ }
181
+ if (args.options.groupId &&
182
+ !validation.isValidGuid(args.options.groupId)) {
183
+ return `${args.options.groupId} is not a valid GUID`;
184
+ }
185
+ return validation.isValidSharePointUrl(args.options.siteUrl);
186
+ });
187
+ }, _SpoSiteAdminRemoveCommand_initOptionSets = function _SpoSiteAdminRemoveCommand_initOptionSets() {
188
+ this.optionSets.push({ options: ['userId', 'userName', 'groupId', 'groupName'] });
189
+ }, _SpoSiteAdminRemoveCommand_initTypes = function _SpoSiteAdminRemoveCommand_initTypes() {
190
+ this.types.string.push('siteUrl', 'userId', 'userName', 'groupId', 'groupName');
191
+ this.types.boolean.push('force', 'asAdmin');
192
+ };
193
+ export default new SpoSiteAdminRemoveCommand();
194
+ //# sourceMappingURL=site-admin-remove.js.map
@@ -0,0 +1,68 @@
1
+ import SpoCommand from '../../../base/SpoCommand.js';
2
+ import { globalOptionsZod } from '../../../../Command.js';
3
+ import { z } from 'zod';
4
+ import { zod } from '../../../../utils/zod.js';
5
+ import commands from '../../commands.js';
6
+ import { validation } from '../../../../utils/validation.js';
7
+ import request from '../../../../request.js';
8
+ const options = globalOptionsZod
9
+ .extend({
10
+ siteUrl: zod.alias('u', z.string()
11
+ .refine(url => validation.isValidSharePointUrl(url) === true, url => ({
12
+ message: `'${url}' is not a valid SharePoint Online site URL.`
13
+ }))),
14
+ capability: z.enum(['full', 'limited', 'ownersOnly'])
15
+ })
16
+ .strict();
17
+ class SpoSiteSharingPermissionSetCommand extends SpoCommand {
18
+ get name() {
19
+ return commands.SITE_SHARINGPERMISSION_SET;
20
+ }
21
+ get description() {
22
+ return 'Controls how a site and its components can be shared';
23
+ }
24
+ get schema() {
25
+ return options;
26
+ }
27
+ async commandAction(logger, args) {
28
+ try {
29
+ if (this.verbose) {
30
+ await logger.logToStderr(`Updating sharing permissions for site '${args.options.siteUrl}'...`);
31
+ }
32
+ const { capability } = args.options;
33
+ if (this.verbose) {
34
+ await logger.logToStderr(`Updating site sharing permissions...`);
35
+ }
36
+ const requestOptionsWeb = {
37
+ url: `${args.options.siteUrl}/_api/Web`,
38
+ headers: {
39
+ accept: 'application/json;odata=nometadata'
40
+ },
41
+ responseType: 'json',
42
+ data: {
43
+ MembersCanShare: capability === 'full' || capability === 'limited'
44
+ }
45
+ };
46
+ await request.patch(requestOptionsWeb);
47
+ if (this.verbose) {
48
+ await logger.logToStderr(`Updating associated member group sharing permissions...`);
49
+ }
50
+ const requestOptionsMemberGroup = {
51
+ url: `${args.options.siteUrl}/_api/Web/AssociatedMemberGroup`,
52
+ headers: {
53
+ accept: 'application/json;odata=nometadata'
54
+ },
55
+ responseType: 'json',
56
+ data: {
57
+ AllowMembersEditMembership: capability === 'full'
58
+ }
59
+ };
60
+ await request.patch(requestOptionsMemberGroup);
61
+ }
62
+ catch (err) {
63
+ this.handleRejectedODataJsonPromise(err);
64
+ }
65
+ }
66
+ }
67
+ export default new SpoSiteSharingPermissionSetCommand();
68
+ //# sourceMappingURL=site-sharingpermission-set.js.map
@@ -37,8 +37,9 @@ class SpoSiteScriptGetCommand extends SpoCommand {
37
37
  responseType: 'json'
38
38
  };
39
39
  const response = await request.post(requestOptions);
40
- if (args.options.content === true) {
41
- await logger.log(JSON.parse(response.Content));
40
+ response.Content = JSON.parse(response.Content);
41
+ if (args.options.content) {
42
+ await logger.log(response.Content);
42
43
  return;
43
44
  }
44
45
  await logger.log(response);
@@ -22,9 +22,7 @@ class SpoSiteScriptListCommand extends SpoCommand {
22
22
  responseType: 'json'
23
23
  };
24
24
  const res = await request.post(requestOptions);
25
- if (res.value && res.value.length > 0) {
26
- await logger.log(res.value);
27
- }
25
+ await logger.log(res.value);
28
26
  }
29
27
  catch (err) {
30
28
  this.handleRejectedODataJsonPromise(err);
@@ -3,25 +3,26 @@ 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 _SpoSiteRenameCommand_instances, _SpoSiteRenameCommand_initTelemetry, _SpoSiteRenameCommand_initOptions, _SpoSiteRenameCommand_initValidators;
6
+ var _SpoTenantSiteRenameCommand_instances, _SpoTenantSiteRenameCommand_initTelemetry, _SpoTenantSiteRenameCommand_initOptions, _SpoTenantSiteRenameCommand_initValidators;
7
7
  import request from '../../../../request.js';
8
8
  import { formatting } from '../../../../utils/formatting.js';
9
9
  import { spo } from '../../../../utils/spo.js';
10
+ import { timersUtil } from '../../../../utils/timersUtil.js';
10
11
  import SpoCommand from '../../../base/SpoCommand.js';
11
12
  import commands from '../../commands.js';
12
- class SpoSiteRenameCommand extends SpoCommand {
13
+ class SpoTenantSiteRenameCommand extends SpoCommand {
13
14
  get name() {
14
- return commands.SITE_RENAME;
15
+ return commands.TENANT_SITE_RENAME;
15
16
  }
16
17
  get description() {
17
18
  return 'Renames the URL and title of a site collection';
18
19
  }
19
20
  constructor() {
20
21
  super();
21
- _SpoSiteRenameCommand_instances.add(this);
22
- __classPrivateFieldGet(this, _SpoSiteRenameCommand_instances, "m", _SpoSiteRenameCommand_initTelemetry).call(this);
23
- __classPrivateFieldGet(this, _SpoSiteRenameCommand_instances, "m", _SpoSiteRenameCommand_initOptions).call(this);
24
- __classPrivateFieldGet(this, _SpoSiteRenameCommand_instances, "m", _SpoSiteRenameCommand_initValidators).call(this);
22
+ _SpoTenantSiteRenameCommand_instances.add(this);
23
+ __classPrivateFieldGet(this, _SpoTenantSiteRenameCommand_instances, "m", _SpoTenantSiteRenameCommand_initTelemetry).call(this);
24
+ __classPrivateFieldGet(this, _SpoTenantSiteRenameCommand_instances, "m", _SpoTenantSiteRenameCommand_initOptions).call(this);
25
+ __classPrivateFieldGet(this, _SpoTenantSiteRenameCommand_instances, "m", _SpoTenantSiteRenameCommand_initValidators).call(this);
25
26
  }
26
27
  async commandAction(logger, args) {
27
28
  try {
@@ -40,24 +41,23 @@ class SpoSiteRenameCommand extends SpoCommand {
40
41
  optionsBitmask = optionsBitmask | 16;
41
42
  }
42
43
  const requestOptions = {
43
- "SourceSiteUrl": options.url,
44
- "TargetSiteUrl": options.newUrl,
45
- "TargetSiteTitle": options.newTitle || null,
46
- "Option": optionsBitmask,
47
- "Reserve": null,
48
- "SkipGestures": null,
49
- "OperationId": "00000000-0000-0000-0000-000000000000"
50
- };
51
- const postData = {
52
44
  url: `${spoAdminUrl}/_api/SiteRenameJobs?api-version=1.4.7`,
53
45
  headers: {
54
46
  'X-RequestDigest': this.context.FormDigestValue,
55
47
  'Content-Type': 'application/json'
56
48
  },
57
49
  responseType: 'json',
58
- data: requestOptions
50
+ data: {
51
+ SourceSiteUrl: options.url,
52
+ TargetSiteUrl: options.newUrl,
53
+ TargetSiteTitle: options.newTitle || null,
54
+ Option: optionsBitmask,
55
+ Reserve: null,
56
+ SkipGestures: null,
57
+ OperationId: '00000000-0000-0000-0000-000000000000'
58
+ }
59
59
  };
60
- const res = await request.post(postData);
60
+ const res = await request.post(requestOptions);
61
61
  if (options.verbose) {
62
62
  await logger.logToStderr(res);
63
63
  }
@@ -92,23 +92,20 @@ class SpoSiteRenameCommand extends SpoCommand {
92
92
  if (this.operationData.JobState === "Success") {
93
93
  return;
94
94
  }
95
- await this.sleep(SpoSiteRenameCommand.checkIntervalInMs);
95
+ await timersUtil.setTimeout(SpoTenantSiteRenameCommand.checkIntervalInMs);
96
96
  await command.waitForRenameCompletion(command, isVerbose, spoAdminUrl, siteUrl, iteration);
97
97
  }
98
- sleep(ms) {
99
- return new Promise(resolve => setTimeout(resolve, ms));
100
- }
101
98
  }
102
- _SpoSiteRenameCommand_instances = new WeakSet(), _SpoSiteRenameCommand_initTelemetry = function _SpoSiteRenameCommand_initTelemetry() {
99
+ _SpoTenantSiteRenameCommand_instances = new WeakSet(), _SpoTenantSiteRenameCommand_initTelemetry = function _SpoTenantSiteRenameCommand_initTelemetry() {
103
100
  this.telemetry.push((args) => {
104
101
  Object.assign(this.telemetryProperties, {
105
- newTitle: args.options.newTitle ? true : false,
106
- suppressMarketplaceAppCheck: args.options.suppressMarketplaceAppCheck,
107
- suppressWorkflow2013Check: args.options.suppressWorkflow2013Check,
108
- wait: args.options.wait
102
+ newTitle: typeof args.options.newTitle !== 'undefined',
103
+ suppressMarketplaceAppCheck: !!args.options.suppressMarketplaceAppCheck,
104
+ suppressWorkflow2013Check: !!args.options.suppressWorkflow2013Check,
105
+ wait: !!args.options.wait
109
106
  });
110
107
  });
111
- }, _SpoSiteRenameCommand_initOptions = function _SpoSiteRenameCommand_initOptions() {
108
+ }, _SpoTenantSiteRenameCommand_initOptions = function _SpoTenantSiteRenameCommand_initOptions() {
112
109
  this.options.unshift({
113
110
  option: '-u, --url <url>'
114
111
  }, {
@@ -122,7 +119,7 @@ _SpoSiteRenameCommand_instances = new WeakSet(), _SpoSiteRenameCommand_initTelem
122
119
  }, {
123
120
  option: '--wait'
124
121
  });
125
- }, _SpoSiteRenameCommand_initValidators = function _SpoSiteRenameCommand_initValidators() {
122
+ }, _SpoTenantSiteRenameCommand_initValidators = function _SpoTenantSiteRenameCommand_initValidators() {
126
123
  this.validators.push(async (args) => {
127
124
  if (args.options.url.toLowerCase() === args.options.newUrl.toLowerCase()) {
128
125
  return 'The new URL cannot be the same as the target URL.';
@@ -130,6 +127,6 @@ _SpoSiteRenameCommand_instances = new WeakSet(), _SpoSiteRenameCommand_initTelem
130
127
  return true;
131
128
  });
132
129
  };
133
- SpoSiteRenameCommand.checkIntervalInMs = 5000;
134
- export default new SpoSiteRenameCommand();
135
- //# sourceMappingURL=site-rename.js.map
130
+ SpoTenantSiteRenameCommand.checkIntervalInMs = 5000;
131
+ export default new SpoTenantSiteRenameCommand();
132
+ //# sourceMappingURL=tenant-site-rename.js.map
@@ -26,7 +26,7 @@ class SpoThemeListCommand extends SpoCommand {
26
26
  responseType: 'json'
27
27
  };
28
28
  const rawRes = await request.post(requestOptions);
29
- await logger.log(rawRes.themePreviews);
29
+ await logger.log(rawRes.themePreviews || []);
30
30
  }
31
31
  catch (err) {
32
32
  this.handleRejectedODataJsonPromise(err);
@@ -3,8 +3,9 @@ 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 _SpoUserGetCommand_instances, _SpoUserGetCommand_initTelemetry, _SpoUserGetCommand_initOptions, _SpoUserGetCommand_initValidators, _SpoUserGetCommand_initOptionSets;
6
+ var _SpoUserGetCommand_instances, _SpoUserGetCommand_initTelemetry, _SpoUserGetCommand_initOptions, _SpoUserGetCommand_initTypes, _SpoUserGetCommand_initValidators, _SpoUserGetCommand_initOptionSets;
7
7
  import request from '../../../../request.js';
8
+ import { entraGroup } from '../../../../utils/entraGroup.js';
8
9
  import { formatting } from '../../../../utils/formatting.js';
9
10
  import { validation } from '../../../../utils/validation.js';
10
11
  import SpoCommand from '../../../base/SpoCommand.js';
@@ -23,23 +24,38 @@ class SpoUserGetCommand extends SpoCommand {
23
24
  __classPrivateFieldGet(this, _SpoUserGetCommand_instances, "m", _SpoUserGetCommand_initOptions).call(this);
24
25
  __classPrivateFieldGet(this, _SpoUserGetCommand_instances, "m", _SpoUserGetCommand_initValidators).call(this);
25
26
  __classPrivateFieldGet(this, _SpoUserGetCommand_instances, "m", _SpoUserGetCommand_initOptionSets).call(this);
27
+ __classPrivateFieldGet(this, _SpoUserGetCommand_instances, "m", _SpoUserGetCommand_initTypes).call(this);
26
28
  }
27
29
  async commandAction(logger, args) {
28
30
  if (this.verbose) {
29
31
  await logger.logToStderr(`Retrieving information for user in site '${args.options.webUrl}'...`);
30
32
  }
31
- let requestUrl = '';
33
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
32
34
  if (args.options.id) {
33
- requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetById('${formatting.encodeQueryParameter(args.options.id.toString())}')`;
35
+ requestUrl += `siteusers/GetById('${formatting.encodeQueryParameter(args.options.id.toString())}')`;
34
36
  }
35
37
  else if (args.options.email) {
36
- requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByEmail('${formatting.encodeQueryParameter(args.options.email)}')`;
38
+ requestUrl += `siteusers/GetByEmail('${formatting.encodeQueryParameter(args.options.email)}')`;
37
39
  }
38
40
  else if (args.options.loginName) {
39
- requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.loginName)}')`;
41
+ requestUrl += `siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.loginName)}')`;
42
+ }
43
+ else if (args.options.userName) {
44
+ const user = await this.getUser(requestUrl, args.options.userName);
45
+ requestUrl += `siteusers/GetById('${formatting.encodeQueryParameter(user.Id.toString())}')`;
46
+ }
47
+ else if (args.options.entraGroupId || args.options.entraGroupName) {
48
+ const entraGroup = await this.getEntraGroup(args.options.entraGroupId, args.options.entraGroupName);
49
+ // For entra groups, M365 groups have an associated email and security groups don't
50
+ if (entraGroup?.mail) {
51
+ requestUrl += `siteusers/GetByEmail('${formatting.encodeQueryParameter(entraGroup.mail)}')`;
52
+ }
53
+ else {
54
+ requestUrl += `siteusers/GetByLoginName('c:0t.c|tenant|${entraGroup?.id}')`;
55
+ }
40
56
  }
41
57
  else {
42
- requestUrl = `${args.options.webUrl}/_api/web/currentuser`;
58
+ requestUrl += `currentuser`;
43
59
  }
44
60
  const requestOptions = {
45
61
  url: requestUrl,
@@ -57,13 +73,38 @@ class SpoUserGetCommand extends SpoCommand {
57
73
  this.handleRejectedODataJsonPromise(err);
58
74
  }
59
75
  }
76
+ async getUser(baseUrl, userName) {
77
+ const requestUrl = `${baseUrl}siteusers?$filter=UserPrincipalName eq ('${formatting.encodeQueryParameter(userName)}')`;
78
+ const requestOptions = {
79
+ url: requestUrl,
80
+ headers: {
81
+ accept: 'application/json;odata=nometadata'
82
+ },
83
+ responseType: 'json'
84
+ };
85
+ const userInstance = await request.get(requestOptions);
86
+ const userInstanceValue = userInstance.value[0];
87
+ if (!userInstanceValue) {
88
+ throw `User not found: ${userName}`;
89
+ }
90
+ return userInstanceValue;
91
+ }
92
+ async getEntraGroup(entraGroupId, entraGroupName) {
93
+ if (entraGroupId) {
94
+ return entraGroup.getGroupById(entraGroupId);
95
+ }
96
+ return entraGroup.getGroupByDisplayName(entraGroupName);
97
+ }
60
98
  }
61
99
  _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry = function _SpoUserGetCommand_initTelemetry() {
62
100
  this.telemetry.push((args) => {
63
101
  Object.assign(this.telemetryProperties, {
64
102
  id: typeof args.options.id !== 'undefined',
65
103
  email: typeof args.options.email !== 'undefined',
66
- loginName: typeof args.options.loginName !== 'undefined'
104
+ loginName: typeof args.options.loginName !== 'undefined',
105
+ userName: typeof args.options.userName !== 'undefined',
106
+ entraGroupId: typeof args.options.entraGroupId !== 'undefined',
107
+ entraGroupName: typeof args.options.entraGroupName !== 'undefined'
67
108
  });
68
109
  });
69
110
  }, _SpoUserGetCommand_initOptions = function _SpoUserGetCommand_initOptions() {
@@ -75,19 +116,36 @@ _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry =
75
116
  option: '--email [email]'
76
117
  }, {
77
118
  option: '--loginName [loginName]'
119
+ }, {
120
+ option: '--userName [userName]'
121
+ }, {
122
+ option: '--entraGroupId [entraGroupId]'
123
+ }, {
124
+ option: '--entraGroupName [entraGroupName]'
78
125
  });
126
+ }, _SpoUserGetCommand_initTypes = function _SpoUserGetCommand_initTypes() {
127
+ this.types.string.push('webUrl', 'id', 'email', 'loginName', 'userName', 'entraGroupId', 'entraGroupName');
79
128
  }, _SpoUserGetCommand_initValidators = function _SpoUserGetCommand_initValidators() {
80
129
  this.validators.push(async (args) => {
81
130
  if (args.options.id &&
82
131
  typeof args.options.id !== 'number') {
83
132
  return `Specified id ${args.options.id} is not a number`;
84
133
  }
134
+ if (args.options.entraGroupId && !validation.isValidGuid(args.options.entraGroupId)) {
135
+ return `${args.options.entraGroupId} is not a valid GUID.`;
136
+ }
137
+ if (args.options.userName && !validation.isValidUserPrincipalName(args.options.userName)) {
138
+ return `${args.options.userName} is not a valid userName.`;
139
+ }
140
+ if (args.options.email && !validation.isValidUserPrincipalName(args.options.email)) {
141
+ return `${args.options.email} is not a valid email.`;
142
+ }
85
143
  return validation.isValidSharePointUrl(args.options.webUrl);
86
144
  });
87
145
  }, _SpoUserGetCommand_initOptionSets = function _SpoUserGetCommand_initOptionSets() {
88
146
  this.optionSets.push({
89
- options: ['id', 'email', 'loginName'],
90
- runsWhen: (args) => args.options.id || args.options.loginName || args.options.email
147
+ options: ['id', 'email', 'loginName', 'userName', 'entraGroupId', 'entraGroupName'],
148
+ runsWhen: (args) => args.options.id || args.options.email || args.options.loginName || args.options.userName || args.options.entraGroupId || args.options.entraGroupName
91
149
  });
92
150
  };
93
151
  export default new SpoUserGetCommand();