@pnp/cli-microsoft365 6.2.0-beta.e162995 → 6.2.0-beta.edaa477
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.
- package/.eslintrc.js +6 -0
- package/dist/m365/aad/commands/approleassignment/approleassignment-add.js +3 -0
- package/dist/m365/onenote/commands/page/page-list.js +137 -0
- package/dist/m365/onenote/commands.js +2 -1
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-list.js +68 -0
- package/dist/m365/pp/commands.js +1 -0
- package/dist/m365/purview/commands/retentionlabel/retentionlabel-add.js +143 -0
- package/dist/m365/purview/commands.js +1 -0
- package/dist/m365/spo/commands/file/GraphFileDetails.js +3 -0
- package/dist/m365/spo/commands/file/file-sharinginfo-get.js +12 -12
- package/dist/m365/spo/commands/file/file-sharinglink-get.js +116 -0
- package/dist/m365/spo/commands/file/file-sharinglink-list.js +133 -0
- package/dist/m365/spo/commands/file/file-sharinglink-remove.js +135 -0
- package/dist/m365/spo/commands/group/group-member-add.js +33 -6
- package/dist/m365/spo/commands/group/group-member-remove.js +78 -33
- package/dist/m365/spo/commands/list/list-retentionlabel-ensure.js +10 -2
- package/dist/m365/spo/commands/listitem/ListItemRetentionLabel.js +3 -0
- package/dist/m365/spo/commands/listitem/SiteRetentionLabel.js +3 -0
- package/dist/m365/spo/commands/listitem/listitem-retentionlabel-ensure.js +161 -0
- package/dist/m365/spo/commands/term/term-list.js +99 -29
- package/dist/m365/spo/commands.js +4 -0
- package/dist/m365/teams/commands/chat/chat-list.js +29 -7
- package/docs/docs/cmd/onenote/page/page-list.md +140 -0
- package/docs/docs/cmd/planner/bucket/bucket-add.md +17 -0
- package/docs/docs/cmd/planner/bucket/bucket-get.md +17 -0
- package/docs/docs/cmd/planner/bucket/bucket-list.md +17 -0
- package/docs/docs/cmd/planner/plan/plan-add.md +40 -0
- package/docs/docs/cmd/planner/plan/plan-get.md +21 -0
- package/docs/docs/cmd/planner/plan/plan-list.md +19 -0
- package/docs/docs/cmd/planner/plan/plan-set.md +20 -0
- package/docs/docs/cmd/pp/aibuildermodel/aibuildermodel-list.md +95 -0
- package/docs/docs/cmd/purview/retentionlabel/retentionlabel-add.md +128 -0
- package/docs/docs/cmd/spo/file/file-sharinglink-get.md +107 -0
- package/docs/docs/cmd/spo/file/file-sharinglink-list.md +106 -0
- package/docs/docs/cmd/spo/file/file-sharinglink-remove.md +52 -0
- package/docs/docs/cmd/spo/group/group-member-add.md +22 -4
- package/docs/docs/cmd/spo/group/group-member-remove.md +24 -6
- package/docs/docs/cmd/spo/list/list-retentionlabel-ensure.md +8 -5
- package/docs/docs/cmd/spo/listitem/listitem-retentionlabel-ensure.md +58 -0
- package/docs/docs/cmd/spo/term/term-list.md +138 -0
- package/docs/docs/cmd/teams/chat/chat-list.md +16 -4
- package/npm-shrinkwrap.json +182 -202
- package/package.json +12 -11
package/.eslintrc.js
CHANGED
|
@@ -5,11 +5,13 @@ const dictionary = [
|
|
|
5
5
|
'activation',
|
|
6
6
|
'activations',
|
|
7
7
|
'adaptive',
|
|
8
|
+
'ai',
|
|
8
9
|
'app',
|
|
9
10
|
'apply',
|
|
10
11
|
'approve',
|
|
11
12
|
'assets',
|
|
12
13
|
'bin',
|
|
14
|
+
'builder',
|
|
13
15
|
'catalog',
|
|
14
16
|
'checklist',
|
|
15
17
|
'client',
|
|
@@ -31,6 +33,7 @@ const dictionary = [
|
|
|
31
33
|
'home',
|
|
32
34
|
'hub',
|
|
33
35
|
'in',
|
|
36
|
+
'info',
|
|
34
37
|
'inheritance',
|
|
35
38
|
'init',
|
|
36
39
|
'install',
|
|
@@ -39,9 +42,11 @@ const dictionary = [
|
|
|
39
42
|
'issue',
|
|
40
43
|
'label',
|
|
41
44
|
'list',
|
|
45
|
+
'link',
|
|
42
46
|
'management',
|
|
43
47
|
'member',
|
|
44
48
|
'messaging',
|
|
49
|
+
'model',
|
|
45
50
|
'news',
|
|
46
51
|
'oauth2',
|
|
47
52
|
'office365',
|
|
@@ -60,6 +65,7 @@ const dictionary = [
|
|
|
60
65
|
'service',
|
|
61
66
|
'setting',
|
|
62
67
|
'settings',
|
|
68
|
+
'sharing',
|
|
63
69
|
'side',
|
|
64
70
|
'site',
|
|
65
71
|
'status',
|
|
@@ -58,6 +58,9 @@ class AadAppRoleAssignmentAddCommand extends GraphCommand_1.default {
|
|
|
58
58
|
};
|
|
59
59
|
try {
|
|
60
60
|
const servicePrincipalResult = yield request_1.default.get(getServicePrinciplesRequestOptions);
|
|
61
|
+
if (servicePrincipalResult.value.length === 0) {
|
|
62
|
+
return Promise.reject(`The specified service principal doesn't exist`);
|
|
63
|
+
}
|
|
61
64
|
if (servicePrincipalResult.value.length > 1) {
|
|
62
65
|
throw 'More than one service principal found. Please use the appId or appObjectId option to make sure the right service principal is specified.';
|
|
63
66
|
}
|
|
@@ -0,0 +1,137 @@
|
|
|
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
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
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");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _OneNotePageListCommand_instances, _OneNotePageListCommand_initTelemetry, _OneNotePageListCommand_initOptions, _OneNotePageListCommand_initValidators, _OneNotePageListCommand_initOptionSets;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const odata_1 = require("../../../../utils/odata");
|
|
20
|
+
const validation_1 = require("../../../../utils/validation");
|
|
21
|
+
const aadGroup_1 = require("../../../../utils/aadGroup");
|
|
22
|
+
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
23
|
+
const commands_1 = require("../../commands");
|
|
24
|
+
class OneNotePageListCommand extends GraphCommand_1.default {
|
|
25
|
+
get name() {
|
|
26
|
+
return commands_1.default.PAGE_LIST;
|
|
27
|
+
}
|
|
28
|
+
get description() {
|
|
29
|
+
return 'Retrieve a list of OneNote pages.';
|
|
30
|
+
}
|
|
31
|
+
defaultProperties() {
|
|
32
|
+
return ['createdDateTime', 'title', 'id'];
|
|
33
|
+
}
|
|
34
|
+
constructor() {
|
|
35
|
+
super();
|
|
36
|
+
_OneNotePageListCommand_instances.add(this);
|
|
37
|
+
__classPrivateFieldGet(this, _OneNotePageListCommand_instances, "m", _OneNotePageListCommand_initTelemetry).call(this);
|
|
38
|
+
__classPrivateFieldGet(this, _OneNotePageListCommand_instances, "m", _OneNotePageListCommand_initOptions).call(this);
|
|
39
|
+
__classPrivateFieldGet(this, _OneNotePageListCommand_instances, "m", _OneNotePageListCommand_initValidators).call(this);
|
|
40
|
+
__classPrivateFieldGet(this, _OneNotePageListCommand_instances, "m", _OneNotePageListCommand_initOptionSets).call(this);
|
|
41
|
+
}
|
|
42
|
+
getEndpointUrl(args) {
|
|
43
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
44
|
+
let endpoint = `${this.resource}/v1.0/`;
|
|
45
|
+
if (args.options.userId) {
|
|
46
|
+
endpoint += `users/${args.options.userId}`;
|
|
47
|
+
}
|
|
48
|
+
else if (args.options.userName) {
|
|
49
|
+
endpoint += `users/${args.options.userName}`;
|
|
50
|
+
}
|
|
51
|
+
else if (args.options.groupId) {
|
|
52
|
+
endpoint += `groups/${args.options.groupId}`;
|
|
53
|
+
}
|
|
54
|
+
else if (args.options.groupName) {
|
|
55
|
+
const groupId = yield this.getGroupId(args.options.groupName);
|
|
56
|
+
endpoint += `groups/${groupId}`;
|
|
57
|
+
}
|
|
58
|
+
else if (args.options.webUrl) {
|
|
59
|
+
const siteId = yield this.getSpoSiteId(args.options.webUrl);
|
|
60
|
+
endpoint += `sites/${siteId}`;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
endpoint += 'me';
|
|
64
|
+
}
|
|
65
|
+
endpoint += '/onenote/pages';
|
|
66
|
+
return endpoint;
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
getGroupId(groupName) {
|
|
70
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
71
|
+
const group = yield aadGroup_1.aadGroup.getGroupByDisplayName(groupName);
|
|
72
|
+
return group.id;
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
getSpoSiteId(webUrl) {
|
|
76
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
77
|
+
const url = new URL(webUrl);
|
|
78
|
+
const requestOptions = {
|
|
79
|
+
url: `${this.resource}/v1.0/sites/${url.hostname}:${url.pathname}`,
|
|
80
|
+
headers: {
|
|
81
|
+
accept: 'application/json;odata.metadata=none'
|
|
82
|
+
},
|
|
83
|
+
responseType: 'json'
|
|
84
|
+
};
|
|
85
|
+
const site = yield request_1.default.get(requestOptions);
|
|
86
|
+
return site.id;
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
commandAction(logger, args) {
|
|
90
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
91
|
+
try {
|
|
92
|
+
const endpoint = yield this.getEndpointUrl(args);
|
|
93
|
+
const items = yield odata_1.odata.getAllItems(endpoint);
|
|
94
|
+
logger.log(items);
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
this.handleRejectedODataJsonPromise(err);
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
_OneNotePageListCommand_instances = new WeakSet(), _OneNotePageListCommand_initTelemetry = function _OneNotePageListCommand_initTelemetry() {
|
|
103
|
+
this.telemetry.push((args) => {
|
|
104
|
+
Object.assign(this.telemetryProperties, {
|
|
105
|
+
userId: typeof args.options.userId !== 'undefined',
|
|
106
|
+
userName: typeof args.options.userName !== 'undefined',
|
|
107
|
+
groupId: typeof args.options.groupId !== 'undefined',
|
|
108
|
+
groupName: typeof args.options.groupName !== 'undefined',
|
|
109
|
+
webUrl: typeof args.options.webUrl !== 'undefined'
|
|
110
|
+
});
|
|
111
|
+
});
|
|
112
|
+
}, _OneNotePageListCommand_initOptions = function _OneNotePageListCommand_initOptions() {
|
|
113
|
+
this.options.unshift({ option: '--userId [userId]' }, { option: '--userName [userName]' }, { option: '--groupId [groupId]' }, { option: '--groupName [groupName]' }, { option: '-u, --webUrl [webUrl]' });
|
|
114
|
+
}, _OneNotePageListCommand_initValidators = function _OneNotePageListCommand_initValidators() {
|
|
115
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
116
|
+
if (args.options.userId && !validation_1.validation.isValidGuid(args.options.userId)) {
|
|
117
|
+
return `${args.options.userId} is not a valid GUID`;
|
|
118
|
+
}
|
|
119
|
+
if (args.options.groupId && !validation_1.validation.isValidGuid(args.options.groupId)) {
|
|
120
|
+
return `${args.options.groupId} is not a valid GUID`;
|
|
121
|
+
}
|
|
122
|
+
if (args.options.webUrl) {
|
|
123
|
+
return validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
124
|
+
}
|
|
125
|
+
return true;
|
|
126
|
+
}));
|
|
127
|
+
}, _OneNotePageListCommand_initOptionSets = function _OneNotePageListCommand_initOptionSets() {
|
|
128
|
+
this.optionSets.push({
|
|
129
|
+
options: ['userId', 'userName', 'groupId', 'groupName', 'webUrl'],
|
|
130
|
+
runsWhen: (args) => {
|
|
131
|
+
const options = [args.options.userId, args.options.userName, args.options.groupId, args.options.groupName, args.options.webUrl];
|
|
132
|
+
return options.some(item => item !== undefined);
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
};
|
|
136
|
+
module.exports = new OneNotePageListCommand();
|
|
137
|
+
//# sourceMappingURL=page-list.js.map
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const prefix = 'onenote';
|
|
4
4
|
exports.default = {
|
|
5
|
-
NOTEBOOK_LIST: `${prefix} notebook list
|
|
5
|
+
NOTEBOOK_LIST: `${prefix} notebook list`,
|
|
6
|
+
PAGE_LIST: `${prefix} page list`
|
|
6
7
|
};
|
|
7
8
|
//# sourceMappingURL=commands.js.map
|
|
@@ -0,0 +1,68 @@
|
|
|
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
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
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");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PpAiBuilderModelListCommand_instances, _PpAiBuilderModelListCommand_initTelemetry, _PpAiBuilderModelListCommand_initOptions;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const odata_1 = require("../../../../utils/odata");
|
|
19
|
+
const powerPlatform_1 = require("../../../../utils/powerPlatform");
|
|
20
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
21
|
+
const commands_1 = require("../../commands");
|
|
22
|
+
class PpAiBuilderModelListCommand extends PowerPlatformCommand_1.default {
|
|
23
|
+
get name() {
|
|
24
|
+
return commands_1.default.AIBUILDERMODEL_LIST;
|
|
25
|
+
}
|
|
26
|
+
get description() {
|
|
27
|
+
return 'List available AI builder models in the specified Power Platform environment.';
|
|
28
|
+
}
|
|
29
|
+
defaultProperties() {
|
|
30
|
+
return ['msdyn_name', 'msdyn_aimodelid', 'createdon', 'modifiedon'];
|
|
31
|
+
}
|
|
32
|
+
constructor() {
|
|
33
|
+
super();
|
|
34
|
+
_PpAiBuilderModelListCommand_instances.add(this);
|
|
35
|
+
__classPrivateFieldGet(this, _PpAiBuilderModelListCommand_instances, "m", _PpAiBuilderModelListCommand_initTelemetry).call(this);
|
|
36
|
+
__classPrivateFieldGet(this, _PpAiBuilderModelListCommand_instances, "m", _PpAiBuilderModelListCommand_initOptions).call(this);
|
|
37
|
+
}
|
|
38
|
+
commandAction(logger, args) {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
if (this.verbose) {
|
|
41
|
+
logger.logToStderr(`Retrieving available AI Builder models`);
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
const dynamicsApiUrl = yield powerPlatform_1.powerPlatform.getDynamicsInstanceApiUrl(args.options.environment, args.options.asAdmin);
|
|
45
|
+
const aimodels = yield odata_1.odata.getAllItems(`${dynamicsApiUrl}/api/data/v9.0/msdyn_aimodels?$filter=iscustomizable/Value eq true`);
|
|
46
|
+
logger.log(aimodels);
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
this.handleRejectedODataJsonPromise(err);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
_PpAiBuilderModelListCommand_instances = new WeakSet(), _PpAiBuilderModelListCommand_initTelemetry = function _PpAiBuilderModelListCommand_initTelemetry() {
|
|
55
|
+
this.telemetry.push((args) => {
|
|
56
|
+
Object.assign(this.telemetryProperties, {
|
|
57
|
+
asAdmin: !!args.options.asAdmin
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
}, _PpAiBuilderModelListCommand_initOptions = function _PpAiBuilderModelListCommand_initOptions() {
|
|
61
|
+
this.options.unshift({
|
|
62
|
+
option: '-e, --environment <environment>'
|
|
63
|
+
}, {
|
|
64
|
+
option: '--asAdmin'
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
module.exports = new PpAiBuilderModelListCommand();
|
|
68
|
+
//# sourceMappingURL=aibuildermodel-list.js.map
|
package/dist/m365/pp/commands.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const prefix = 'pp';
|
|
4
4
|
exports.default = {
|
|
5
|
+
AIBUILDERMODEL_LIST: `${prefix} aibuildermodel list`,
|
|
5
6
|
CARD_CLONE: `${prefix} card clone`,
|
|
6
7
|
CARD_GET: `${prefix} card get`,
|
|
7
8
|
CARD_LIST: `${prefix} card list`,
|
|
@@ -0,0 +1,143 @@
|
|
|
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
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
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");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PurviewRetentionLabelAddCommand_instances, _PurviewRetentionLabelAddCommand_initTelemetry, _PurviewRetentionLabelAddCommand_initOptions, _PurviewRetentionLabelAddCommand_initValidators;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
20
|
+
const commands_1 = require("../../commands");
|
|
21
|
+
class PurviewRetentionLabelAddCommand extends GraphCommand_1.default {
|
|
22
|
+
get name() {
|
|
23
|
+
return commands_1.default.RETENTIONLABEL_ADD;
|
|
24
|
+
}
|
|
25
|
+
get description() {
|
|
26
|
+
return 'Create a retention label';
|
|
27
|
+
}
|
|
28
|
+
constructor() {
|
|
29
|
+
super();
|
|
30
|
+
_PurviewRetentionLabelAddCommand_instances.add(this);
|
|
31
|
+
__classPrivateFieldGet(this, _PurviewRetentionLabelAddCommand_instances, "m", _PurviewRetentionLabelAddCommand_initTelemetry).call(this);
|
|
32
|
+
__classPrivateFieldGet(this, _PurviewRetentionLabelAddCommand_instances, "m", _PurviewRetentionLabelAddCommand_initOptions).call(this);
|
|
33
|
+
__classPrivateFieldGet(this, _PurviewRetentionLabelAddCommand_instances, "m", _PurviewRetentionLabelAddCommand_initValidators).call(this);
|
|
34
|
+
}
|
|
35
|
+
commandAction(logger, args) {
|
|
36
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
37
|
+
const retentionTrigger = args.options.retentionTrigger ? args.options.retentionTrigger : 'dateLabeled';
|
|
38
|
+
const defaultRecordBehavior = args.options.defaultRecordBehavior ? args.options.defaultRecordBehavior : 'startLocked';
|
|
39
|
+
const requestBody = {
|
|
40
|
+
displayName: args.options.displayName,
|
|
41
|
+
behaviorDuringRetentionPeriod: args.options.behaviorDuringRetentionPeriod,
|
|
42
|
+
actionAfterRetentionPeriod: args.options.actionAfterRetentionPeriod,
|
|
43
|
+
retentionTrigger: retentionTrigger,
|
|
44
|
+
retentionDuration: {
|
|
45
|
+
'@odata.type': '#microsoft.graph.security.retentionDurationInDays',
|
|
46
|
+
days: args.options.retentionDuration
|
|
47
|
+
},
|
|
48
|
+
defaultRecordBehavior: defaultRecordBehavior
|
|
49
|
+
};
|
|
50
|
+
if (args.options.descriptionForAdmins) {
|
|
51
|
+
if (this.verbose) {
|
|
52
|
+
logger.logToStderr(`Using '${args.options.descriptionForAdmins}' as descriptionForAdmins`);
|
|
53
|
+
}
|
|
54
|
+
requestBody.descriptionForAdmins = args.options.descriptionForAdmins;
|
|
55
|
+
}
|
|
56
|
+
if (args.options.descriptionForUsers) {
|
|
57
|
+
if (this.verbose) {
|
|
58
|
+
logger.logToStderr(`Using '${args.options.descriptionForUsers}' as descriptionForUsers`);
|
|
59
|
+
}
|
|
60
|
+
requestBody.descriptionForUsers = args.options.descriptionForUsers;
|
|
61
|
+
}
|
|
62
|
+
if (args.options.labelToBeApplied) {
|
|
63
|
+
if (this.verbose) {
|
|
64
|
+
logger.logToStderr(`Using '${args.options.labelToBeApplied}' as labelToBeApplied...`);
|
|
65
|
+
}
|
|
66
|
+
requestBody.labelToBeApplied = args.options.labelToBeApplied;
|
|
67
|
+
}
|
|
68
|
+
const requestOptions = {
|
|
69
|
+
url: `${this.resource}/beta/security/labels/retentionLabels`,
|
|
70
|
+
headers: {
|
|
71
|
+
accept: 'application/json;odata.metadata=none'
|
|
72
|
+
},
|
|
73
|
+
data: requestBody,
|
|
74
|
+
responseType: 'json'
|
|
75
|
+
};
|
|
76
|
+
try {
|
|
77
|
+
const response = yield request_1.default.post(requestOptions);
|
|
78
|
+
logger.log(response);
|
|
79
|
+
}
|
|
80
|
+
catch (err) {
|
|
81
|
+
this.handleRejectedODataPromise(err);
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
_PurviewRetentionLabelAddCommand_instances = new WeakSet(), _PurviewRetentionLabelAddCommand_initTelemetry = function _PurviewRetentionLabelAddCommand_initTelemetry() {
|
|
87
|
+
this.telemetry.push((args) => {
|
|
88
|
+
Object.assign(this.telemetryProperties, {
|
|
89
|
+
retentionTrigger: typeof args.options.retentionTrigger !== 'undefined',
|
|
90
|
+
defaultRecordBehavior: typeof args.options.defaultRecordBehavior !== 'undefined',
|
|
91
|
+
descriptionForUsers: typeof args.options.descriptionForUsers !== 'undefined',
|
|
92
|
+
descriptionForAdmins: typeof args.options.descriptionForAdmins !== 'undefined',
|
|
93
|
+
labelToBeApplied: typeof args.options.labelToBeApplied !== 'undefined'
|
|
94
|
+
});
|
|
95
|
+
});
|
|
96
|
+
}, _PurviewRetentionLabelAddCommand_initOptions = function _PurviewRetentionLabelAddCommand_initOptions() {
|
|
97
|
+
this.options.unshift({
|
|
98
|
+
option: '-n, --displayName <displayName>'
|
|
99
|
+
}, {
|
|
100
|
+
option: '--behaviorDuringRetentionPeriod <behaviorDuringRetentionPeriod>',
|
|
101
|
+
autocomplete: ['doNotRetain', 'retain', 'retainAsRecord', 'retainAsRegulatoryRecord']
|
|
102
|
+
}, {
|
|
103
|
+
option: '--actionAfterRetentionPeriod <actionAfterRetentionPeriod>',
|
|
104
|
+
autocomplete: ['none', 'delete', 'startDispositionReview']
|
|
105
|
+
}, {
|
|
106
|
+
option: '--retentionDuration <retentionDuration>'
|
|
107
|
+
}, {
|
|
108
|
+
option: '-t, --retentionTrigger [retentionTrigger]',
|
|
109
|
+
autocomplete: ['dateLabeled', 'dateCreated', 'dateModified', 'dateOfEvent']
|
|
110
|
+
}, {
|
|
111
|
+
option: '--defaultRecordBehavior [defaultRecordBehavior]',
|
|
112
|
+
autocomplete: ['startLocked', 'startUnlocked']
|
|
113
|
+
}, {
|
|
114
|
+
option: '--descriptionForUsers [descriptionForUsers]'
|
|
115
|
+
}, {
|
|
116
|
+
option: '--descriptionForAdmins [descriptionForAdmins]'
|
|
117
|
+
}, {
|
|
118
|
+
option: '--labelToBeApplied [labelToBeApplied]'
|
|
119
|
+
});
|
|
120
|
+
}, _PurviewRetentionLabelAddCommand_initValidators = function _PurviewRetentionLabelAddCommand_initValidators() {
|
|
121
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
122
|
+
if (isNaN(args.options.retentionDuration)) {
|
|
123
|
+
return `Specified retentionDuration ${args.options.retentionDuration} is not a number`;
|
|
124
|
+
}
|
|
125
|
+
if (['doNotRetain', 'retain', 'retainAsRecord', 'retainAsRegulatoryRecord'].indexOf(args.options.behaviorDuringRetentionPeriod) === -1) {
|
|
126
|
+
return `${args.options.behaviorDuringRetentionPeriod} is not a valid behavior of a document with the label. Allowed values are doNotRetain|retain|retainAsRecord|retainAsRegulatoryRecord`;
|
|
127
|
+
}
|
|
128
|
+
if (['none', 'delete', 'startDispositionReview'].indexOf(args.options.actionAfterRetentionPeriod) === -1) {
|
|
129
|
+
return `${args.options.actionAfterRetentionPeriod} is not a valid action to take on a document with the label. Allowed values are none|delete|startDispositionReview`;
|
|
130
|
+
}
|
|
131
|
+
if (args.options.retentionTrigger &&
|
|
132
|
+
['dateLabeled', 'dateCreated', 'dateModified', 'dateOfEvent'].indexOf(args.options.retentionTrigger) === -1) {
|
|
133
|
+
return `${args.options.retentionTrigger} is not a valid action retention duration calculation. Allowed values are dateLabeled|dateCreated|dateModified|dateOfEvent`;
|
|
134
|
+
}
|
|
135
|
+
if (args.options.defaultRecordBehavior &&
|
|
136
|
+
['startLocked', 'startUnlocked'].indexOf(args.options.defaultRecordBehavior) === -1) {
|
|
137
|
+
return `${args.options.defaultRecordBehavior} is not a valid state of a record label. Allowed values are startLocked|startUnlocked`;
|
|
138
|
+
}
|
|
139
|
+
return true;
|
|
140
|
+
}));
|
|
141
|
+
};
|
|
142
|
+
module.exports = new PurviewRetentionLabelAddCommand();
|
|
143
|
+
//# sourceMappingURL=retentionlabel-add.js.map
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const prefix = 'purview';
|
|
4
4
|
exports.default = {
|
|
5
|
+
RETENTIONLABEL_ADD: `${prefix} retentionlabel add`,
|
|
5
6
|
RETENTIONLABEL_GET: `${prefix} retentionlabel get`,
|
|
6
7
|
RETENTIONLABEL_LIST: `${prefix} retentionlabel list`,
|
|
7
8
|
RETENTIONLABEL_REMOVE: `${prefix} retentionlabel remove`,
|
|
@@ -13,7 +13,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
13
13
|
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");
|
|
14
14
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
15
|
};
|
|
16
|
-
var
|
|
16
|
+
var _SpoFileSharingInfoGetCommand_instances, _SpoFileSharingInfoGetCommand_initTelemetry, _SpoFileSharingInfoGetCommand_initOptions, _SpoFileSharingInfoGetCommand_initValidators, _SpoFileSharingInfoGetCommand_initOptionSets;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const request_1 = require("../../../../request");
|
|
19
19
|
const formatting_1 = require("../../../../utils/formatting");
|
|
@@ -21,7 +21,7 @@ const validation_1 = require("../../../../utils/validation");
|
|
|
21
21
|
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
22
22
|
const commands_1 = require("../../commands");
|
|
23
23
|
const FileSharingPrincipalType_1 = require("./FileSharingPrincipalType");
|
|
24
|
-
class
|
|
24
|
+
class SpoFileSharingInfoGetCommand extends SpoCommand_1.default {
|
|
25
25
|
get name() {
|
|
26
26
|
return commands_1.default.FILE_SHARINGINFO_GET;
|
|
27
27
|
}
|
|
@@ -30,11 +30,11 @@ class SpoFileSharinginfoGetCommand extends SpoCommand_1.default {
|
|
|
30
30
|
}
|
|
31
31
|
constructor() {
|
|
32
32
|
super();
|
|
33
|
-
|
|
34
|
-
__classPrivateFieldGet(this,
|
|
35
|
-
__classPrivateFieldGet(this,
|
|
36
|
-
__classPrivateFieldGet(this,
|
|
37
|
-
__classPrivateFieldGet(this,
|
|
33
|
+
_SpoFileSharingInfoGetCommand_instances.add(this);
|
|
34
|
+
__classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initTelemetry).call(this);
|
|
35
|
+
__classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initOptions).call(this);
|
|
36
|
+
__classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initValidators).call(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoFileSharingInfoGetCommand_instances, "m", _SpoFileSharingInfoGetCommand_initOptionSets).call(this);
|
|
38
38
|
}
|
|
39
39
|
getExcludedOptionsWithUrls() {
|
|
40
40
|
return ['fileUrl'];
|
|
@@ -113,14 +113,14 @@ class SpoFileSharinginfoGetCommand extends SpoCommand_1.default {
|
|
|
113
113
|
}));
|
|
114
114
|
}
|
|
115
115
|
}
|
|
116
|
-
|
|
116
|
+
_SpoFileSharingInfoGetCommand_instances = new WeakSet(), _SpoFileSharingInfoGetCommand_initTelemetry = function _SpoFileSharingInfoGetCommand_initTelemetry() {
|
|
117
117
|
this.telemetry.push((args) => {
|
|
118
118
|
Object.assign(this.telemetryProperties, {
|
|
119
119
|
fileId: (!(!args.options.fileId)).toString(),
|
|
120
120
|
fileUrl: (!(!args.options.fileUrl)).toString()
|
|
121
121
|
});
|
|
122
122
|
});
|
|
123
|
-
},
|
|
123
|
+
}, _SpoFileSharingInfoGetCommand_initOptions = function _SpoFileSharingInfoGetCommand_initOptions() {
|
|
124
124
|
this.options.unshift({
|
|
125
125
|
option: '-u, --webUrl <webUrl>'
|
|
126
126
|
}, {
|
|
@@ -128,7 +128,7 @@ _SpoFileSharinginfoGetCommand_instances = new WeakSet(), _SpoFileSharinginfoGetC
|
|
|
128
128
|
}, {
|
|
129
129
|
option: '-f, --fileUrl [fileUrl]'
|
|
130
130
|
});
|
|
131
|
-
},
|
|
131
|
+
}, _SpoFileSharingInfoGetCommand_initValidators = function _SpoFileSharingInfoGetCommand_initValidators() {
|
|
132
132
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
133
133
|
const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
134
134
|
if (isValidSharePointUrl !== true) {
|
|
@@ -141,8 +141,8 @@ _SpoFileSharinginfoGetCommand_instances = new WeakSet(), _SpoFileSharinginfoGetC
|
|
|
141
141
|
}
|
|
142
142
|
return true;
|
|
143
143
|
}));
|
|
144
|
-
},
|
|
144
|
+
}, _SpoFileSharingInfoGetCommand_initOptionSets = function _SpoFileSharingInfoGetCommand_initOptionSets() {
|
|
145
145
|
this.optionSets.push({ options: ['fileId', 'fileUrl'] });
|
|
146
146
|
};
|
|
147
|
-
module.exports = new
|
|
147
|
+
module.exports = new SpoFileSharingInfoGetCommand();
|
|
148
148
|
//# sourceMappingURL=file-sharinginfo-get.js.map
|
|
@@ -0,0 +1,116 @@
|
|
|
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
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
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");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _SpoFileSharingLinkGetCommand_instances, _SpoFileSharingLinkGetCommand_initTelemetry, _SpoFileSharingLinkGetCommand_initOptions, _SpoFileSharingLinkGetCommand_initValidators, _SpoFileSharingLinkGetCommand_initOptionSets;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const formatting_1 = require("../../../../utils/formatting");
|
|
20
|
+
const urlUtil_1 = require("../../../../utils/urlUtil");
|
|
21
|
+
const validation_1 = require("../../../../utils/validation");
|
|
22
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
23
|
+
const commands_1 = require("../../commands");
|
|
24
|
+
class SpoFileSharingLinkGetCommand extends SpoCommand_1.default {
|
|
25
|
+
get name() {
|
|
26
|
+
return commands_1.default.FILE_SHARINGLINK_GET;
|
|
27
|
+
}
|
|
28
|
+
get description() {
|
|
29
|
+
return 'Gets details about a specific sharing link of a file';
|
|
30
|
+
}
|
|
31
|
+
constructor() {
|
|
32
|
+
super();
|
|
33
|
+
_SpoFileSharingLinkGetCommand_instances.add(this);
|
|
34
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkGetCommand_instances, "m", _SpoFileSharingLinkGetCommand_initTelemetry).call(this);
|
|
35
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkGetCommand_instances, "m", _SpoFileSharingLinkGetCommand_initOptions).call(this);
|
|
36
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkGetCommand_instances, "m", _SpoFileSharingLinkGetCommand_initValidators).call(this);
|
|
37
|
+
__classPrivateFieldGet(this, _SpoFileSharingLinkGetCommand_instances, "m", _SpoFileSharingLinkGetCommand_initOptionSets).call(this);
|
|
38
|
+
}
|
|
39
|
+
commandAction(logger, args) {
|
|
40
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
if (this.verbose) {
|
|
42
|
+
logger.logToStderr(`Retrieving sharing link for file ${args.options.fileUrl || args.options.fileId} with id ${args.options.id}...`);
|
|
43
|
+
}
|
|
44
|
+
try {
|
|
45
|
+
const fileDetails = yield this.getNeededFileInformation(args);
|
|
46
|
+
const requestOptions = {
|
|
47
|
+
url: `https://graph.microsoft.com/v1.0/sites/${fileDetails.SiteId}/drives/${fileDetails.VroomDriveID}/items/${fileDetails.VroomItemID}/permissions/${args.options.id}`,
|
|
48
|
+
headers: {
|
|
49
|
+
accept: 'application/json;odata.metadata=none'
|
|
50
|
+
},
|
|
51
|
+
responseType: 'json'
|
|
52
|
+
};
|
|
53
|
+
const res = yield request_1.default.get(requestOptions);
|
|
54
|
+
logger.log(res);
|
|
55
|
+
}
|
|
56
|
+
catch (err) {
|
|
57
|
+
this.handleRejectedODataJsonPromise(err);
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
getNeededFileInformation(args) {
|
|
62
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
+
let requestUrl = `${args.options.webUrl}/_api/web/`;
|
|
64
|
+
if (args.options.fileUrl) {
|
|
65
|
+
const fileServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
66
|
+
requestUrl += `GetFileByServerRelativePath(decodedUrl='${formatting_1.formatting.encodeQueryParameter(fileServerRelativeUrl)}')`;
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
requestUrl += `GetFileById('${args.options.fileId}')`;
|
|
70
|
+
}
|
|
71
|
+
requestUrl += '?$select=SiteId,VroomItemId,VroomDriveId';
|
|
72
|
+
const requestOptions = {
|
|
73
|
+
url: requestUrl,
|
|
74
|
+
headers: {
|
|
75
|
+
accept: 'application/json;odata=nometadata'
|
|
76
|
+
},
|
|
77
|
+
responseType: 'json'
|
|
78
|
+
};
|
|
79
|
+
const res = yield request_1.default.get(requestOptions);
|
|
80
|
+
return res;
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
_SpoFileSharingLinkGetCommand_instances = new WeakSet(), _SpoFileSharingLinkGetCommand_initTelemetry = function _SpoFileSharingLinkGetCommand_initTelemetry() {
|
|
85
|
+
this.telemetry.push((args) => {
|
|
86
|
+
Object.assign(this.telemetryProperties, {
|
|
87
|
+
fileUrl: typeof args.options.fileUrl !== 'undefined',
|
|
88
|
+
fileId: typeof args.options.fileId !== 'undefined'
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
}, _SpoFileSharingLinkGetCommand_initOptions = function _SpoFileSharingLinkGetCommand_initOptions() {
|
|
92
|
+
this.options.unshift({
|
|
93
|
+
option: '-u, --webUrl <webUrl>'
|
|
94
|
+
}, {
|
|
95
|
+
option: '--fileUrl [fileUrl]'
|
|
96
|
+
}, {
|
|
97
|
+
option: '--fileId [fileId]'
|
|
98
|
+
}, {
|
|
99
|
+
option: '-i, --id <id>'
|
|
100
|
+
});
|
|
101
|
+
}, _SpoFileSharingLinkGetCommand_initValidators = function _SpoFileSharingLinkGetCommand_initValidators() {
|
|
102
|
+
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
103
|
+
const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
|
|
104
|
+
if (isValidSharePointUrl !== true) {
|
|
105
|
+
return isValidSharePointUrl;
|
|
106
|
+
}
|
|
107
|
+
if (args.options.fileId && !validation_1.validation.isValidGuid(args.options.fileId)) {
|
|
108
|
+
return `${args.options.fileId} is not a valid GUID`;
|
|
109
|
+
}
|
|
110
|
+
return true;
|
|
111
|
+
}));
|
|
112
|
+
}, _SpoFileSharingLinkGetCommand_initOptionSets = function _SpoFileSharingLinkGetCommand_initOptionSets() {
|
|
113
|
+
this.optionSets.push({ options: ['fileUrl', 'fileId'] });
|
|
114
|
+
};
|
|
115
|
+
module.exports = new SpoFileSharingLinkGetCommand();
|
|
116
|
+
//# sourceMappingURL=file-sharinglink-get.js.map
|