@pnp/cli-microsoft365 5.3.0-beta.b46b892 → 5.3.0-beta.c04ad6e

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.
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const request_1 = require("../../../../request");
4
+ const utils_1 = require("../../../../utils");
4
5
  const GraphCommand_1 = require("../../../base/GraphCommand");
5
6
  const commands_1 = require("../../commands");
6
7
  class PlannerTaskGetCommand extends GraphCommand_1.default {
@@ -11,27 +12,169 @@ class PlannerTaskGetCommand extends GraphCommand_1.default {
11
12
  return 'Retrieve the the specified planner task';
12
13
  }
13
14
  commandAction(logger, args, cb) {
15
+ this
16
+ .getTaskId(args.options)
17
+ .then(taskId => {
18
+ const requestOptions = {
19
+ url: `${this.resource}/beta/planner/tasks/${encodeURIComponent(taskId)}`,
20
+ headers: {
21
+ accept: 'application/json;odata.metadata=none'
22
+ },
23
+ responseType: 'json'
24
+ };
25
+ return request_1.default.get(requestOptions);
26
+ })
27
+ .then((res) => {
28
+ logger.log(res);
29
+ cb();
30
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
31
+ }
32
+ getTaskId(options) {
33
+ if (options.id) {
34
+ return Promise.resolve(options.id);
35
+ }
36
+ return this
37
+ .getBucketId(options)
38
+ .then(bucketId => {
39
+ const requestOptions = {
40
+ url: `${this.resource}/v1.0/planner/buckets/${bucketId}/tasks?$select=id,title`,
41
+ headers: {
42
+ accept: 'application/json;odata.metadata=none'
43
+ },
44
+ responseType: 'json'
45
+ };
46
+ return request_1.default.get(requestOptions);
47
+ })
48
+ .then((response) => {
49
+ const title = options.title;
50
+ const tasks = response.value.filter(val => { var _a; return ((_a = val.title) === null || _a === void 0 ? void 0 : _a.toLocaleLowerCase()) === title.toLocaleLowerCase(); });
51
+ if (!tasks.length) {
52
+ return Promise.reject(`The specified task ${options.title} does not exist`);
53
+ }
54
+ if (tasks.length > 1) {
55
+ return Promise.reject(`Multiple tasks with title ${options.title} found: ${tasks.map(x => x.id)}`);
56
+ }
57
+ return Promise.resolve(tasks[0].id);
58
+ });
59
+ }
60
+ getBucketId(options) {
61
+ if (options.bucketId) {
62
+ return Promise.resolve(options.bucketId);
63
+ }
64
+ return this
65
+ .getPlanId(options)
66
+ .then(planId => {
67
+ const requestOptions = {
68
+ url: `${this.resource}/v1.0/planner/plans/${planId}/buckets?$select=id,name`,
69
+ headers: {
70
+ accept: 'application/json;odata.metadata=none'
71
+ },
72
+ responseType: 'json'
73
+ };
74
+ return request_1.default.get(requestOptions);
75
+ })
76
+ .then((response) => {
77
+ const bucketName = options.bucketName;
78
+ const buckets = response.value.filter(val => { var _a; return ((_a = val.name) === null || _a === void 0 ? void 0 : _a.toLocaleLowerCase()) === bucketName.toLocaleLowerCase(); });
79
+ if (!buckets.length) {
80
+ return Promise.reject(`The specified bucket ${options.bucketName} does not exist`);
81
+ }
82
+ if (buckets.length > 1) {
83
+ return Promise.reject(`Multiple buckets with name ${options.bucketName} found: ${buckets.map(x => x.id)}`);
84
+ }
85
+ return Promise.resolve(buckets[0].id);
86
+ });
87
+ }
88
+ getPlanId(options) {
89
+ if (options.planId) {
90
+ return Promise.resolve(options.planId);
91
+ }
92
+ return this
93
+ .getGroupId(options)
94
+ .then((groupId) => {
95
+ const requestOptions = {
96
+ url: `${this.resource}/v1.0/planner/plans?$filter=owner eq '${groupId}'&$select=id,title`,
97
+ headers: {
98
+ accept: 'application/json;odata.metadata=none'
99
+ },
100
+ responseType: 'json'
101
+ };
102
+ return request_1.default.get(requestOptions);
103
+ })
104
+ .then((response) => {
105
+ const planName = options.planName;
106
+ const plans = response.value.filter(val => { var _a; return ((_a = val.title) === null || _a === void 0 ? void 0 : _a.toLocaleLowerCase()) === planName.toLocaleLowerCase(); });
107
+ if (!plans.length) {
108
+ return Promise.reject(`The specified plan ${options.planName} does not exist`);
109
+ }
110
+ if (plans.length > 1) {
111
+ return Promise.reject(`Multiple plans with name ${options.planName} found: ${plans.map(x => x.id)}`);
112
+ }
113
+ return Promise.resolve(plans[0].id);
114
+ });
115
+ }
116
+ getGroupId(options) {
117
+ if (options.ownerGroupId) {
118
+ return Promise.resolve(options.ownerGroupId);
119
+ }
14
120
  const requestOptions = {
15
- url: `${this.resource}/beta/planner/tasks/${encodeURIComponent(args.options.id)}`,
121
+ url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(options.ownerGroupName)}'&$select=id`,
16
122
  headers: {
17
123
  accept: 'application/json;odata.metadata=none'
18
124
  },
19
125
  responseType: 'json'
20
126
  };
21
- request_1.default
127
+ return request_1.default
22
128
  .get(requestOptions)
23
- .then((res) => {
24
- logger.log(res);
25
- cb();
26
- }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
129
+ .then(response => {
130
+ const groups = response.value;
131
+ if (!groups.length) {
132
+ return Promise.reject(`The specified ownerGroup ${options.ownerGroupName} does not exist`);
133
+ }
134
+ if (groups.length > 1) {
135
+ return Promise.reject(`Multiple ownerGroups with name ${options.ownerGroupName} found: ${groups.map(x => x.id)}`);
136
+ }
137
+ return Promise.resolve(groups[0].id);
138
+ });
27
139
  }
28
140
  options() {
29
141
  const options = [
30
- { option: '-i, --id <id>' }
142
+ { option: '-i, --id [id]' },
143
+ { option: '-t, --title [title]' },
144
+ { option: '--bucketId [bucketId]' },
145
+ { option: '--bucketName [bucketName]' },
146
+ { option: '--planId [planId]' },
147
+ { option: '--planName [planName]' },
148
+ { option: '--ownerGroupId [ownerGroupId]' },
149
+ { option: '--ownerGroupName [ownerGroupName]' }
31
150
  ];
32
151
  const parentOptions = super.options();
33
152
  return options.concat(parentOptions);
34
153
  }
154
+ validate(args) {
155
+ if (args.options.title && !args.options.bucketId && !args.options.bucketName) {
156
+ return 'Specify either bucketId or bucketName when using title';
157
+ }
158
+ if (args.options.title && args.options.bucketId && args.options.bucketName) {
159
+ return 'Specify either bucketId or bucketName when using title but not both';
160
+ }
161
+ if (args.options.bucketName && !args.options.planId && !args.options.planName) {
162
+ return 'Specify either planId or planName when using bucketName';
163
+ }
164
+ if (args.options.bucketName && args.options.planId && args.options.planName) {
165
+ return 'Specify either planId or planName when using bucketName but not both';
166
+ }
167
+ if (args.options.planName && !args.options.ownerGroupId && !args.options.ownerGroupName) {
168
+ return 'Specify either ownerGroupId or ownerGroupName when using planName';
169
+ }
170
+ if (args.options.planName && args.options.ownerGroupId && args.options.ownerGroupName) {
171
+ return 'Specify either ownerGroupId or ownerGroupName when using planName but not both';
172
+ }
173
+ if (args.options.ownerGroupId && !utils_1.validation.isValidGuid(args.options.ownerGroupId)) {
174
+ return `${args.options.ownerGroupId} is not a valid GUID`;
175
+ }
176
+ return true;
177
+ }
35
178
  }
36
179
  module.exports = new PlannerTaskGetCommand();
37
180
  //# sourceMappingURL=task-get.js.map
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const request_1 = require("../../../../request");
4
+ const utils_1 = require("../../../../utils");
5
+ const SpoCommand_1 = require("../../../base/SpoCommand");
6
+ const commands_1 = require("../../commands");
7
+ class SpoFieldListCommand extends SpoCommand_1.default {
8
+ get name() {
9
+ return commands_1.default.FIELD_LIST;
10
+ }
11
+ get description() {
12
+ return 'Retrieves columns for the specified list or site';
13
+ }
14
+ getTelemetryProperties(args) {
15
+ const telemetryProps = super.getTelemetryProperties(args);
16
+ telemetryProps.listId = typeof args.options.listId !== 'undefined';
17
+ telemetryProps.listTitle = typeof args.options.listTitle !== 'undefined';
18
+ telemetryProps.listUrl = typeof args.options.listUrl !== 'undefined';
19
+ return telemetryProps;
20
+ }
21
+ defaultProperties() {
22
+ return ['Id', 'Title', 'Group', 'Hidden'];
23
+ }
24
+ commandAction(logger, args, cb) {
25
+ let listUrl = '';
26
+ if (args.options.listId) {
27
+ listUrl = `lists(guid'${encodeURIComponent(args.options.listId)}')/`;
28
+ }
29
+ else if (args.options.listTitle) {
30
+ listUrl = `lists/getByTitle('${encodeURIComponent(args.options.listTitle)}')/`;
31
+ }
32
+ else if (args.options.listUrl) {
33
+ const listServerRelativeUrl = utils_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
34
+ listUrl = `GetList('${encodeURIComponent(listServerRelativeUrl)}')/`;
35
+ }
36
+ const requestOptions = {
37
+ url: `${args.options.webUrl}/_api/web/${listUrl}fields`,
38
+ headers: {
39
+ accept: 'application/json;odata=nometadata'
40
+ },
41
+ responseType: 'json'
42
+ };
43
+ request_1.default
44
+ .get(requestOptions)
45
+ .then((res) => {
46
+ logger.log(res.value);
47
+ cb();
48
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
49
+ }
50
+ options() {
51
+ const options = [
52
+ {
53
+ option: '-u, --webUrl <webUrl>'
54
+ },
55
+ {
56
+ option: '-t, --listTitle [listTitle]'
57
+ },
58
+ {
59
+ option: '-i, --listId [listId]'
60
+ },
61
+ {
62
+ option: '--listUrl [listUrl]'
63
+ }
64
+ ];
65
+ const parentOptions = super.options();
66
+ return options.concat(parentOptions);
67
+ }
68
+ validate(args) {
69
+ const isValidSharePointUrl = utils_1.validation.isValidSharePointUrl(args.options.webUrl);
70
+ if (isValidSharePointUrl !== true) {
71
+ return isValidSharePointUrl;
72
+ }
73
+ if (args.options.listId && !utils_1.validation.isValidGuid(args.options.listId)) {
74
+ return `${args.options.listId} is not a valid GUID`;
75
+ }
76
+ const listOptions = [args.options.listId, args.options.listTitle, args.options.listUrl];
77
+ if (listOptions.some(item => item !== undefined) && listOptions.filter(item => item !== undefined).length > 1) {
78
+ return `Specify either list id or title or list url`;
79
+ }
80
+ return true;
81
+ }
82
+ }
83
+ module.exports = new SpoFieldListCommand();
84
+ //# sourceMappingURL=field-list.js.map
@@ -41,6 +41,7 @@ exports.default = {
41
41
  FEATURE_LIST: `${prefix} feature list`,
42
42
  FIELD_ADD: `${prefix} field add`,
43
43
  FIELD_GET: `${prefix} field get`,
44
+ FIELD_LIST: `${prefix} field list`,
44
45
  FIELD_REMOVE: `${prefix} field remove`,
45
46
  FIELD_SET: `${prefix} field set`,
46
47
  FILE_ADD: `${prefix} file add`,
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const GraphCommand_1 = require("../../../base/GraphCommand");
4
+ const request_1 = require("../../../../request");
5
+ const commands_1 = require("../../commands");
6
+ class TenantSecurityAlertsListCommand extends GraphCommand_1.default {
7
+ get name() {
8
+ return commands_1.default.SECURITY_ALERTS_LIST;
9
+ }
10
+ get description() {
11
+ return 'Gets the security alerts for a tenant';
12
+ }
13
+ getTelemetryProperties(args) {
14
+ const telemetryProps = super.getTelemetryProperties(args);
15
+ telemetryProps.vendor = typeof args.options.vendor !== 'undefined';
16
+ return telemetryProps;
17
+ }
18
+ defaultProperties() {
19
+ return ['id', 'title', 'severity'];
20
+ }
21
+ commandAction(logger, args, cb) {
22
+ this
23
+ .listAlert(args.options)
24
+ .then((res) => {
25
+ logger.log(res);
26
+ cb();
27
+ }, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
28
+ }
29
+ listAlert(options) {
30
+ let queryFilter = '';
31
+ if (options.vendor) {
32
+ let vendorName = options.vendor;
33
+ switch (options.vendor.toLowerCase()) {
34
+ case 'azure security center':
35
+ vendorName = 'ASC';
36
+ break;
37
+ case 'microsoft cloud app security':
38
+ vendorName = 'MCAS';
39
+ break;
40
+ case 'azure active directory identity protection':
41
+ vendorName = 'IPC';
42
+ }
43
+ queryFilter = `?$filter=vendorInformation/provider eq '${encodeURIComponent(vendorName)}'`;
44
+ }
45
+ const requestOptions = {
46
+ url: `${this.resource}/v1.0/security/alerts${queryFilter}`,
47
+ headers: {
48
+ accept: 'application/json;odata.metadata=none'
49
+ },
50
+ responseType: 'json'
51
+ };
52
+ return request_1.default
53
+ .get(requestOptions)
54
+ .then(response => {
55
+ const alertList = response.value;
56
+ if (!alertList) {
57
+ return Promise.reject(`Error fetching security alerts`);
58
+ }
59
+ return Promise.resolve(alertList);
60
+ });
61
+ }
62
+ options() {
63
+ const options = [
64
+ { option: '--vendor [vendor]' }
65
+ ];
66
+ const parentOptions = super.options();
67
+ return options.concat(parentOptions);
68
+ }
69
+ }
70
+ module.exports = new TenantSecurityAlertsListCommand();
71
+ //# sourceMappingURL=security-alerts-list.js.map
@@ -9,6 +9,7 @@ exports.default = {
9
9
  REPORT_OFFICE365ACTIVATIONSUSERDETAIL: `${prefix} report office365activationsuserdetail`,
10
10
  REPORT_OFFICE365ACTIVATIONSUSERCOUNTS: `${prefix} report office365activationsusercounts`,
11
11
  REPORT_SERVICESUSERCOUNTS: `${prefix} report servicesusercounts`,
12
+ SECURITY_ALERTS_LIST: `${prefix} security alerts list`,
12
13
  SERVICEANNOUNCEMENT_HEALTHISSUE_GET: `${prefix} serviceannouncement healthissue get`,
13
14
  SERVICEANNOUNCEMENT_HEALTH_GET: `${prefix} serviceannouncement health get`,
14
15
  SERVICEANNOUNCEMENT_HEALTH_LIST: `${prefix} serviceannouncement health list`,
@@ -10,8 +10,29 @@ m365 planner task get [options]
10
10
 
11
11
  ## Options
12
12
 
13
- `-i, --id <id>`
14
- : ID of the task to retrieve details from
13
+ `-i, --id [id]`
14
+ : ID of the task. Specify either `id` or `title` but not both. When you specify the task ID, you no longer need to provide the information for `bucket`, `plan`, and `ownerGroup`.
15
+
16
+ `-t, --title [title]`
17
+ : Title of the task. Specify either `id` or `title` but not both.
18
+
19
+ `--bucketId [bucketId]`
20
+ : Bucket ID to which the task belongs. Specify `bucketId` or `bucketName` when using `title`.
21
+
22
+ `--bucketName [bucketName]`
23
+ : Bucket Name to which the task belongs. Specify `bucketId` or `bucketName` when using `title`.
24
+
25
+ `--planId [planId]`
26
+ : Plan ID to which the task belongs. Specify `planId` or `planName` when using `bucketName`.
27
+
28
+ `--planName [planName]`
29
+ : Plan Name to which the task belongs. Specify `planId` or `planName` when using `bucketName`.
30
+
31
+ `--ownerGroupId [ownerGroupId]`
32
+ : ID of the group to which the plan belongs. Specify `ownerGroupId` or `ownerGroupName` when using `planName`.
33
+
34
+ `--ownerGroupName [ownerGroupName]`
35
+ : Name of the group to which the plan belongs. Specify `ownerGroupId` or `ownerGroupName` when using `planName`.
15
36
 
16
37
  --8<-- "docs/cmd/_global.md"
17
38
 
@@ -22,8 +43,14 @@ m365 planner task get [options]
22
43
 
23
44
  ## Examples
24
45
 
25
- Retrieve the the specified planner task
46
+ Retrieve the the specified planner task by id.
26
47
 
27
48
  ```sh
28
49
  m365 planner task get --id 'vzCcZoOv-U27PwydxHB8opcADJo-'
29
50
  ```
51
+
52
+ Retrieve the the specified planner task with the title _My Planner Task_ from the bucket named _My Planner Bucket_. Based on the plan with the name _My Planner Plan_ owned by the group _My Planner Group_.
53
+
54
+ ```sh
55
+ m365 planner task get --title "My Planner Task" --bucketName "My Planner Bucket" --planName "My Planner Plan" --ownerGroupName "My Planner Group"
56
+ ```
@@ -0,0 +1,51 @@
1
+ # spo field list
2
+
3
+ Retrieves columns for the specified list or site
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 spo field list [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `-u, --webUrl <webUrl>`
14
+ : Absolute URL of the site where fields are located
15
+
16
+ `-t, --listTitle [listTitle]`
17
+ : Title of the list where fields are located. Specify `listTitle`, `listId` or `listUrl`
18
+
19
+ `-i --listId [listId]`
20
+ : ID of the list where fields are located. Specify `listTitle`, `listId` or `listUrl`
21
+
22
+ `--listUrl [listUrl]`
23
+ : Server- or web-relative URL of the list where fields are located. Specify `listTitle`, `listId` or `listUrl`
24
+
25
+ --8<-- "docs/cmd/_global.md"
26
+
27
+ ## Examples
28
+
29
+ Retrieves site columns for site _https://contoso.sharepoint.com/sites/contoso-sales_.
30
+
31
+ ```sh
32
+ m365 spo field list --webUrl https://contoso.sharepoint.com/sites/contoso-sales
33
+ ```
34
+
35
+ Retrieves list columns for list _Events_ in site _https://contoso.sharepoint.com/sites/contoso-sales_
36
+
37
+ ```sh
38
+ m365 spo field list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listTitle Events
39
+ ```
40
+
41
+ Retrieves list columns for list _202b8199-b9de-43fd-9737-7f213f51c991_ in site _https://contoso.sharepoint.com/sites/contoso-sales_
42
+
43
+ ```sh
44
+ m365 spo field list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listId '202b8199-b9de-43fd-9737-7f213f51c991'
45
+ ```
46
+
47
+ Retrieves list columns for list _/sites/contoso-sales/lists/Events_ in site _https://contoso.sharepoint.com/sites/contoso-sales_
48
+
49
+ ```sh
50
+ m365 spo field list --webUrl https://contoso.sharepoint.com/sites/contoso-sales --listUrl '/sites/contoso-sales/lists/Events'
51
+ ```
@@ -0,0 +1,30 @@
1
+ # tenant security alerts list
2
+
3
+ Gets the security alerts for a tenant
4
+
5
+ ## Usage
6
+
7
+ ```sh
8
+ m365 tenant security alerts list [options]
9
+ ```
10
+
11
+ ## Options
12
+
13
+ `--vendor [vendor]`
14
+ : The vendor to return alerts for. Possible values `Azure Advanced Threat Protection`, `Azure Security Center`, `Microsoft Cloud App Security`, `Azure Active Directory Identity Protection`, `Azure Sentinel`, `Microsoft Defender ATP`. If omitted, all alerts are returned
15
+
16
+ --8<-- "docs/cmd/_global.md"
17
+
18
+ ## Examples
19
+
20
+ Get all security alerts for a tenant
21
+
22
+ ```sh
23
+ m365 tenant security alerts list
24
+ ```
25
+
26
+ Get security alerts for a vendor with name _Azure Sentinel_
27
+
28
+ ```sh
29
+ m365 tenant security alerts list --vendor "Azure Sentinel"
30
+ ```
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pnp/cli-microsoft365",
3
- "version": "5.3.0-beta.b46b892",
3
+ "version": "5.3.0-beta.c04ad6e",
4
4
  "description": "Manage Microsoft 365 and SharePoint Framework projects on any platform",
5
5
  "license": "MIT",
6
6
  "main": "./dist/api.js",