@pnp/cli-microsoft365 5.3.0-beta.24cd8e4 → 5.3.0-beta.2a76d05

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 (81) hide show
  1. package/dist/Auth.js +5 -0
  2. package/dist/m365/aad/commands/app/app-add.js +91 -35
  3. package/dist/m365/aad/commands/app/app-role-list.js +1 -1
  4. package/dist/m365/aad/commands/app/app-set.js +91 -0
  5. package/dist/m365/aad/commands/group/group-list.js +1 -1
  6. package/dist/m365/aad/commands/groupsetting/groupsetting-list.js +1 -1
  7. package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-get.js +1 -1
  8. package/dist/m365/aad/commands/groupsettingtemplate/groupsettingtemplate-list.js +1 -1
  9. package/dist/m365/aad/commands/o365group/o365group-conversation-list.js +1 -1
  10. package/dist/m365/aad/commands/o365group/o365group-conversation-post-list.js +1 -1
  11. package/dist/m365/aad/commands/o365group/o365group-list.js +1 -1
  12. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-clear.js +3 -3
  13. package/dist/m365/aad/commands/o365group/o365group-recyclebinitem-list.js +1 -1
  14. package/dist/m365/aad/commands/o365group/o365group-user-list.js +2 -2
  15. package/dist/m365/aad/commands/o365group/o365group-user-set.js +2 -2
  16. package/dist/m365/aad/commands/user/user-list.js +1 -1
  17. package/dist/m365/aad/commands/user/user-signin-list.js +1 -1
  18. package/dist/m365/base/PowerBICommand.js +10 -0
  19. package/dist/m365/file/commands/file-list.js +1 -1
  20. package/dist/m365/outlook/commands/message/message-list.js +1 -1
  21. package/dist/m365/outlook/commands/room/room-list.js +1 -1
  22. package/dist/m365/outlook/commands/roomlist/roomlist-list.js +1 -1
  23. package/dist/m365/planner/commands/bucket/bucket-add.js +3 -16
  24. package/dist/m365/planner/commands/bucket/bucket-get.js +3 -20
  25. package/dist/m365/planner/commands/bucket/bucket-list.js +4 -18
  26. package/dist/m365/planner/commands/bucket/bucket-remove.js +3 -20
  27. package/dist/m365/planner/commands/bucket/bucket-set.js +3 -20
  28. package/dist/m365/planner/commands/plan/plan-details-get.js +6 -14
  29. package/dist/m365/planner/commands/plan/plan-get.js +8 -18
  30. package/dist/m365/planner/commands/plan/plan-list.js +4 -12
  31. package/dist/m365/planner/commands/task/task-add.js +3 -16
  32. package/dist/m365/planner/commands/task/task-get.js +3 -21
  33. package/dist/m365/planner/commands/task/task-list.js +9 -23
  34. package/dist/m365/planner/commands/task/task-reference-add.js +75 -0
  35. package/dist/m365/planner/commands/task/task-reference-list.js +45 -0
  36. package/dist/m365/planner/commands/task/task-set.js +3 -17
  37. package/dist/m365/planner/commands.js +3 -1
  38. package/dist/m365/pp/commands/gateway/gateway-list.js +36 -0
  39. package/dist/m365/pp/commands/managementapp/managementapp-list.js +1 -1
  40. package/dist/m365/pp/commands.js +1 -0
  41. package/dist/m365/search/commands/externalconnection/externalconnection-list.js +26 -0
  42. package/dist/m365/search/commands.js +2 -1
  43. package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +119 -0
  44. package/dist/m365/spo/commands/list/list-view-add.js +113 -0
  45. package/dist/m365/spo/commands.js +2 -0
  46. package/dist/m365/teams/commands/app/app-list.js +1 -1
  47. package/dist/m365/teams/commands/channel/channel-list.js +1 -1
  48. package/dist/m365/teams/commands/channel/channel-member-add.js +4 -1
  49. package/dist/m365/teams/commands/channel/channel-member-list.js +1 -1
  50. package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -0
  51. package/dist/m365/teams/commands/channel/channel-member-set.js +3 -0
  52. package/dist/m365/teams/commands/chat/chat-get.js +8 -8
  53. package/dist/m365/teams/commands/chat/chat-list.js +1 -1
  54. package/dist/m365/teams/commands/chat/chat-member-list.js +1 -1
  55. package/dist/m365/teams/commands/chat/chat-message-list.js +1 -1
  56. package/dist/m365/teams/commands/chat/chat-message-send.js +6 -6
  57. package/dist/m365/teams/commands/chat/chatUtil.js +4 -4
  58. package/dist/m365/teams/commands/message/message-list.js +1 -1
  59. package/dist/m365/teams/commands/message/message-reply-list.js +1 -1
  60. package/dist/m365/teams/commands/tab/tab-list.js +1 -1
  61. package/dist/m365/teams/commands/team/team-list.js +1 -1
  62. package/dist/m365/teams/commands/user/user-app-list.js +1 -1
  63. package/dist/m365/teams/commands/user/user-list.js +2 -2
  64. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +1 -1
  65. package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +1 -1
  66. package/dist/m365/todo/commands/list/list-list.js +1 -1
  67. package/dist/m365/todo/commands/task/task-list.js +1 -1
  68. package/dist/utils/formatting.js +11 -2
  69. package/dist/utils/odata.js +2 -2
  70. package/dist/utils/planner.js +65 -0
  71. package/docs/docs/cmd/aad/app/app-add.md +15 -0
  72. package/docs/docs/cmd/aad/app/app-set.md +17 -0
  73. package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.md +1 -1
  74. package/docs/docs/cmd/planner/task/task-reference-add.md +45 -0
  75. package/docs/docs/cmd/planner/task/task-reference-list.md +24 -0
  76. package/docs/docs/cmd/pp/gateway/gateway-list.md +21 -0
  77. package/docs/docs/cmd/search/externalconnection/externalconnection-list.md +21 -0
  78. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +70 -0
  79. package/docs/docs/cmd/spo/list/list-view-add.md +67 -0
  80. package/docs/docs/cmd/spo/userprofile/userprofile-get.md +1 -1
  81. package/package.json +2 -1
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.planner = void 0;
13
+ const request_1 = require("../request");
14
+ const odata_1 = require("./odata");
15
+ const graphResource = 'https://graph.microsoft.com';
16
+ const getRequestOptions = (url, metadata) => ({
17
+ url: url,
18
+ headers: {
19
+ accept: `application/json;odata.metadata=${metadata}`
20
+ },
21
+ responseType: 'json'
22
+ });
23
+ exports.planner = {
24
+ /**
25
+ * Get Planner plan by ID.
26
+ * @param id Planner ID.
27
+ */
28
+ getPlanById(id) {
29
+ return __awaiter(this, void 0, void 0, function* () {
30
+ const requestOptions = getRequestOptions(`${graphResource}/v1.0/planner/plans/${id}`, 'none');
31
+ try {
32
+ return yield request_1.default.get(requestOptions);
33
+ }
34
+ catch (ex) {
35
+ throw Error(`Planner plan with id '${id}' was not found.`);
36
+ }
37
+ });
38
+ },
39
+ /**
40
+ * Get all Planner plans for a specific group.
41
+ * @param groupId Group ID.
42
+ */
43
+ getPlansByGroupId(groupId) {
44
+ return odata_1.odata.getAllItems(`${graphResource}/v1.0/groups/${groupId}/planner/plans`, 'none');
45
+ },
46
+ /**
47
+ * Get Planner plan by name in a specific group.
48
+ * @param name Name of the Planner plan. Case insensitive.
49
+ * @param groupId Owner group ID .
50
+ */
51
+ getPlanByName(name, groupId) {
52
+ return __awaiter(this, void 0, void 0, function* () {
53
+ const plans = yield this.getPlansByGroupId(groupId);
54
+ const filteredPlans = plans.filter(p => p.title && p.title.toLowerCase() === name.toLowerCase());
55
+ if (!filteredPlans.length) {
56
+ throw Error(`The specified plan '${name}' does not exist.`);
57
+ }
58
+ if (filteredPlans.length > 1) {
59
+ throw Error(`Multiple plans with name '${name}' found: ${filteredPlans.map(x => x.id)}.`);
60
+ }
61
+ return filteredPlans[0];
62
+ });
63
+ }
64
+ };
65
+ //# sourceMappingURL=planner.js.map
@@ -49,6 +49,15 @@ m365 aad app add [options]
49
49
  `--scopeAdminConsentDescription [scopeAdminConsentDescription]`
50
50
  : Scope admin consent description
51
51
 
52
+ `--certificateFile [certificateFile]`
53
+ : Path to the file with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
54
+
55
+ `--certificateBase64Encoded [certificateBase64Encoded]`
56
+ : Base64-encoded string with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
57
+
58
+ `--certificateDisplayName [certificateDisplayName]`
59
+ : Display name for the certificate. If not given, the displayName will be set to the certificate subject. When specified, also specify either `certificateFile` or `certificateBase64Encoded`
60
+
52
61
  `--manifest [manifest]`
53
62
  : Azure AD app manifest as retrieved from the Azure Portal to create the app registration from
54
63
 
@@ -152,3 +161,9 @@ Create new Azure AD app registration with the specified name. Store information
152
161
  ```sh
153
162
  m365 aad app add --name 'My AAD app' --save
154
163
  ```
164
+
165
+ Create new Azure AD app registration with a certificate
166
+
167
+ ```sh
168
+ m365 aad app add --name 'My AAD app' --certificateDisplayName "Some certificate name" --certificateFile c:\temp\some-certificate.cer
169
+ ```
@@ -31,6 +31,15 @@ m365 aad app set [options]
31
31
  `--redirectUrisToRemove [redirectUrisToRemove]`
32
32
  : Comma-separated list of existing redirect URIs to remove. Specify, when you want to replace existing redirect URIs with another
33
33
 
34
+ `--certificateFile [certificateFile]`
35
+ : Path to the file with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
36
+
37
+ `--certificateBase64Encoded [certificateBase64Encoded]`
38
+ : Base64-encoded string with certificate public key. Specify either `certificateFile` or `certificateBase64Encoded`
39
+
40
+ `--certificateDisplayName [certificateDisplayName]`
41
+ : Display name for the certificate. If not given, the displayName will be set to the certificate subject. When specified, also specify either `certificateFile` or `certificateBase64Encoded`
42
+
34
43
  --8<-- "docs/cmd/_global.md"
35
44
 
36
45
  ## Remarks
@@ -39,6 +48,8 @@ For best performance use the `objectId` option to reference the Azure AD applica
39
48
 
40
49
  If the command finds multiple Azure AD application registrations with the specified app name, it will prompt you to disambiguate which app it should use, listing the discovered object IDs.
41
50
 
51
+ When a certificate is specified it will be added to the list of certificates of the app without changing existing certificates.
52
+
42
53
  ## Examples
43
54
 
44
55
  Update the app URI of the Azure AD application registration specified by its object ID
@@ -70,3 +81,9 @@ Replace one redirect URI with another for SPA authentication
70
81
  ```sh
71
82
  m365 aad app set --objectId 95cfe30d-ed44-4f9d-b73d-c66560f72e83 --redirectUris https://contoso.com/auth --platform spa --redirectUrisToRemove https://contoso.com/old-auth
72
83
  ```
84
+
85
+ Add a certificate to the app
86
+
87
+ ```sh
88
+ m365 aad app set --certificateDisplayName "Some certificate name" --certificateFile c:\temp\some-certificate.cer
89
+ ```
@@ -1,4 +1,4 @@
1
- # aad approleassignment add
1
+ # aad approleassignment remove
2
2
 
3
3
  Deletes an app role assignment for the specified Azure AD Application Registration
4
4
 
@@ -0,0 +1,45 @@
1
+ # planner task reference add
2
+
3
+ Adds a new reference to a Planner task.
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 planner task reference add [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-i, --taskId <taskId>`
14
+ : ID of the task.
15
+
16
+ `-u, --url <url>`
17
+ : URL location of the reference.
18
+
19
+ `--alias [alias]`
20
+ : A name alias to describe the reference.
21
+
22
+ `--type [type]`
23
+ : Used to describe the type of the reference. Types include: `PowerPoint`, `Word`, `Excel`, `Other`.
24
+
25
+ --8<-- "docs/cmd/_global.md"
26
+
27
+ ## Examples
28
+
29
+ Add a new reference with the url _https://www.microsoft.com_ to a Planner task with the id _2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2_
30
+
31
+ ```sh
32
+ m365 planner task reference add --taskId "2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2" --url "https://www.microsoft.com"
33
+ ```
34
+
35
+ Add a new reference with the url _https://www.microsoft.com_ and with the alias _Parker_ to a Planner task with the id _2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2_
36
+
37
+ ```sh
38
+ m365 planner task reference add --taskId "2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2" --url "https://www.microsoft.com" --alias "Parker"
39
+ ```
40
+
41
+ Add a new reference with the url _https://www.microsoft.com_ and with the type Excel to a Planner task with the id _2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2_
42
+
43
+ ```sh
44
+ m365 planner task reference add --taskId "2Vf8JHgsBUiIf-nuvBtv-ZgAAYw2" --url "https://www.microsoft.com" --type "Excel"
45
+ ```
@@ -0,0 +1,24 @@
1
+ # planner task reference list
2
+
3
+ Retrieve the references associated to a Planner task.
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 planner task reference list [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-i, --taskId <taskId>`
14
+ : ID of the task to retrieve references from
15
+
16
+ --8<-- "docs/cmd/_global.md"
17
+
18
+ ## Examples
19
+
20
+ Retrieve the references of the specified planner task
21
+
22
+ ```sh
23
+ m365 planner task reference list --taskId uBk5fK_MHkeyuPYlCo4OFpcAM
24
+ ```
@@ -0,0 +1,21 @@
1
+ # pp gateway list
2
+
3
+ Returns a list of gateways for which the user is an admin
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 pp gateway list [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ --8<-- "docs/cmd/_global.md"
14
+
15
+ ## Examples
16
+
17
+ List gateways for which the user is an admin
18
+
19
+ ```sh
20
+ m365 pp gateway list
21
+ ```
@@ -0,0 +1,21 @@
1
+ # search externalconnection list
2
+
3
+ Lists external connections defined in Microsoft Search
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 search externalconnection list [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ --8<-- "docs/cmd/_global.md"
14
+
15
+ ## Examples
16
+
17
+ List external connections defined in Microsoft Search
18
+
19
+ ```sh
20
+ m365 search externalconnection list
21
+ ```
@@ -0,0 +1,70 @@
1
+ # spo eventreceiver get
2
+
3
+ Retrieves specific event receiver for the specified web, site or list by event receiver name or id.
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 spo eventreceiver get [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-u, --webUrl <webUrl>`
14
+ : The URL of the web for which to retrieve the event receivers.
15
+
16
+ `--listTitle [listTitle]`
17
+ : The title of the list for which to retrieve the event receivers, _if the event receivers should be retrieved from a list_.
18
+ Specify either `listTitle`, `listId` or `listUrl`.
19
+
20
+ `--listId [listId]`
21
+ : The id of the list for which to retrieve the event receivers, _if the event receivers should be retrieved from a list_.
22
+ Specify either `listTitle`, `listId` or `listUrl`.
23
+
24
+ `--listUrl [listUrl]`
25
+ : The url of the list for which to retrieve the event receivers, _if the event receivers should be retrieved from a list_.
26
+ Specify either `listTitle`, `listId` or `listUrl`.
27
+
28
+ `-n, --name [name]`
29
+ The name of the event receiver to retrieve. Specify either `name` or `id` but not both.
30
+
31
+ `-i, --id [id]`
32
+ The id of the event receiver to retrieve. Specify either `name` or `id` but not both.
33
+
34
+ `-s, --scope [scope]`
35
+ : The scope of which to retrieve the Event Receivers.
36
+ Can be either "site" or "web". Defaults to "web". Only applicable when not specifying any of the list properties.
37
+
38
+ --8<-- "docs/cmd/_global.md"
39
+
40
+ ## Examples
41
+
42
+ Retrieve event receivers in web _<https://contoso.sharepoint.com/sites/contoso-sales>_ with name _PnP Test Receiver_.
43
+
44
+ ```sh
45
+ m365 spo eventreceiver list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --name 'PnP Test Receiver'
46
+ ```
47
+
48
+ Retrieve event receivers in site _<https://contoso.sharepoint.com/sites/contoso-sales>_ with id _c5a6444a-9c7f-4a0d-9e29-fc6fe30e34ec_.
49
+
50
+ ```sh
51
+ m365 spo eventreceiver list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --scope site --id c5a6444a-9c7f-4a0d-9e29-fc6fe30e34ec
52
+ ```
53
+
54
+ Retrieve event receivers for list with title _Events_ in web _<https://contoso.sharepoint.com/sites/contoso-sales>_ with name _PnP Test Receiver_.
55
+
56
+ ```sh
57
+ m365 spo eventreceiver list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listTitle Events --name 'PnP Test Receiver'
58
+ ```
59
+
60
+ Retrieve event receivers for list with ID _202b8199-b9de-43fd-9737-7f213f51c991_ in web _<https://contoso.sharepoint.com/sites/contoso-sales>_ with id _c5a6444a-9c7f-4a0d-9e29-fc6fe30e34ec_.
61
+
62
+ ```sh
63
+ m365 spo eventreceiver list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listId '202b8199-b9de-43fd-9737-7f213f51c991' --id c5a6444a-9c7f-4a0d-9e29-fc6fe30e34ec
64
+ ```
65
+
66
+ Retrieve event receivers for list with url _/sites/contoso-sales/lists/Events_ in web _<https://contoso.sharepoint.com/sites/contoso-sales>_ with name _PnP Test Receiver_.
67
+
68
+ ```sh
69
+ m365 spo eventreceiver list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listUrl '/sites/contoso-sales/lists/Events' --name 'PnP Test Receiver'
70
+ ```
@@ -0,0 +1,67 @@
1
+ # spo list view add
2
+
3
+ Adds a new view to a SharePoint list
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 spo list view add [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-u, --webUrl <webUrl>`
14
+ : URL of the site where the list is located.
15
+
16
+ `--listId [listId]`
17
+ : ID of the list to which the view should be added. Specify either `listId`, `listTitle` or `listUrl` but not multiple.
18
+
19
+ `--listTitle [listTitle]`
20
+ : Title of the list to which the view should be added. Specify either `listId`, `listTitle` or `listUrl` but not multiple.
21
+
22
+ `--listUrl [listUrl]`
23
+ : Relative URL of the list to which the view should be added. Specify either `listId`, `listTitle` or `listUrl` but not multiple.
24
+
25
+ `--title <title>`
26
+ : Title of the view to be created for the list.
27
+
28
+ `--fields <fields>`
29
+ : Comma-separated list of **case-sensitive** internal names of the fields to add to the view.
30
+
31
+ `--personal`
32
+ : View will be created as personal view, if specified.
33
+
34
+ `--default`
35
+ : View will be set as default view, if specified.
36
+
37
+ `--paged`
38
+ : View supports paging, if specified (recommended to use this).
39
+
40
+ `--rowLimit [rowLimit]`
41
+ : Sets the number of items to display for the view. Default value is 30.
42
+
43
+ --8<-- "docs/cmd/_global.md"
44
+
45
+ ## Remarks
46
+
47
+ We recommend using the `paged` option. When specified, the view supports displaying more items page by page (default behavior). When not specified, the `rowLimit` is absolute, and there is no link to see more items.
48
+
49
+ ## Examples
50
+
51
+ Add a view called _All events_ to a list with specific title.
52
+
53
+ ```sh
54
+ spo list view add --webUrl https://contoso.sharepoint.com/sites/project-x --listTitle "My List" --title "All events" --fields "FieldName1,FieldName2,Created,Author,Modified,Editor" --paged
55
+ ```
56
+
57
+ Add a view as default view with title _All events_ to a list with a specific URL.
58
+
59
+ ```sh
60
+ spo list view add --webUrl https://contoso.sharepoint.com/sites/project-x --listUrl "/Lists/MyList" --title "All events" --fields "FieldName1,Created" --paged --default
61
+ ```
62
+
63
+ Add a personal view called _All events_ to a list with a specific ID.
64
+
65
+ ```sh
66
+ spo list view add --webUrl https://contoso.sharepoint.com/sites/project-x --listId 00000000-0000-0000-0000-000000000000 --title "All events" --fields "FieldName1,Created" --paged --personal
67
+ ```
@@ -1,4 +1,4 @@
1
- # spo userprofile set
1
+ # spo userprofile get
2
2
 
3
3
  Get SharePoint user profile properties for the specified user
4
4
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pnp/cli-microsoft365",
3
- "version": "5.3.0-beta.24cd8e4",
3
+ "version": "5.3.0-beta.2a76d05",
4
4
  "description": "Manage Microsoft 365 and SharePoint Framework projects on any platform",
5
5
  "license": "MIT",
6
6
  "main": "./dist/api.js",
@@ -131,6 +131,7 @@
131
131
  "Lingstuyl, Martin <martin@i4-you.com>",
132
132
  "Maillot, Michaël <battosaimykle@gmail.com>",
133
133
  "Mastykarz, Waldek <waldek@mastykarz.nl>",
134
+ "Mathijs Verbeeck <verbeeckmathijs@gmail.com>",
134
135
  "McDonnell, Kevin <kevin@mcd79.com>",
135
136
  "Menon, Arjun <arjun.umenon@gmail.com>",
136
137
  "Moujahid, Abderahman <rags_place@hotmail.com>",