@pnp/cli-microsoft365 11.7.0-beta.71e4ac5 → 11.7.0-beta.837cfea

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 (86) hide show
  1. package/allCommands.json +1 -1
  2. package/allCommandsFull.json +1 -1
  3. package/dist/m365/entra/commands/user/user-license-add.js +2 -1
  4. package/dist/m365/entra/commands/user/user-license-list.js +4 -9
  5. package/dist/m365/entra/commands/user/user-license-remove.js +2 -1
  6. package/dist/m365/outlook/commands/calendar/calendar-set.js +132 -0
  7. package/dist/m365/outlook/commands/calendargroup/calendargroup-get.js +114 -0
  8. package/dist/m365/outlook/commands/calendargroup/calendargroup-set.js +115 -0
  9. package/dist/m365/outlook/commands/event/event-cancel.js +103 -0
  10. package/dist/m365/outlook/commands/event/event-remove.js +104 -0
  11. package/dist/m365/outlook/commands.js +5 -0
  12. package/dist/m365/spfx/commands/SpfxCompatibilityMatrix.js +643 -0
  13. package/dist/m365/spfx/commands/project/DeployWorkflow.js +2 -2
  14. package/dist/m365/spfx/commands/project/project-azuredevops-pipeline-add.js +13 -1
  15. package/dist/m365/spfx/commands/project/project-doctor/doctor-1.23.0-rc.0.js +19 -0
  16. package/dist/m365/spfx/commands/project/project-doctor.js +2 -1
  17. package/dist/m365/spfx/commands/project/project-github-workflow-add.js +16 -1
  18. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002021_DEVDEP_rushstack_eslint_config.js +2 -2
  19. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002032_DEVDEP_typescript_eslint_parser.js +2 -2
  20. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN015008_FILE_eslintrc_js.js +1 -1
  21. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN015016_FILE_eslint_config_js.js +10 -0
  22. package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.23.0-rc.0.js +84 -0
  23. package/dist/m365/spfx/commands/project/project-upgrade.js +12 -11
  24. package/dist/m365/spfx/commands/spfx-doctor.js +5 -631
  25. package/dist/m365/spo/commands/brandcenter/brandcenter-colors-list.js +59 -0
  26. package/dist/m365/spo/commands/propertybag/propertybag-set.js +3 -9
  27. package/dist/m365/spo/commands/tenant/tenant-settings-set.js +5 -1
  28. package/dist/m365/spo/commands.js +1 -0
  29. package/dist/m365/teams/commands/chat/chat-message-list.js +43 -4
  30. package/dist/request.js +0 -16
  31. package/dist/utils/entraApp.js +9 -2
  32. package/dist/utils/spfx.js +59 -0
  33. package/docs/docs/cmd/entra/license/license-list.mdx +19 -0
  34. package/docs/docs/cmd/entra/m365group/m365group-conversation-list.mdx +19 -0
  35. package/docs/docs/cmd/entra/m365group/m365group-conversation-post-list.mdx +19 -0
  36. package/docs/docs/cmd/entra/m365group/m365group-user-add.mdx +21 -0
  37. package/docs/docs/cmd/entra/m365group/m365group-user-list.mdx +19 -0
  38. package/docs/docs/cmd/entra/m365group/m365group-user-remove.mdx +21 -0
  39. package/docs/docs/cmd/entra/m365group/m365group-user-set.mdx +21 -0
  40. package/docs/docs/cmd/entra/roledefinition/roledefinition-add.mdx +19 -0
  41. package/docs/docs/cmd/entra/roledefinition/roledefinition-get.mdx +19 -0
  42. package/docs/docs/cmd/entra/roledefinition/roledefinition-list.mdx +19 -0
  43. package/docs/docs/cmd/entra/roledefinition/roledefinition-remove.mdx +21 -0
  44. package/docs/docs/cmd/entra/roledefinition/roledefinition-set.mdx +21 -0
  45. package/docs/docs/cmd/entra/siteclassification/siteclassification-disable.mdx +21 -0
  46. package/docs/docs/cmd/entra/siteclassification/siteclassification-enable.mdx +21 -0
  47. package/docs/docs/cmd/entra/siteclassification/siteclassification-get.mdx +19 -0
  48. package/docs/docs/cmd/entra/siteclassification/siteclassification-set.mdx +20 -0
  49. package/docs/docs/cmd/entra/user/user-groupmembership-list.mdx +19 -0
  50. package/docs/docs/cmd/entra/user/user-guest-add.mdx +19 -0
  51. package/docs/docs/cmd/entra/user/user-license-add.mdx +19 -0
  52. package/docs/docs/cmd/entra/user/user-license-list.mdx +18 -1
  53. package/docs/docs/cmd/entra/user/user-license-remove.mdx +21 -0
  54. package/docs/docs/cmd/entra/user/user-password-validate.mdx +12 -0
  55. package/docs/docs/cmd/entra/user/user-recyclebinitem-clear.mdx +21 -0
  56. package/docs/docs/cmd/entra/user/user-recyclebinitem-list.mdx +19 -0
  57. package/docs/docs/cmd/entra/user/user-recyclebinitem-remove.mdx +21 -0
  58. package/docs/docs/cmd/entra/user/user-recyclebinitem-restore.mdx +19 -0
  59. package/docs/docs/cmd/entra/user/user-registrationdetails-list.mdx +19 -0
  60. package/docs/docs/cmd/entra/user/user-session-revoke.mdx +21 -0
  61. package/docs/docs/cmd/entra/user/user-signin-list.mdx +19 -0
  62. package/docs/docs/cmd/exo/approleassignment/approleassignment-add.mdx +19 -0
  63. package/docs/docs/cmd/external/connection/connection-add.mdx +21 -0
  64. package/docs/docs/cmd/external/connection/connection-doctor.mdx +19 -0
  65. package/docs/docs/cmd/external/connection/connection-get.mdx +19 -0
  66. package/docs/docs/cmd/external/connection/connection-list.mdx +19 -0
  67. package/docs/docs/cmd/external/connection/connection-remove.mdx +21 -0
  68. package/docs/docs/cmd/external/connection/connection-schema-add.mdx +21 -0
  69. package/docs/docs/cmd/external/connection/connection-urltoitemresolver-add.mdx +21 -0
  70. package/docs/docs/cmd/external/item/item-add.mdx +19 -0
  71. package/docs/docs/cmd/file/convert/convert-pdf.mdx +21 -0
  72. package/docs/docs/cmd/file/file-add.mdx +21 -0
  73. package/docs/docs/cmd/file/file-copy.mdx +21 -0
  74. package/docs/docs/cmd/file/file-list.mdx +19 -0
  75. package/docs/docs/cmd/file/file-move.mdx +21 -0
  76. package/docs/docs/cmd/outlook/calendar/calendar-set.mdx +178 -0
  77. package/docs/docs/cmd/outlook/calendargroup/calendargroup-get.mdx +125 -0
  78. package/docs/docs/cmd/outlook/calendargroup/calendargroup-set.mdx +83 -0
  79. package/docs/docs/cmd/outlook/event/event-cancel.mdx +85 -0
  80. package/docs/docs/cmd/outlook/event/event-remove.mdx +85 -0
  81. package/docs/docs/cmd/spfx/project/project-upgrade.mdx +1 -1
  82. package/docs/docs/cmd/spo/brandcenter/brandcenter-colors-list.mdx +115 -0
  83. package/docs/docs/cmd/spo/propertybag/propertybag-set.mdx +1 -1
  84. package/docs/docs/cmd/spo/tenant/tenant-settings-set.mdx +3 -0
  85. package/docs/docs/cmd/teams/chat/chat-message-list.mdx +23 -2
  86. package/package.json +2 -1
@@ -5,6 +5,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
5
5
  };
6
6
  var _EntraUserLicenseAddCommand_instances, _EntraUserLicenseAddCommand_initTelemetry, _EntraUserLicenseAddCommand_initOptions, _EntraUserLicenseAddCommand_initValidators, _EntraUserLicenseAddCommand_initOptionSets;
7
7
  import request from '../../../../request.js';
8
+ import { formatting } from '../../../../utils/formatting.js';
8
9
  import { validation } from '../../../../utils/validation.js';
9
10
  import GraphCommand from '../../../base/GraphCommand.js';
10
11
  import commands from '../../commands.js';
@@ -27,7 +28,7 @@ class EntraUserLicenseAddCommand extends GraphCommand {
27
28
  const addLicenses = args.options.ids.split(',').map(x => { return { "disabledPlans": [], "skuId": x }; });
28
29
  const requestBody = { "addLicenses": addLicenses, "removeLicenses": [] };
29
30
  const requestOptions = {
30
- url: `${this.resource}/v1.0/users/${args.options.userId || args.options.userName}/assignLicense`,
31
+ url: `${this.resource}/v1.0/users/${formatting.encodeQueryParameter(args.options.userId || args.options.userName)}/assignLicense`,
31
32
  headers: {
32
33
  accept: 'application/json;odata.metadata=none'
33
34
  },
@@ -4,13 +4,12 @@ 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 _EntraUserLicenseListCommand_instances, _EntraUserLicenseListCommand_initTelemetry, _EntraUserLicenseListCommand_initOptions, _EntraUserLicenseListCommand_initValidators, _EntraUserLicenseListCommand_initOptionSets;
7
- import { accessToken } from '../../../../utils/accessToken.js';
8
7
  import { odata } from '../../../../utils/odata.js';
8
+ import { formatting } from '../../../../utils/formatting.js';
9
9
  import { validation } from '../../../../utils/validation.js';
10
- import GraphCommand from '../../../base/GraphCommand.js';
11
10
  import commands from '../../commands.js';
12
- import auth from '../../../../Auth.js';
13
- class EntraUserLicenseListCommand extends GraphCommand {
11
+ import GraphDelegatedCommand from '../../../base/GraphDelegatedCommand.js';
12
+ class EntraUserLicenseListCommand extends GraphDelegatedCommand {
14
13
  get name() {
15
14
  return commands.USER_LICENSE_LIST;
16
15
  }
@@ -29,16 +28,12 @@ class EntraUserLicenseListCommand extends GraphCommand {
29
28
  __classPrivateFieldGet(this, _EntraUserLicenseListCommand_instances, "m", _EntraUserLicenseListCommand_initOptionSets).call(this);
30
29
  }
31
30
  async commandAction(logger, args) {
32
- const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(auth.connection.accessTokens[this.resource].accessToken);
33
- if (isAppOnlyAccessToken && !args.options.userId && !args.options.userName) {
34
- this.handleError(`Specify at least 'userId' or 'userName' when using application permissions.`);
35
- }
36
31
  if (this.verbose) {
37
32
  await logger.logToStderr(`Retrieving licenses from user: ${args.options.userId || args.options.userName || 'current user'}.`);
38
33
  }
39
34
  let requestUrl = `${this.resource}/v1.0/`;
40
35
  if (args.options.userId || args.options.userName) {
41
- requestUrl += `users/${args.options.userId || args.options.userName}`;
36
+ requestUrl += `users/${formatting.encodeQueryParameter(args.options.userId || args.options.userName)}`;
42
37
  }
43
38
  else {
44
39
  requestUrl += 'me';
@@ -7,6 +7,7 @@ var _EntraUserLicenseRemoveCommand_instances, _EntraUserLicenseRemoveCommand_ini
7
7
  import commands from '../../commands.js';
8
8
  import request from '../../../../request.js';
9
9
  import { validation } from '../../../../utils/validation.js';
10
+ import { formatting } from '../../../../utils/formatting.js';
10
11
  import { cli } from '../../../../cli/cli.js';
11
12
  import GraphCommand from '../../../base/GraphCommand.js';
12
13
  class EntraUserLicenseRemoveCommand extends GraphCommand {
@@ -42,7 +43,7 @@ class EntraUserLicenseRemoveCommand extends GraphCommand {
42
43
  const removeLicenses = args.options.ids.split(',');
43
44
  const requestBody = { "addLicenses": [], "removeLicenses": removeLicenses };
44
45
  const requestOptions = {
45
- url: `${this.resource}/v1.0/users/${args.options.userId || args.options.userName}/assignLicense`,
46
+ url: `${this.resource}/v1.0/users/${formatting.encodeQueryParameter(args.options.userId || args.options.userName)}/assignLicense`,
46
47
  headers: {
47
48
  accept: 'application/json;odata.metadata=none'
48
49
  },
@@ -0,0 +1,132 @@
1
+ import { z } from 'zod';
2
+ import { globalOptionsZod } from '../../../../Command.js';
3
+ import GraphCommand from '../../../base/GraphCommand.js';
4
+ import commands from '../../commands.js';
5
+ import { validation } from '../../../../utils/validation.js';
6
+ import request from '../../../../request.js';
7
+ import { accessToken } from '../../../../utils/accessToken.js';
8
+ import auth from '../../../../Auth.js';
9
+ import { calendarGroup } from '../../../../utils/calendarGroup.js';
10
+ const calendarColors = ['auto', 'lightBlue', 'lightGreen', 'lightOrange', 'lightGray', 'lightYellow', 'lightTeal', 'lightPink', 'lightBrown', 'lightRed', 'maxColor'];
11
+ export const options = z.strictObject({
12
+ ...globalOptionsZod.shape,
13
+ id: z.string().alias('i'),
14
+ name: z.string().optional().alias('n'),
15
+ userId: z.string().refine(id => validation.isValidGuid(id), {
16
+ error: e => `'${e.input}' is not a valid GUID.`
17
+ }).optional(),
18
+ userName: z.string().refine(name => validation.isValidUserPrincipalName(name), {
19
+ error: e => `'${e.input}' is not a valid UPN.`
20
+ }).optional(),
21
+ calendarGroupId: z.string().optional(),
22
+ calendarGroupName: z.string().optional(),
23
+ color: z.enum(calendarColors).optional(),
24
+ isDefault: z.boolean().optional()
25
+ });
26
+ class OutlookCalendarSetCommand extends GraphCommand {
27
+ get name() {
28
+ return commands.CALENDAR_SET;
29
+ }
30
+ get description() {
31
+ return 'Updates a calendar for a user';
32
+ }
33
+ get schema() {
34
+ return options;
35
+ }
36
+ getRefinedSchema(schema) {
37
+ return schema
38
+ .refine(options => !(options.userId && options.userName), {
39
+ error: 'Specify either userId or userName, but not both.'
40
+ })
41
+ .refine(options => !(options.calendarGroupId && options.calendarGroupName), {
42
+ error: 'Specify either calendarGroupId or calendarGroupName, but not both.'
43
+ })
44
+ .refine(options => [options.name, options.color, options.isDefault].filter(o => o !== undefined).length > 0, {
45
+ error: 'Specify at least one of the following options: name, color, or isDefault.'
46
+ });
47
+ }
48
+ async commandAction(logger, args) {
49
+ try {
50
+ const token = auth.connection.accessTokens[auth.defaultResource].accessToken;
51
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(token);
52
+ let requestUrl;
53
+ if (isAppOnlyAccessToken) {
54
+ if (!args.options.userId && !args.options.userName) {
55
+ throw 'When running with application permissions either userId or userName is required.';
56
+ }
57
+ const userIdentifier = args.options.userId ?? args.options.userName;
58
+ requestUrl = this.buildRequestUrl(userIdentifier);
59
+ }
60
+ else {
61
+ if (args.options.userId || args.options.userName) {
62
+ const currentUserId = accessToken.getUserIdFromAccessToken(token);
63
+ const currentUserName = accessToken.getUserNameFromAccessToken(token);
64
+ const isOtherUser = (args.options.userId && args.options.userId !== currentUserId) ||
65
+ (args.options.userName && args.options.userName.toLowerCase() !== currentUserName?.toLowerCase());
66
+ if (isOtherUser) {
67
+ const scopes = accessToken.getScopesFromAccessToken(token);
68
+ const hasSharedScope = scopes.some(s => s === 'Calendars.ReadWrite.Shared');
69
+ if (!hasSharedScope) {
70
+ throw 'To update calendars of other users, the Entra ID application used for authentication must have the Calendars.ReadWrite.Shared delegated permission assigned.';
71
+ }
72
+ }
73
+ const userIdentifier = args.options.userId ?? args.options.userName;
74
+ requestUrl = this.buildRequestUrl(userIdentifier);
75
+ }
76
+ else {
77
+ requestUrl = this.buildRequestUrl(undefined);
78
+ }
79
+ }
80
+ if (this.verbose) {
81
+ await logger.logToStderr(`Updating calendar '${args.options.id}'...`);
82
+ }
83
+ let calendarGroupId = args.options.calendarGroupId;
84
+ if (args.options.calendarGroupName) {
85
+ const userIdForGroup = args.options.userId ?? args.options.userName ?? accessToken.getUserIdFromAccessToken(token);
86
+ const calendarGroupResult = await calendarGroup.getUserCalendarGroupByName(userIdForGroup, args.options.calendarGroupName, 'id');
87
+ calendarGroupId = calendarGroupResult.id;
88
+ }
89
+ const url = this.buildCalendarUrl(requestUrl, args.options.id, calendarGroupId);
90
+ const requestOptions = {
91
+ url,
92
+ headers: {
93
+ accept: 'application/json;odata.metadata=none'
94
+ },
95
+ responseType: 'json',
96
+ data: this.createRequestBody(args)
97
+ };
98
+ const result = await request.patch(requestOptions);
99
+ await logger.log(result);
100
+ }
101
+ catch (err) {
102
+ this.handleRejectedODataJsonPromise(err);
103
+ }
104
+ }
105
+ buildRequestUrl(userIdentifier) {
106
+ if (userIdentifier) {
107
+ return `${this.resource}/v1.0/users('${userIdentifier}')`;
108
+ }
109
+ return `${this.resource}/v1.0/me`;
110
+ }
111
+ buildCalendarUrl(baseUrl, calendarId, calendarGroupId) {
112
+ if (calendarGroupId) {
113
+ return `${baseUrl}/calendarGroups/${calendarGroupId}/calendars/${calendarId}`;
114
+ }
115
+ return `${baseUrl}/calendars/${calendarId}`;
116
+ }
117
+ createRequestBody(args) {
118
+ const data = {};
119
+ if (args.options.name !== undefined) {
120
+ data.name = args.options.name;
121
+ }
122
+ if (args.options.color !== undefined) {
123
+ data.color = args.options.color;
124
+ }
125
+ if (args.options.isDefault !== undefined) {
126
+ data.isDefaultCalendar = args.options.isDefault;
127
+ }
128
+ return data;
129
+ }
130
+ }
131
+ export default new OutlookCalendarSetCommand();
132
+ //# sourceMappingURL=calendar-set.js.map
@@ -0,0 +1,114 @@
1
+ import { z } from 'zod';
2
+ import GraphCommand from '../../../base/GraphCommand.js';
3
+ import commands from '../../commands.js';
4
+ import { validation } from '../../../../utils/validation.js';
5
+ import { globalOptionsZod } from '../../../../Command.js';
6
+ import { formatting } from '../../../../utils/formatting.js';
7
+ import { odata } from '../../../../utils/odata.js';
8
+ import request from '../../../../request.js';
9
+ import { accessToken } from '../../../../utils/accessToken.js';
10
+ import auth from '../../../../Auth.js';
11
+ export const options = z.strictObject({
12
+ ...globalOptionsZod.shape,
13
+ id: z.string().optional(),
14
+ name: z.string().optional(),
15
+ userId: z.string().refine(id => validation.isValidGuid(id), {
16
+ error: e => `'${e.input}' is not a valid GUID.`
17
+ }).optional(),
18
+ userName: z.string().refine(name => validation.isValidUserPrincipalName(name), {
19
+ error: e => `'${e.input}' is not a valid UPN.`
20
+ }).optional()
21
+ });
22
+ class OutlookCalendarGroupGetCommand extends GraphCommand {
23
+ get name() {
24
+ return commands.CALENDARGROUP_GET;
25
+ }
26
+ get description() {
27
+ return 'Retrieve information about a calendar group for a user';
28
+ }
29
+ get schema() {
30
+ return options;
31
+ }
32
+ getRefinedSchema(schema) {
33
+ return schema
34
+ .refine(o => !(o.id && o.name), {
35
+ error: 'Specify either id or name, but not both.'
36
+ })
37
+ .refine(o => Boolean(o.id || o.name), {
38
+ error: 'Specify either id or name.'
39
+ })
40
+ .refine(o => !(o.userId && o.userName), {
41
+ error: 'Specify either userId or userName, but not both.'
42
+ });
43
+ }
44
+ async commandAction(logger, args) {
45
+ try {
46
+ const token = auth.connection.accessTokens[auth.defaultResource].accessToken;
47
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(token);
48
+ let userIdentifier = undefined;
49
+ if (args.options.userId || args.options.userName) {
50
+ userIdentifier = args.options.userId ?? args.options.userName;
51
+ }
52
+ const encodedUserIdentifier = userIdentifier
53
+ ? formatting.encodeQueryParameter(userIdentifier)
54
+ : undefined;
55
+ if (isAppOnlyAccessToken) {
56
+ if (!args.options.userId && !args.options.userName) {
57
+ throw 'When running with application permissions either userId or userName is required.';
58
+ }
59
+ }
60
+ else {
61
+ if (args.options.userId || args.options.userName) {
62
+ const currentUserId = accessToken.getUserIdFromAccessToken(token);
63
+ const currentUserName = accessToken.getUserNameFromAccessToken(token);
64
+ const isOtherUser = (args.options.userId && args.options.userId !== currentUserId) ||
65
+ (args.options.userName && args.options.userName.toLowerCase() !== currentUserName?.toLowerCase());
66
+ if (isOtherUser) {
67
+ const scopes = accessToken.getScopesFromAccessToken(token);
68
+ const hasSharedScope = scopes.some(s => s === 'Calendars.Read.Shared' || s === 'Calendars.ReadWrite.Shared');
69
+ if (!hasSharedScope) {
70
+ throw `To retrieve calendar groups of other users, the Entra ID application used for authentication must have either the Calendars.Read.Shared or Calendars.ReadWrite.Shared delegated permission assigned.`;
71
+ }
72
+ }
73
+ }
74
+ }
75
+ const getCalendarGroupByName = async (calendarGroupName) => {
76
+ const userPath = encodedUserIdentifier ? `users('${encodedUserIdentifier}')` : 'me';
77
+ const calendarGroups = await odata.getAllItems(`${this.resource}/v1.0/${userPath}/calendarGroups?$filter=name eq '${formatting.encodeQueryParameter(calendarGroupName)}'`);
78
+ if (calendarGroups.length === 0) {
79
+ throw `The specified calendar group '${calendarGroupName}' does not exist.`;
80
+ }
81
+ return calendarGroups[0];
82
+ };
83
+ if (args.options.name) {
84
+ if (this.verbose) {
85
+ await logger.logToStderr(`Retrieving calendar group '${args.options.name}'...`);
86
+ }
87
+ const result = await getCalendarGroupByName(args.options.name);
88
+ await logger.log(result);
89
+ }
90
+ else {
91
+ const calendarGroupId = args.options.id;
92
+ const userPath = encodedUserIdentifier ? `users('${encodedUserIdentifier}')` : 'me';
93
+ const requestUrl = `${this.resource}/v1.0/${userPath}/calendarGroups/${calendarGroupId}`;
94
+ if (this.verbose) {
95
+ await logger.logToStderr(`Retrieving calendar group '${calendarGroupId}'...`);
96
+ }
97
+ const requestOptions = {
98
+ url: requestUrl,
99
+ headers: {
100
+ accept: 'application/json;odata.metadata=none'
101
+ },
102
+ responseType: 'json'
103
+ };
104
+ const result = await request.get(requestOptions);
105
+ await logger.log(result);
106
+ }
107
+ }
108
+ catch (err) {
109
+ this.handleRejectedODataJsonPromise(err);
110
+ }
111
+ }
112
+ }
113
+ export default new OutlookCalendarGroupGetCommand();
114
+ //# sourceMappingURL=calendargroup-get.js.map
@@ -0,0 +1,115 @@
1
+ import { z } from 'zod';
2
+ import { globalOptionsZod } from '../../../../Command.js';
3
+ import GraphCommand from '../../../base/GraphCommand.js';
4
+ import commands from '../../commands.js';
5
+ import { validation } from '../../../../utils/validation.js';
6
+ import request from '../../../../request.js';
7
+ import { accessToken } from '../../../../utils/accessToken.js';
8
+ import auth from '../../../../Auth.js';
9
+ import { formatting } from '../../../../utils/formatting.js';
10
+ import { calendarGroup } from '../../../../utils/calendarGroup.js';
11
+ export const options = z.strictObject({
12
+ ...globalOptionsZod.shape,
13
+ id: z.string().optional(),
14
+ name: z.string().optional(),
15
+ userId: z.string().refine(id => validation.isValidGuid(id), {
16
+ error: e => `'${e.input}' is not a valid GUID.`
17
+ }).optional(),
18
+ userName: z.string().refine(name => validation.isValidUserPrincipalName(name), {
19
+ error: e => `'${e.input}' is not a valid UPN.`
20
+ }).optional(),
21
+ newName: z.string()
22
+ });
23
+ class OutlookCalendarGroupSetCommand extends GraphCommand {
24
+ get name() {
25
+ return commands.CALENDARGROUP_SET;
26
+ }
27
+ get description() {
28
+ return 'Updates a calendar group for a user';
29
+ }
30
+ get schema() {
31
+ return options;
32
+ }
33
+ getRefinedSchema(schema) {
34
+ return schema
35
+ .refine(options => !(options.userId && options.userName), {
36
+ error: 'Specify either userId or userName, but not both.'
37
+ })
38
+ .refine(options => !(!options.id && !options.name), {
39
+ error: 'Specify either id or name.'
40
+ })
41
+ .refine(options => !(options.id && options.name), {
42
+ error: 'Specify either id or name, but not both.'
43
+ });
44
+ }
45
+ async commandAction(logger, args) {
46
+ try {
47
+ const token = auth.connection.accessTokens[auth.defaultResource].accessToken;
48
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(token);
49
+ let userUrl;
50
+ let graphUserId;
51
+ if (isAppOnlyAccessToken) {
52
+ if (!args.options.userId && !args.options.userName) {
53
+ throw 'When running with application permissions either userId or userName is required.';
54
+ }
55
+ graphUserId = (args.options.userId ?? args.options.userName);
56
+ userUrl = `${this.resource}/v1.0/users('${formatting.encodeQueryParameter(graphUserId)}')`;
57
+ if (this.verbose) {
58
+ await logger.logToStderr(`Updating calendar group using application permissions for user '${graphUserId}'...`);
59
+ }
60
+ }
61
+ else if (args.options.userId || args.options.userName) {
62
+ const currentUserId = accessToken.getUserIdFromAccessToken(token);
63
+ const currentUserName = accessToken.getUserNameFromAccessToken(token);
64
+ const isOtherUser = (args.options.userId && args.options.userId !== currentUserId) ||
65
+ (args.options.userName && args.options.userName.toLowerCase() !== currentUserName?.toLowerCase());
66
+ if (isOtherUser) {
67
+ const scopes = accessToken.getScopesFromAccessToken(token);
68
+ const hasSharedScope = scopes.some(s => s === 'Calendars.ReadWrite.Shared');
69
+ if (!hasSharedScope) {
70
+ throw `To update calendar groups of other users, the Entra ID application used for authentication must have the Calendars.ReadWrite.Shared delegated permission assigned.`;
71
+ }
72
+ }
73
+ graphUserId = (args.options.userId ?? args.options.userName);
74
+ userUrl = `${this.resource}/v1.0/users('${formatting.encodeQueryParameter(graphUserId)}')`;
75
+ if (this.verbose) {
76
+ await logger.logToStderr(`Updating calendar group using delegated permissions for user '${graphUserId}'...`);
77
+ }
78
+ }
79
+ else {
80
+ graphUserId = accessToken.getUserIdFromAccessToken(token);
81
+ userUrl = `${this.resource}/v1.0/me`;
82
+ if (this.verbose) {
83
+ await logger.logToStderr('Updating calendar group for the signed-in user...');
84
+ }
85
+ }
86
+ let calendarGroupId;
87
+ if (args.options.id) {
88
+ calendarGroupId = args.options.id;
89
+ }
90
+ else {
91
+ const calendarGroupResult = await calendarGroup.getUserCalendarGroupByName(graphUserId, args.options.name);
92
+ calendarGroupId = calendarGroupResult.id;
93
+ }
94
+ if (this.verbose) {
95
+ await logger.logToStderr(`Updating calendar group '${calendarGroupId}'...`);
96
+ }
97
+ const requestOptions = {
98
+ url: `${userUrl}/calendarGroups/${calendarGroupId}`,
99
+ headers: {
100
+ accept: 'application/json;odata.metadata=none'
101
+ },
102
+ responseType: 'json',
103
+ data: {
104
+ name: args.options.newName
105
+ }
106
+ };
107
+ await request.patch(requestOptions);
108
+ }
109
+ catch (err) {
110
+ this.handleRejectedODataJsonPromise(err);
111
+ }
112
+ }
113
+ }
114
+ export default new OutlookCalendarGroupSetCommand();
115
+ //# sourceMappingURL=calendargroup-set.js.map
@@ -0,0 +1,103 @@
1
+ import auth from '../../../../Auth.js';
2
+ import request from '../../../../request.js';
3
+ import { accessToken } from '../../../../utils/accessToken.js';
4
+ import { validation } from '../../../../utils/validation.js';
5
+ import GraphCommand from '../../../base/GraphCommand.js';
6
+ import commands from '../../commands.js';
7
+ import { cli } from '../../../../cli/cli.js';
8
+ import { globalOptionsZod } from '../../../../Command.js';
9
+ import { z } from 'zod';
10
+ export const options = z.strictObject({
11
+ ...globalOptionsZod.shape,
12
+ id: z.string().alias('i'),
13
+ userId: z.string().refine(id => validation.isValidGuid(id), {
14
+ error: e => `'${e.input}' is not a valid GUID.`
15
+ }).optional(),
16
+ userName: z.string()
17
+ .refine(upn => validation.isValidUserPrincipalName(upn) === true, {
18
+ error: e => `'${e.input}' is not a valid user principal name for option 'userName'.`
19
+ })
20
+ .optional(),
21
+ comment: z.string().optional(),
22
+ force: z.boolean().optional().alias('f')
23
+ });
24
+ class OutlookEventCancelCommand extends GraphCommand {
25
+ get name() {
26
+ return commands.EVENT_CANCEL;
27
+ }
28
+ get description() {
29
+ return 'Cancels a calendar event';
30
+ }
31
+ get schema() {
32
+ return options;
33
+ }
34
+ getRefinedSchema(schema) {
35
+ return schema
36
+ .refine(options => !(options.userId && options.userName), {
37
+ error: `Specify either 'userId' or 'userName', but not both.`
38
+ });
39
+ }
40
+ async commandAction(logger, args) {
41
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(auth.connection.accessTokens[auth.defaultResource].accessToken);
42
+ let principalUrl = '';
43
+ const token = auth.connection.accessTokens[auth.defaultResource].accessToken;
44
+ if (isAppOnlyAccessToken) {
45
+ if (!args.options.userId && !args.options.userName) {
46
+ throw `The option 'userId' or 'userName' is required when cancelling an event using application permissions.`;
47
+ }
48
+ }
49
+ else {
50
+ if (args.options.userId) {
51
+ const currentUserId = accessToken.getUserIdFromAccessToken(token);
52
+ if (args.options.userId !== currentUserId) {
53
+ throw `You can only cancel your own events when using delegated permissions. The specified userId '${args.options.userId}' does not match the current user '${currentUserId}'.`;
54
+ }
55
+ }
56
+ if (args.options.userName) {
57
+ const currentUserName = accessToken.getUserNameFromAccessToken(token);
58
+ if (args.options.userName.toLowerCase() !== currentUserName.toLowerCase()) {
59
+ throw `You can only cancel your own events when using delegated permissions. The specified userName '${args.options.userName}' does not match the current user '${currentUserName}'.`;
60
+ }
61
+ }
62
+ }
63
+ if (args.options.userId || args.options.userName) {
64
+ const userIdentifier = args.options.userId ?? args.options.userName;
65
+ principalUrl += `users('${userIdentifier}')`;
66
+ }
67
+ else {
68
+ principalUrl += 'me';
69
+ }
70
+ const cancelEvent = async () => {
71
+ try {
72
+ if (this.verbose) {
73
+ await logger.logToStderr(`Cancelling event with id '${args.options.id}'...`);
74
+ }
75
+ const requestOptions = {
76
+ url: `${this.resource}/v1.0/${principalUrl}/events/${args.options.id}/cancel`,
77
+ headers: {
78
+ accept: 'application/json;odata.metadata=none',
79
+ 'content-type': 'application/json'
80
+ },
81
+ data: {
82
+ comment: args.options.comment
83
+ }
84
+ };
85
+ await request.post(requestOptions);
86
+ }
87
+ catch (err) {
88
+ this.handleRejectedODataJsonPromise(err);
89
+ }
90
+ };
91
+ if (args.options.force) {
92
+ await cancelEvent();
93
+ }
94
+ else {
95
+ const result = await cli.promptForConfirmation({ message: `Are you sure you want to cancel event with id '${args.options.id}'?` });
96
+ if (result) {
97
+ await cancelEvent();
98
+ }
99
+ }
100
+ }
101
+ }
102
+ export default new OutlookEventCancelCommand();
103
+ //# sourceMappingURL=event-cancel.js.map
@@ -0,0 +1,104 @@
1
+ import auth from '../../../../Auth.js';
2
+ import request from '../../../../request.js';
3
+ import { accessToken } from '../../../../utils/accessToken.js';
4
+ import { validation } from '../../../../utils/validation.js';
5
+ import GraphCommand from '../../../base/GraphCommand.js';
6
+ import commands from '../../commands.js';
7
+ import { cli } from '../../../../cli/cli.js';
8
+ import { globalOptionsZod } from '../../../../Command.js';
9
+ import { z } from 'zod';
10
+ export const options = z.strictObject({
11
+ ...globalOptionsZod.shape,
12
+ id: z.string().alias('i'),
13
+ userId: z.string().refine(id => validation.isValidGuid(id), {
14
+ error: e => `'${e.input}' is not a valid GUID.`
15
+ }).optional(),
16
+ userName: z.string()
17
+ .refine(upn => validation.isValidUserPrincipalName(upn) === true, {
18
+ error: e => `'${e.input}' is not a valid user principal name for option 'userName'.`
19
+ })
20
+ .optional(),
21
+ permanent: z.boolean().optional(),
22
+ force: z.boolean().optional().alias('f')
23
+ });
24
+ class OutlookEventRemoveCommand extends GraphCommand {
25
+ get name() {
26
+ return commands.EVENT_REMOVE;
27
+ }
28
+ get description() {
29
+ return 'Removes an event from a calendar';
30
+ }
31
+ get schema() {
32
+ return options;
33
+ }
34
+ getRefinedSchema(schema) {
35
+ return schema.refine(options => !options.userId || !options.userName, {
36
+ error: 'Specify either userId or userName, but not both.'
37
+ });
38
+ }
39
+ async commandAction(logger, args) {
40
+ const isAppOnlyAccessToken = accessToken.isAppOnlyAccessToken(auth.connection.accessTokens[auth.defaultResource].accessToken);
41
+ const token = auth.connection.accessTokens[auth.defaultResource].accessToken;
42
+ if (isAppOnlyAccessToken) {
43
+ if (!args.options.userId && !args.options.userName) {
44
+ throw `The option 'userId' or 'userName' is required when removing an event using application permissions.`;
45
+ }
46
+ }
47
+ else {
48
+ if (args.options.userId) {
49
+ const currentUserId = accessToken.getUserIdFromAccessToken(token);
50
+ if (args.options.userId !== currentUserId) {
51
+ throw `You can only remove your own events when using delegated permissions. The specified userId '${args.options.userId}' does not match the current user '${currentUserId}'.`;
52
+ }
53
+ }
54
+ if (args.options.userName) {
55
+ const currentUserName = accessToken.getUserNameFromAccessToken(token);
56
+ if (args.options.userName.toLowerCase() !== currentUserName.toLowerCase()) {
57
+ throw `You can only remove your own events when using delegated permissions. The specified userName '${args.options.userName}' does not match the current user '${currentUserName}'.`;
58
+ }
59
+ }
60
+ }
61
+ let principalUrl = '';
62
+ const userIdentifier = args.options.userId ?? args.options.userName;
63
+ if (userIdentifier) {
64
+ principalUrl += `users('${userIdentifier}')`;
65
+ }
66
+ else {
67
+ principalUrl += 'me';
68
+ }
69
+ const removeEvent = async () => {
70
+ try {
71
+ if (this.verbose) {
72
+ await logger.logToStderr(`Removing event with id '${args.options.id}'...`);
73
+ }
74
+ const requestOptions = {
75
+ url: `${this.resource}/v1.0/${principalUrl}/events/${args.options.id}`,
76
+ headers: {
77
+ accept: 'application/json;odata.metadata=none'
78
+ }
79
+ };
80
+ if (args.options.permanent) {
81
+ requestOptions.url += '/permanentDelete';
82
+ await request.post(requestOptions);
83
+ }
84
+ else {
85
+ await request.delete(requestOptions);
86
+ }
87
+ }
88
+ catch (err) {
89
+ this.handleRejectedODataJsonPromise(err);
90
+ }
91
+ };
92
+ if (args.options.force) {
93
+ await removeEvent();
94
+ }
95
+ else {
96
+ const result = await cli.promptForConfirmation({ message: `Are you sure you want to remove event with id '${args.options.id}'?` });
97
+ if (result) {
98
+ await removeEvent();
99
+ }
100
+ }
101
+ }
102
+ }
103
+ export default new OutlookEventRemoveCommand();
104
+ //# sourceMappingURL=event-remove.js.map
@@ -3,8 +3,13 @@ export default {
3
3
  CALENDAR_ADD: `${prefix} calendar add`,
4
4
  CALENDAR_GET: `${prefix} calendar get`,
5
5
  CALENDAR_REMOVE: `${prefix} calendar remove`,
6
+ CALENDAR_SET: `${prefix} calendar set`,
7
+ CALENDARGROUP_GET: `${prefix} calendargroup get`,
6
8
  CALENDARGROUP_LIST: `${prefix} calendargroup list`,
9
+ CALENDARGROUP_SET: `${prefix} calendargroup set`,
10
+ EVENT_CANCEL: `${prefix} event cancel`,
7
11
  EVENT_LIST: `${prefix} event list`,
12
+ EVENT_REMOVE: `${prefix} event remove`,
8
13
  MAIL_SEARCHFOLDER_ADD: `${prefix} mail searchfolder add`,
9
14
  MAIL_SEND: `${prefix} mail send`,
10
15
  MAILBOX_SETTINGS_GET: `${prefix} mailbox settings get`,