@pnp/cli-microsoft365 10.0.0-beta.787c5f1 → 10.0.0-beta.7be7794

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 (125) hide show
  1. package/allCommands.json +1 -1
  2. package/allCommandsFull.json +1 -1
  3. package/dist/Auth.js +6 -4
  4. package/dist/AuthServer.js +7 -7
  5. package/dist/api.js +1 -1
  6. package/dist/config.js +1 -0
  7. package/dist/m365/cli/commands/cli-doctor.js +2 -2
  8. package/dist/m365/cli/commands.js +1 -2
  9. package/dist/m365/commands/login.js +120 -67
  10. package/dist/m365/entra/commands/group/{group-user-add.js → group-member-add.js} +18 -18
  11. package/dist/m365/entra/commands/group/{group-user-list.js → group-member-list.js} +17 -17
  12. package/dist/m365/entra/commands/group/{group-user-set.js → group-member-set.js} +19 -19
  13. package/dist/m365/entra/commands/m365group/m365group-set.js +159 -81
  14. package/dist/m365/entra/commands/m365group/m365group-user-add.js +5 -12
  15. package/dist/m365/entra/commands/oauth2grant/oauth2grant-list.js +3 -12
  16. package/dist/m365/entra/commands.js +3 -3
  17. package/dist/m365/external/commands/item/item-add.js +2 -5
  18. package/dist/m365/file/commands/file-move.js +135 -0
  19. package/dist/m365/file/commands.js +2 -1
  20. package/dist/m365/flow/commands/environment/environment-list.js +1 -1
  21. package/dist/m365/pa/commands/app/app-list.js +1 -6
  22. package/dist/m365/pa/commands/connector/connector-list.js +1 -6
  23. package/dist/m365/pa/commands/environment/environment-list.js +1 -1
  24. package/dist/m365/pp/commands/environment/environment-list.js +1 -1
  25. package/dist/m365/spfx/commands/project/project-doctor/doctor-1.20.0.js +27 -0
  26. package/dist/m365/spfx/commands/project/project-doctor/rules/FN002021_DEVDEP_rushstack_eslint_config.js +10 -0
  27. package/dist/m365/spfx/commands/project/project-doctor.js +2 -1
  28. package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.20.0.js +59 -0
  29. package/dist/m365/spfx/commands/project/project-upgrade.js +2 -1
  30. package/dist/m365/spfx/commands/spfx-doctor.js +15 -0
  31. package/dist/m365/spo/commands/app/app-instance-list.js +3 -18
  32. package/dist/m365/spo/commands/app/app-list.js +1 -8
  33. package/dist/m365/spo/commands/feature/feature-list.js +1 -8
  34. package/dist/m365/spo/commands/file/file-copy.js +5 -1
  35. package/dist/m365/spo/commands/file/file-move.js +55 -33
  36. package/dist/m365/spo/commands/list/list-webhook-list.js +1 -6
  37. package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +1 -8
  38. package/dist/m365/spo/commands/page/page-list.js +1 -1
  39. package/dist/m365/spo/commands/page/page-remove.js +37 -16
  40. package/dist/m365/spo/commands/page/page-template-list.js +1 -3
  41. package/dist/m365/spo/commands/site/site-admin-list.js +8 -9
  42. package/dist/m365/spo/commands/site/site-admin-remove.js +194 -0
  43. package/dist/m365/spo/commands/site/site-sharingpermission-set.js +68 -0
  44. package/dist/m365/spo/commands/sitescript/sitescript-get.js +3 -2
  45. package/dist/m365/spo/commands/sitescript/sitescript-list.js +1 -3
  46. package/dist/m365/spo/commands/{site/site-rename.js → tenant/tenant-site-rename.js} +29 -32
  47. package/dist/m365/spo/commands/theme/theme-list.js +1 -1
  48. package/dist/m365/spo/commands/web/web-clientsidewebpart-list.js +1 -6
  49. package/dist/m365/spo/commands.js +3 -1
  50. package/dist/m365/teams/MeetingTranscript.js +2 -0
  51. package/dist/m365/teams/commands/meeting/meeting-transcript-get.js +152 -0
  52. package/dist/m365/teams/commands/tab/tab-list.js +5 -3
  53. package/dist/m365/teams/commands.js +1 -0
  54. package/dist/m365/viva/commands/engage/Community.js +2 -0
  55. package/dist/m365/viva/commands/engage/engage-community-list.js +28 -0
  56. package/dist/m365/viva/commands.js +1 -0
  57. package/dist/request.js +46 -61
  58. package/dist/utils/driveUtil.js +51 -0
  59. package/dist/utils/spo.js +8 -8
  60. package/dist/utils/timersUtil.js +12 -0
  61. package/dist/utils/urlUtil.js +8 -0
  62. package/docs/docs/cmd/cli/cli-doctor.mdx +24 -23
  63. package/docs/docs/cmd/entra/group/group-member-add.mdx +62 -0
  64. package/docs/docs/cmd/entra/group/{group-user-list.mdx → group-member-list.mdx} +14 -14
  65. package/docs/docs/cmd/entra/group/group-member-set.mdx +62 -0
  66. package/docs/docs/cmd/entra/m365group/m365group-report-activitystorage.mdx +2 -2
  67. package/docs/docs/cmd/entra/m365group/m365group-set.mdx +37 -16
  68. package/docs/docs/cmd/entra/m365group/m365group-user-add.mdx +0 -3
  69. package/docs/docs/cmd/external/item/item-add.mdx +3 -3
  70. package/docs/docs/cmd/file/file-move.mdx +79 -0
  71. package/docs/docs/cmd/login.mdx +9 -0
  72. package/docs/docs/cmd/spfx/project/project-upgrade.mdx +1 -1
  73. package/docs/docs/cmd/spo/cdn/cdn-get.mdx +1 -1
  74. package/docs/docs/cmd/spo/cdn/cdn-origin-add.mdx +1 -1
  75. package/docs/docs/cmd/spo/cdn/cdn-origin-list.mdx +1 -1
  76. package/docs/docs/cmd/spo/cdn/cdn-origin-remove.mdx +1 -1
  77. package/docs/docs/cmd/spo/cdn/cdn-policy-list.mdx +1 -1
  78. package/docs/docs/cmd/spo/cdn/cdn-policy-set.mdx +1 -1
  79. package/docs/docs/cmd/spo/externaluser/externaluser-list.mdx +1 -1
  80. package/docs/docs/cmd/spo/file/file-move.mdx +116 -9
  81. package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-get.mdx +1 -1
  82. package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-set.mdx +1 -1
  83. package/docs/docs/cmd/spo/homesite/homesite-remove.mdx +1 -1
  84. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-get.mdx +1 -1
  85. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-remove.mdx +1 -1
  86. package/docs/docs/cmd/spo/knowledgehub/knowledgehub-set.mdx +1 -1
  87. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-add.mdx +1 -1
  88. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-list.mdx +1 -1
  89. package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-remove.mdx +1 -1
  90. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-list.mdx +1 -1
  91. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-remove.mdx +1 -1
  92. package/docs/docs/cmd/spo/orgnewssite/orgnewssite-set.mdx +1 -1
  93. package/docs/docs/cmd/spo/page/page-remove.mdx +30 -12
  94. package/docs/docs/cmd/spo/site/site-admin-add.mdx +2 -2
  95. package/docs/docs/cmd/spo/site/site-admin-list.mdx +64 -12
  96. package/docs/docs/cmd/spo/site/site-admin-remove.mdx +67 -0
  97. package/docs/docs/cmd/spo/site/site-appcatalog-add.mdx +1 -1
  98. package/docs/docs/cmd/spo/site/site-appcatalog-remove.mdx +1 -1
  99. package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +1 -1
  100. package/docs/docs/cmd/spo/site/site-list.mdx +6 -4
  101. package/docs/docs/cmd/spo/site/site-set.mdx +1 -1
  102. package/docs/docs/cmd/spo/site/site-sharingpermission-set.mdx +58 -0
  103. package/docs/docs/cmd/spo/sitescript/sitescript-get.mdx +14 -1
  104. package/docs/docs/cmd/spo/storageentity/storageentity-remove.mdx +1 -1
  105. package/docs/docs/cmd/spo/storageentity/storageentity-set.mdx +1 -1
  106. package/docs/docs/cmd/spo/tenant/tenant-appcatalog-add.mdx +1 -1
  107. package/docs/docs/cmd/spo/tenant/tenant-appcatalogurl-get.mdx +1 -1
  108. package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-list.mdx +1 -1
  109. package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-remove.mdx +1 -1
  110. package/docs/docs/cmd/spo/tenant/tenant-settings-list.mdx +1 -1
  111. package/docs/docs/cmd/spo/{site/site-rename.mdx → tenant/tenant-site-rename.mdx} +7 -7
  112. package/docs/docs/cmd/spo/theme/theme-apply.mdx +1 -1
  113. package/docs/docs/cmd/spo/theme/theme-get.mdx +1 -1
  114. package/docs/docs/cmd/spo/theme/theme-list.mdx +1 -1
  115. package/docs/docs/cmd/spo/theme/theme-remove.mdx +1 -1
  116. package/docs/docs/cmd/spo/theme/theme-set.mdx +1 -1
  117. package/docs/docs/cmd/spp/contentcenter/contentcenter-list.mdx +3 -5
  118. package/docs/docs/cmd/teams/meeting/meeting-transcript-get.mdx +132 -0
  119. package/docs/docs/cmd/teams/tab/tab-list.mdx +1 -2
  120. package/docs/docs/cmd/viva/engage/engage-community-list.mdx +81 -0
  121. package/package.json +1 -1
  122. package/dist/m365/cli/commands/cli-reconsent.js +0 -29
  123. package/docs/docs/cmd/cli/cli-reconsent.mdx +0 -62
  124. package/docs/docs/cmd/entra/group/group-user-add.mdx +0 -62
  125. package/docs/docs/cmd/entra/group/group-user-set.mdx +0 -62
@@ -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);
@@ -41,12 +41,7 @@ class SpoWebClientSideWebPartListCommand extends SpoCommand {
41
41
  });
42
42
  }
43
43
  });
44
- if (clientSideWebParts.length === 0 && this.verbose) {
45
- await logger.logToStderr("No client-side web parts available for this site");
46
- }
47
- if (clientSideWebParts.length > 0) {
48
- await logger.log(clientSideWebParts);
49
- }
44
+ await logger.log(clientSideWebParts);
50
45
  }
51
46
  catch (err) {
52
47
  this.handleRejectedODataJsonPromise(err);
@@ -246,6 +246,7 @@ export default {
246
246
  SITE_ADD: `${prefix} site add`,
247
247
  SITE_ADMIN_ADD: `${prefix} site admin add`,
248
248
  SITE_ADMIN_LIST: `${prefix} site admin list`,
249
+ SITE_ADMIN_REMOVE: `${prefix} site admin remove`,
249
250
  SITE_APPCATALOG_ADD: `${prefix} site appcatalog add`,
250
251
  SITE_APPCATALOG_LIST: `${prefix} site appcatalog list`,
251
252
  SITE_APPCATALOG_REMOVE: `${prefix} site appcatalog remove`,
@@ -269,8 +270,8 @@ export default {
269
270
  SITE_RECYCLEBINITEM_REMOVE: `${prefix} site recyclebinitem remove`,
270
271
  SITE_RECYCLEBINITEM_RESTORE: `${prefix} site recyclebinitem restore`,
271
272
  SITE_REMOVE: `${prefix} site remove`,
272
- SITE_RENAME: `${prefix} site rename`,
273
273
  SITE_SET: `${prefix} site set`,
274
+ SITE_SHARINGPERMISSION_SET: `${prefix} site sharingpermission set`,
274
275
  SITE_CHROME_SET: `${prefix} site chrome set`,
275
276
  SITEDESIGN_ADD: `${prefix} sitedesign add`,
276
277
  SITEDESIGN_APPLY: `${prefix} sitedesign apply`,
@@ -320,6 +321,7 @@ export default {
320
321
  TENANT_SETTINGS_LIST: `${prefix} tenant settings list`,
321
322
  TENANT_SETTINGS_SET: `${prefix} tenant settings set`,
322
323
  TENANT_SITE_ARCHIVE: `${prefix} tenant site archive`,
324
+ TENANT_SITE_RENAME: `${prefix} tenant site rename`,
323
325
  TENANT_SITE_UNARCHIVE: `${prefix} tenant site unarchive`,
324
326
  TERM_ADD: `${prefix} term add`,
325
327
  TERM_GET: `${prefix} term get`,
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=MeetingTranscript.js.map
@@ -0,0 +1,152 @@
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 _TeamsMeetingTranscriptGetCommand_instances, _TeamsMeetingTranscriptGetCommand_initTelemetry, _TeamsMeetingTranscriptGetCommand_initOptions, _TeamsMeetingTranscriptGetCommand_initValidators, _TeamsMeetingTranscriptGetCommand_initOptionSets;
7
+ import auth from '../../../../Auth.js';
8
+ import request from '../../../../request.js';
9
+ import { entraUser } from '../../../../utils/entraUser.js';
10
+ import { accessToken } from '../../../../utils/accessToken.js';
11
+ import { validation } from '../../../../utils/validation.js';
12
+ import GraphCommand from '../../../base/GraphCommand.js';
13
+ import commands from '../../commands.js';
14
+ import fs from 'fs';
15
+ import path from 'path';
16
+ class TeamsMeetingTranscriptGetCommand extends GraphCommand {
17
+ get name() {
18
+ return commands.MEETING_TRANSCRIPT_GET;
19
+ }
20
+ get description() {
21
+ return 'Downloads a transcript for a given meeting';
22
+ }
23
+ constructor() {
24
+ super();
25
+ _TeamsMeetingTranscriptGetCommand_instances.add(this);
26
+ __classPrivateFieldGet(this, _TeamsMeetingTranscriptGetCommand_instances, "m", _TeamsMeetingTranscriptGetCommand_initTelemetry).call(this);
27
+ __classPrivateFieldGet(this, _TeamsMeetingTranscriptGetCommand_instances, "m", _TeamsMeetingTranscriptGetCommand_initOptions).call(this);
28
+ __classPrivateFieldGet(this, _TeamsMeetingTranscriptGetCommand_instances, "m", _TeamsMeetingTranscriptGetCommand_initValidators).call(this);
29
+ __classPrivateFieldGet(this, _TeamsMeetingTranscriptGetCommand_instances, "m", _TeamsMeetingTranscriptGetCommand_initOptionSets).call(this);
30
+ }
31
+ async commandAction(logger, args) {
32
+ try {
33
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(auth.connection.accessTokens[this.resource].accessToken);
34
+ if (this.verbose) {
35
+ await logger.logToStderr(`Retrieving transcript for the given meeting...`);
36
+ }
37
+ let requestUrl = `${this.resource}/beta/`;
38
+ if (isAppOnlyAccessToken) {
39
+ if (!args.options.userId && !args.options.userName && !args.options.email) {
40
+ throw `The option 'userId', 'userName' or 'email' is required when retrieving meeting transcript using app only permissions`;
41
+ }
42
+ requestUrl += 'users/';
43
+ if (args.options.userId) {
44
+ requestUrl += args.options.userId;
45
+ }
46
+ else if (args.options.userName) {
47
+ requestUrl += args.options.userName;
48
+ }
49
+ else if (args.options.email) {
50
+ if (this.verbose) {
51
+ await logger.logToStderr(`Getting user ID for user with email '${args.options.email}'.`);
52
+ }
53
+ const userId = await entraUser.getUserIdByEmail(args.options.email);
54
+ requestUrl += userId;
55
+ }
56
+ }
57
+ else {
58
+ if (args.options.userId || args.options.userName || args.options.email) {
59
+ throw `The options 'userId', 'userName', and 'email' cannot be used while retrieving meeting transcript using delegated permissions`;
60
+ }
61
+ requestUrl += `me`;
62
+ }
63
+ requestUrl += `/onlineMeetings/${args.options.meetingId}/transcripts/${args.options.id}`;
64
+ if (args.options.outputFile) {
65
+ requestUrl += '/content?$format=text/vtt';
66
+ }
67
+ const requestOptions = {
68
+ url: requestUrl,
69
+ headers: {
70
+ accept: 'application/json;odata.metadata=none'
71
+ },
72
+ responseType: args.options.outputFile ? 'stream' : 'json'
73
+ };
74
+ const meetingTranscript = await request.get(requestOptions);
75
+ if (meetingTranscript) {
76
+ if (args.options.outputFile) {
77
+ // Not possible to use async/await for this promise
78
+ await new Promise((resolve, reject) => {
79
+ const writer = fs.createWriteStream(args.options.outputFile);
80
+ meetingTranscript.data.pipe(writer);
81
+ writer.on('error', err => {
82
+ reject(err);
83
+ });
84
+ writer.on('close', async () => {
85
+ const filePath = args.options.outputFile;
86
+ if (this.verbose) {
87
+ await logger.logToStderr(`File saved to path ${filePath}`);
88
+ }
89
+ return resolve();
90
+ });
91
+ });
92
+ }
93
+ else {
94
+ await logger.log(meetingTranscript);
95
+ }
96
+ }
97
+ else {
98
+ throw `The specified meeting transcript was not found`;
99
+ }
100
+ }
101
+ catch (err) {
102
+ this.handleRejectedODataJsonPromise(err);
103
+ }
104
+ }
105
+ }
106
+ _TeamsMeetingTranscriptGetCommand_instances = new WeakSet(), _TeamsMeetingTranscriptGetCommand_initTelemetry = function _TeamsMeetingTranscriptGetCommand_initTelemetry() {
107
+ this.telemetry.push((args) => {
108
+ Object.assign(this.telemetryProperties, {
109
+ userId: typeof args.options.userId !== 'undefined',
110
+ userName: typeof args.options.userName !== 'undefined',
111
+ email: typeof args.options.email !== 'undefined',
112
+ outputFile: typeof args.options.outputFile !== 'undefined'
113
+ });
114
+ });
115
+ }, _TeamsMeetingTranscriptGetCommand_initOptions = function _TeamsMeetingTranscriptGetCommand_initOptions() {
116
+ this.options.unshift({
117
+ option: '-u, --userId [userId]'
118
+ }, {
119
+ option: '-n, --userName [userName]'
120
+ }, {
121
+ option: '--email [email]'
122
+ }, {
123
+ option: '-m, --meetingId <meetingId>'
124
+ }, {
125
+ option: '-i, --id <id>'
126
+ }, {
127
+ option: '-f, --outputFile [outputFile]'
128
+ });
129
+ }, _TeamsMeetingTranscriptGetCommand_initValidators = function _TeamsMeetingTranscriptGetCommand_initValidators() {
130
+ this.validators.push(async (args) => {
131
+ if (args.options.userId && !validation.isValidGuid(args.options.userId)) {
132
+ return `${args.options.userId} is not a valid Guid`;
133
+ }
134
+ if (args.options.userName && !validation.isValidUserPrincipalName(args.options.userName)) {
135
+ return `${args.options.userName} is not a valid user principal name (UPN)`;
136
+ }
137
+ if (args.options.email && !validation.isValidUserPrincipalName(args.options.email)) {
138
+ return `${args.options.email} is not a valid email`;
139
+ }
140
+ if (args.options.outputFile && !fs.existsSync(path.dirname(args.options.outputFile))) {
141
+ return 'Specified path where to save the file does not exits';
142
+ }
143
+ return true;
144
+ });
145
+ }, _TeamsMeetingTranscriptGetCommand_initOptionSets = function _TeamsMeetingTranscriptGetCommand_initOptionSets() {
146
+ this.optionSets.push({
147
+ options: ['userId', 'userName', 'email'],
148
+ runsWhen: (args) => args.options.userId || args.options.userName || args.options.email
149
+ });
150
+ };
151
+ export default new TeamsMeetingTranscriptGetCommand();
152
+ //# sourceMappingURL=meeting-transcript-get.js.map
@@ -29,9 +29,11 @@ class TeamsTabListCommand extends GraphCommand {
29
29
  const endpoint = `${this.resource}/v1.0/teams/${args.options.teamId}/channels/${formatting.encodeQueryParameter(args.options.channelId)}/tabs?$expand=teamsApp`;
30
30
  try {
31
31
  const items = await odata.getAllItems(endpoint);
32
- items.forEach(i => {
33
- i.teamsAppTabId = i.teamsApp.id;
34
- });
32
+ if (args.options.output !== 'json') {
33
+ items.forEach(i => {
34
+ i.teamsAppTabId = i.teamsApp.id;
35
+ });
36
+ }
35
37
  await logger.log(items);
36
38
  }
37
39
  catch (err) {
@@ -32,6 +32,7 @@ export default {
32
32
  MEETING_LIST: `${prefix} meeting list`,
33
33
  MEETING_ATTENDANCEREPORT_GET: `${prefix} meeting attendancereport get`,
34
34
  MEETING_ATTENDANCEREPORT_LIST: `${prefix} meeting attendancereport list`,
35
+ MEETING_TRANSCRIPT_GET: `${prefix} meeting transcript get`,
35
36
  MEETING_TRANSCRIPT_LIST: `${prefix} meeting transcript list`,
36
37
  MEMBERSETTINGS_LIST: `${prefix} membersettings list`,
37
38
  MEMBERSETTINGS_SET: `${prefix} membersettings set`,
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Community.js.map