@pnp/cli-microsoft365 10.0.0-beta.7dfc31a → 10.0.0-beta.977d78b
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/allCommands.json +1 -1
- package/allCommandsFull.json +1 -1
- package/dist/Auth.js +14 -13
- package/dist/Command.js +4 -1
- package/dist/cli/cli.js +14 -0
- package/dist/config.js +60 -5
- package/dist/m365/base/PowerAutomateCommand.js +1 -1
- package/dist/m365/base/SpoCommand.js +1 -1
- package/dist/m365/cli/commands/cli-consent.js +2 -2
- package/dist/m365/cli/commands/cli-doctor.js +2 -2
- package/dist/m365/cli/commands/cli-reconsent.js +2 -3
- package/dist/m365/cli/commands/config/config-set.js +12 -4
- package/dist/m365/commands/login.js +28 -9
- package/dist/m365/commands/setup.js +256 -33
- package/dist/m365/commands/setupPresets.js +2 -4
- package/dist/m365/connection/commands/connection-list.js +4 -4
- package/dist/m365/entra/commands/app/app-add.js +52 -288
- package/dist/m365/file/commands/file-move.js +135 -0
- package/dist/m365/file/commands.js +2 -1
- package/dist/m365/flow/commands/environment/environment-get.js +1 -1
- package/dist/m365/flow/commands/environment/environment-list.js +1 -1
- package/dist/m365/flow/commands/flow-disable.js +1 -1
- package/dist/m365/flow/commands/flow-enable.js +1 -1
- package/dist/m365/flow/commands/flow-export.js +17 -16
- package/dist/m365/flow/commands/flow-get.js +1 -1
- package/dist/m365/flow/commands/flow-list.js +1 -1
- package/dist/m365/flow/commands/flow-remove.js +1 -1
- package/dist/m365/flow/commands/owner/owner-ensure.js +1 -1
- package/dist/m365/flow/commands/owner/owner-list.js +1 -1
- package/dist/m365/flow/commands/owner/owner-remove.js +1 -1
- package/dist/m365/flow/commands/recyclebinitem/recyclebinitem-list.js +47 -0
- package/dist/m365/flow/commands/recyclebinitem/recyclebinitem-restore.js +48 -0
- package/dist/m365/flow/commands/run/run-cancel.js +1 -1
- package/dist/m365/flow/commands/run/run-get.js +1 -1
- package/dist/m365/flow/commands/run/run-list.js +1 -1
- package/dist/m365/flow/commands/run/run-resubmit.js +2 -2
- package/dist/m365/flow/commands.js +2 -0
- package/dist/m365/spfx/commands/project/project-doctor/doctor-1.20.0-rc.1.js +25 -0
- package/dist/m365/spfx/commands/project/project-doctor.js +2 -1
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.20.0-rc.1.js +57 -0
- package/dist/m365/spfx/commands/project/project-upgrade.js +16 -13
- package/dist/m365/spfx/commands/spfx-doctor.js +15 -0
- package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +8 -8
- package/dist/m365/spo/commands/contenttype/contenttype-field-set.js +2 -2
- package/dist/m365/spo/commands/file/file-roleassignment-add.js +17 -54
- package/dist/m365/spo/commands/file/file-roleassignment-remove.js +13 -40
- package/dist/m365/spo/commands/file/file-roleinheritance-break.js +5 -13
- package/dist/m365/spo/commands/file/file-roleinheritance-reset.js +5 -13
- package/dist/m365/spo/commands/folder/folder-sharinglink-add.js +143 -0
- package/dist/m365/spo/commands/folder/folder-sharinglink-clear.js +111 -0
- package/dist/m365/spo/commands/folder/folder-sharinglink-remove.js +95 -0
- package/dist/m365/spo/commands/list/list-get.js +17 -4
- package/dist/m365/spo/commands/page/page-section-add.js +185 -34
- package/dist/m365/spo/commands/site/SiteAdmin.js +2 -0
- package/dist/m365/spo/commands/site/site-admin-add.js +252 -0
- package/dist/m365/spo/commands/site/site-admin-list.js +2 -27
- package/dist/m365/spo/commands/site/site-admin-remove.js +193 -0
- package/dist/m365/spo/commands/sitescript/sitescript-get.js +3 -2
- package/dist/m365/spo/commands/user/user-get.js +67 -9
- package/dist/m365/spo/commands.js +5 -0
- package/dist/m365/spp/commands/contentcenter/contentcenter-list.js +56 -0
- package/dist/m365/spp/commands.js +5 -0
- package/dist/m365/teams/MeetingTranscript.js +2 -0
- package/dist/m365/teams/commands/meeting/meeting-transcript-get.js +152 -0
- package/dist/m365/teams/commands.js +1 -0
- package/dist/settingsNames.js +6 -1
- package/dist/utils/driveUtil.js +51 -0
- package/dist/utils/entraApp.js +283 -0
- package/dist/utils/spo.js +75 -7
- package/dist/utils/zod.js +1 -1
- package/docs/docs/_clisettings.mdx +6 -1
- package/docs/docs/cmd/entra/m365group/m365group-report-activitystorage.mdx +2 -2
- package/docs/docs/cmd/file/file-move.mdx +79 -0
- package/docs/docs/cmd/flow/recyclebinitem/recyclebinitem-list.mdx +132 -0
- package/docs/docs/cmd/flow/recyclebinitem/recyclebinitem-restore.mdx +55 -0
- package/docs/docs/cmd/setup.mdx +17 -6
- package/docs/docs/cmd/spo/cdn/cdn-get.mdx +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-add.mdx +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-list.mdx +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-origin-remove.mdx +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-policy-list.mdx +1 -1
- package/docs/docs/cmd/spo/cdn/cdn-policy-set.mdx +1 -1
- package/docs/docs/cmd/spo/contenttype/contenttype-field-remove.mdx +7 -7
- package/docs/docs/cmd/spo/contenttype/contenttype-field-set.mdx +2 -2
- package/docs/docs/cmd/spo/externaluser/externaluser-list.mdx +1 -1
- package/docs/docs/cmd/spo/folder/folder-sharinglink-add.mdx +125 -0
- package/docs/docs/cmd/spo/folder/folder-sharinglink-clear.mdx +50 -0
- package/docs/docs/cmd/spo/folder/folder-sharinglink-remove.mdx +50 -0
- package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-get.mdx +1 -1
- package/docs/docs/cmd/spo/hidedefaultthemes/hidedefaultthemes-set.mdx +1 -1
- package/docs/docs/cmd/spo/homesite/homesite-remove.mdx +1 -1
- package/docs/docs/cmd/spo/knowledgehub/knowledgehub-get.mdx +1 -1
- package/docs/docs/cmd/spo/knowledgehub/knowledgehub-remove.mdx +1 -1
- package/docs/docs/cmd/spo/knowledgehub/knowledgehub-set.mdx +1 -1
- package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-add.mdx +1 -1
- package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-list.mdx +1 -1
- package/docs/docs/cmd/spo/orgassetslibrary/orgassetslibrary-remove.mdx +1 -1
- package/docs/docs/cmd/spo/orgnewssite/orgnewssite-list.mdx +1 -1
- package/docs/docs/cmd/spo/orgnewssite/orgnewssite-remove.mdx +1 -1
- package/docs/docs/cmd/spo/orgnewssite/orgnewssite-set.mdx +1 -1
- package/docs/docs/cmd/spo/page/page-section-add.mdx +57 -2
- package/docs/docs/cmd/spo/site/site-admin-add.mdx +67 -0
- package/docs/docs/cmd/spo/site/site-admin-remove.mdx +67 -0
- package/docs/docs/cmd/spo/site/site-appcatalog-add.mdx +1 -1
- package/docs/docs/cmd/spo/site/site-appcatalog-remove.mdx +1 -1
- package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +1 -1
- package/docs/docs/cmd/spo/site/site-list.mdx +6 -4
- package/docs/docs/cmd/spo/site/site-set.mdx +1 -1
- package/docs/docs/cmd/spo/sitescript/sitescript-get.mdx +14 -1
- package/docs/docs/cmd/spo/storageentity/storageentity-remove.mdx +1 -1
- package/docs/docs/cmd/spo/storageentity/storageentity-set.mdx +1 -1
- package/docs/docs/cmd/spo/tenant/tenant-appcatalog-add.mdx +1 -1
- package/docs/docs/cmd/spo/tenant/tenant-appcatalogurl-get.mdx +1 -1
- package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-list.mdx +1 -1
- package/docs/docs/cmd/spo/tenant/tenant-recyclebinitem-remove.mdx +1 -1
- package/docs/docs/cmd/spo/tenant/tenant-settings-list.mdx +1 -1
- package/docs/docs/cmd/spo/theme/theme-apply.mdx +1 -1
- package/docs/docs/cmd/spo/theme/theme-get.mdx +1 -1
- package/docs/docs/cmd/spo/theme/theme-list.mdx +1 -1
- package/docs/docs/cmd/spo/theme/theme-remove.mdx +1 -1
- package/docs/docs/cmd/spo/theme/theme-set.mdx +1 -1
- package/docs/docs/cmd/spo/user/user-get.mdx +35 -9
- package/docs/docs/cmd/spp/contentcenter/contentcenter-list.mdx +287 -0
- package/docs/docs/cmd/teams/meeting/meeting-transcript-get.mdx +132 -0
- package/npm-shrinkwrap.json +203 -375
- package/package.json +16 -17
|
@@ -4,17 +4,13 @@ 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 _SpoFileRoleAssignmentAddCommand_instances, _SpoFileRoleAssignmentAddCommand_initTelemetry, _SpoFileRoleAssignmentAddCommand_initOptions, _SpoFileRoleAssignmentAddCommand_initValidators, _SpoFileRoleAssignmentAddCommand_initOptionSets, _SpoFileRoleAssignmentAddCommand_initTypes;
|
|
7
|
-
import { cli } from '../../../../cli/cli.js';
|
|
8
7
|
import request from '../../../../request.js';
|
|
9
8
|
import { formatting } from '../../../../utils/formatting.js';
|
|
9
|
+
import { spo } from '../../../../utils/spo.js';
|
|
10
10
|
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
11
11
|
import { validation } from '../../../../utils/validation.js';
|
|
12
12
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
13
|
import commands from '../../commands.js';
|
|
14
|
-
import spoGroupGetCommand from '../group/group-get.js';
|
|
15
|
-
import spoRoleDefinitionListCommand from '../roledefinition/roledefinition-list.js';
|
|
16
|
-
import spoUserGetCommand from '../user/user-get.js';
|
|
17
|
-
import spoFileGetCommand from './file-get.js';
|
|
18
14
|
class SpoFileRoleAssignmentAddCommand extends SpoCommand {
|
|
19
15
|
get name() {
|
|
20
16
|
return commands.FILE_ROLEASSIGNMENT_ADD;
|
|
@@ -36,14 +32,14 @@ class SpoFileRoleAssignmentAddCommand extends SpoCommand {
|
|
|
36
32
|
await logger.logToStderr(`Adding role assignment to file in site at ${args.options.webUrl}...`);
|
|
37
33
|
}
|
|
38
34
|
try {
|
|
39
|
-
const fileUrl = await this.getFileURL(args);
|
|
40
|
-
const roleDefinitionId = await this.getRoleDefinitionId(args.options);
|
|
35
|
+
const fileUrl = await this.getFileURL(args, logger);
|
|
36
|
+
const roleDefinitionId = await this.getRoleDefinitionId(args.options, logger);
|
|
41
37
|
if (args.options.upn) {
|
|
42
|
-
const upnPrincipalId = await this.getUserPrincipalId(args.options);
|
|
38
|
+
const upnPrincipalId = await this.getUserPrincipalId(args.options, logger);
|
|
43
39
|
await this.addRoleAssignment(fileUrl, args.options.webUrl, upnPrincipalId, roleDefinitionId);
|
|
44
40
|
}
|
|
45
41
|
else if (args.options.groupName) {
|
|
46
|
-
const groupPrincipalId = await this.getGroupPrincipalId(args.options);
|
|
42
|
+
const groupPrincipalId = await this.getGroupPrincipalId(args.options, logger);
|
|
47
43
|
await this.addRoleAssignment(fileUrl, args.options.webUrl, groupPrincipalId, roleDefinitionId);
|
|
48
44
|
}
|
|
49
45
|
else {
|
|
@@ -66,60 +62,27 @@ class SpoFileRoleAssignmentAddCommand extends SpoCommand {
|
|
|
66
62
|
};
|
|
67
63
|
return request.post(requestOptions);
|
|
68
64
|
}
|
|
69
|
-
async getRoleDefinitionId(options) {
|
|
65
|
+
async getRoleDefinitionId(options, logger) {
|
|
70
66
|
if (!options.roleDefinitionName) {
|
|
71
67
|
return options.roleDefinitionId;
|
|
72
68
|
}
|
|
73
|
-
const
|
|
74
|
-
|
|
75
|
-
output: 'json',
|
|
76
|
-
debug: this.debug,
|
|
77
|
-
verbose: this.verbose
|
|
78
|
-
};
|
|
79
|
-
const output = await cli.executeCommandWithOutput(spoRoleDefinitionListCommand, { options: { ...roleDefinitionListCommandOptions, _: [] } });
|
|
80
|
-
const getRoleDefinitionListOutput = JSON.parse(output.stdout);
|
|
81
|
-
const roleDefinitionId = getRoleDefinitionListOutput.find((role) => role.Name === options.roleDefinitionName).Id;
|
|
82
|
-
return roleDefinitionId;
|
|
69
|
+
const roleDefinition = await spo.getRoleDefinitionByName(options.webUrl, options.roleDefinitionName, logger, this.verbose);
|
|
70
|
+
return roleDefinition.Id;
|
|
83
71
|
}
|
|
84
|
-
async getGroupPrincipalId(options) {
|
|
85
|
-
const
|
|
86
|
-
|
|
87
|
-
name: options.groupName,
|
|
88
|
-
output: 'json',
|
|
89
|
-
debug: this.debug,
|
|
90
|
-
verbose: this.verbose
|
|
91
|
-
};
|
|
92
|
-
const output = await cli.executeCommandWithOutput(spoGroupGetCommand, { options: { ...groupGetCommandOptions, _: [] } });
|
|
93
|
-
const getGroupOutput = JSON.parse(output.stdout);
|
|
94
|
-
return getGroupOutput.Id;
|
|
72
|
+
async getGroupPrincipalId(options, logger) {
|
|
73
|
+
const group = await spo.getGroupByName(options.webUrl, options.groupName, logger, this.verbose);
|
|
74
|
+
return group.Id;
|
|
95
75
|
}
|
|
96
|
-
async getUserPrincipalId(options) {
|
|
97
|
-
const
|
|
98
|
-
|
|
99
|
-
email: options.upn,
|
|
100
|
-
id: undefined,
|
|
101
|
-
output: 'json',
|
|
102
|
-
debug: this.debug,
|
|
103
|
-
verbose: this.verbose
|
|
104
|
-
};
|
|
105
|
-
const output = await cli.executeCommandWithOutput(spoUserGetCommand, { options: { ...userGetCommandOptions, _: [] } });
|
|
106
|
-
const getUserOutput = JSON.parse(output.stdout);
|
|
107
|
-
return getUserOutput.Id;
|
|
76
|
+
async getUserPrincipalId(options, logger) {
|
|
77
|
+
const user = await spo.getUserByEmail(options.webUrl, options.upn, logger, this.verbose);
|
|
78
|
+
return user.Id;
|
|
108
79
|
}
|
|
109
|
-
async getFileURL(args) {
|
|
80
|
+
async getFileURL(args, logger) {
|
|
110
81
|
if (args.options.fileUrl) {
|
|
111
82
|
return urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
112
83
|
}
|
|
113
|
-
const
|
|
114
|
-
|
|
115
|
-
id: args.options.fileId,
|
|
116
|
-
output: 'json',
|
|
117
|
-
debug: this.debug,
|
|
118
|
-
verbose: this.verbose
|
|
119
|
-
};
|
|
120
|
-
const output = await cli.executeCommandWithOutput(spoFileGetCommand, { options: { ...options, _: [] } });
|
|
121
|
-
const getFileOutput = JSON.parse(output.stdout);
|
|
122
|
-
return getFileOutput.ServerRelativeUrl;
|
|
84
|
+
const file = await spo.getFileById(args.options.webUrl, args.options.fileId, logger, this.verbose);
|
|
85
|
+
return file.ServerRelativeUrl;
|
|
123
86
|
}
|
|
124
87
|
}
|
|
125
88
|
_SpoFileRoleAssignmentAddCommand_instances = new WeakSet(), _SpoFileRoleAssignmentAddCommand_initTelemetry = function _SpoFileRoleAssignmentAddCommand_initTelemetry() {
|
|
@@ -7,13 +7,11 @@ var _SpoFileRoleAssignmentRemoveCommand_instances, _SpoFileRoleAssignmentRemoveC
|
|
|
7
7
|
import { cli } from '../../../../cli/cli.js';
|
|
8
8
|
import request from '../../../../request.js';
|
|
9
9
|
import { formatting } from '../../../../utils/formatting.js';
|
|
10
|
+
import { spo } from '../../../../utils/spo.js';
|
|
10
11
|
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
11
12
|
import { validation } from '../../../../utils/validation.js';
|
|
12
13
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
14
|
import commands from '../../commands.js';
|
|
14
|
-
import spoGroupGetCommand from '../group/group-get.js';
|
|
15
|
-
import spoUserGetCommand from '../user/user-get.js';
|
|
16
|
-
import spoFileGetCommand from './file-get.js';
|
|
17
15
|
class SpoFileRoleAssignmentRemoveCommand extends SpoCommand {
|
|
18
16
|
get name() {
|
|
19
17
|
return commands.FILE_ROLEASSIGNMENT_REMOVE;
|
|
@@ -36,13 +34,13 @@ class SpoFileRoleAssignmentRemoveCommand extends SpoCommand {
|
|
|
36
34
|
await logger.logToStderr(`Removing role assignment for ${args.options.groupName || args.options.upn} from file ${args.options.fileUrl || args.options.fileId}`);
|
|
37
35
|
}
|
|
38
36
|
try {
|
|
39
|
-
const fileURL = await this.getFileURL(args);
|
|
37
|
+
const fileURL = await this.getFileURL(args, logger);
|
|
40
38
|
let principalId;
|
|
41
39
|
if (args.options.groupName) {
|
|
42
|
-
principalId = await this.getGroupPrincipalId(args.options);
|
|
40
|
+
principalId = await this.getGroupPrincipalId(args.options, logger);
|
|
43
41
|
}
|
|
44
42
|
else if (args.options.upn) {
|
|
45
|
-
principalId = await this.getUserPrincipalId(args.options);
|
|
43
|
+
principalId = await this.getUserPrincipalId(args.options, logger);
|
|
46
44
|
}
|
|
47
45
|
else {
|
|
48
46
|
principalId = args.options.principalId;
|
|
@@ -71,45 +69,20 @@ class SpoFileRoleAssignmentRemoveCommand extends SpoCommand {
|
|
|
71
69
|
}
|
|
72
70
|
}
|
|
73
71
|
}
|
|
74
|
-
async getFileURL(args) {
|
|
72
|
+
async getFileURL(args, logger) {
|
|
75
73
|
if (args.options.fileUrl) {
|
|
76
74
|
return urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
77
75
|
}
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
id: args.options.fileId,
|
|
81
|
-
output: 'json',
|
|
82
|
-
debug: this.debug,
|
|
83
|
-
verbose: this.verbose
|
|
84
|
-
};
|
|
85
|
-
const output = await cli.executeCommandWithOutput(spoFileGetCommand, { options: { ...options, _: [] } });
|
|
86
|
-
const getFileOutput = JSON.parse(output.stdout);
|
|
87
|
-
return getFileOutput.ServerRelativeUrl;
|
|
76
|
+
const file = await spo.getFileById(args.options.webUrl, args.options.fileId, logger, this.verbose);
|
|
77
|
+
return file.ServerRelativeUrl;
|
|
88
78
|
}
|
|
89
|
-
async getUserPrincipalId(options) {
|
|
90
|
-
const
|
|
91
|
-
|
|
92
|
-
email: options.upn,
|
|
93
|
-
id: undefined,
|
|
94
|
-
output: 'json',
|
|
95
|
-
debug: this.debug,
|
|
96
|
-
verbose: this.verbose
|
|
97
|
-
};
|
|
98
|
-
const output = await cli.executeCommandWithOutput(spoUserGetCommand, { options: { ...userGetCommandOptions, _: [] } });
|
|
99
|
-
const getUserOutput = JSON.parse(output.stdout);
|
|
100
|
-
return getUserOutput.Id;
|
|
79
|
+
async getUserPrincipalId(options, logger) {
|
|
80
|
+
const user = await spo.getUserByEmail(options.webUrl, options.upn, logger, this.verbose);
|
|
81
|
+
return user.Id;
|
|
101
82
|
}
|
|
102
|
-
async getGroupPrincipalId(options) {
|
|
103
|
-
const
|
|
104
|
-
|
|
105
|
-
name: options.groupName,
|
|
106
|
-
output: 'json',
|
|
107
|
-
debug: this.debug,
|
|
108
|
-
verbose: this.verbose
|
|
109
|
-
};
|
|
110
|
-
const output = await cli.executeCommandWithOutput(spoGroupGetCommand, { options: { ...groupGetCommandOptions, _: [] } });
|
|
111
|
-
const getGroupOutput = JSON.parse(output.stdout);
|
|
112
|
-
return getGroupOutput.Id;
|
|
83
|
+
async getGroupPrincipalId(options, logger) {
|
|
84
|
+
const group = await spo.getGroupByName(options.webUrl, options.groupName, logger, this.verbose);
|
|
85
|
+
return group.Id;
|
|
113
86
|
}
|
|
114
87
|
}
|
|
115
88
|
_SpoFileRoleAssignmentRemoveCommand_instances = new WeakSet(), _SpoFileRoleAssignmentRemoveCommand_initTelemetry = function _SpoFileRoleAssignmentRemoveCommand_initTelemetry() {
|
|
@@ -7,11 +7,11 @@ var _SpoFileRoleInheritanceBreakCommand_instances, _SpoFileRoleInheritanceBreakC
|
|
|
7
7
|
import { cli } from '../../../../cli/cli.js';
|
|
8
8
|
import request from '../../../../request.js';
|
|
9
9
|
import { formatting } from '../../../../utils/formatting.js';
|
|
10
|
+
import { spo } from '../../../../utils/spo.js';
|
|
10
11
|
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
11
12
|
import { validation } from '../../../../utils/validation.js';
|
|
12
13
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
14
|
import commands from '../../commands.js';
|
|
14
|
-
import spoFileGetCommand from './file-get.js';
|
|
15
15
|
class SpoFileRoleInheritanceBreakCommand extends SpoCommand {
|
|
16
16
|
get name() {
|
|
17
17
|
return commands.FILE_ROLEINHERITANCE_BREAK;
|
|
@@ -34,7 +34,7 @@ class SpoFileRoleInheritanceBreakCommand extends SpoCommand {
|
|
|
34
34
|
await logger.logToStderr(`Breaking role inheritance for file ${args.options.fileId || args.options.fileUrl}`);
|
|
35
35
|
}
|
|
36
36
|
try {
|
|
37
|
-
const fileURL = await this.getFileURL(args);
|
|
37
|
+
const fileURL = await this.getFileURL(args, logger);
|
|
38
38
|
const keepExistingPermissions = !args.options.clearExistingPermissions;
|
|
39
39
|
const requestOptions = {
|
|
40
40
|
url: `${args.options.webUrl}/_api/web/GetFileByServerRelativePath(DecodedUrl='${formatting.encodeQueryParameter(fileURL)}')/ListItemAllFields/breakroleinheritance(${keepExistingPermissions})`,
|
|
@@ -59,20 +59,12 @@ class SpoFileRoleInheritanceBreakCommand extends SpoCommand {
|
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
|
-
async getFileURL(args) {
|
|
62
|
+
async getFileURL(args, logger) {
|
|
63
63
|
if (args.options.fileUrl) {
|
|
64
64
|
return urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
65
65
|
}
|
|
66
|
-
const
|
|
67
|
-
|
|
68
|
-
id: args.options.fileId,
|
|
69
|
-
output: 'json',
|
|
70
|
-
debug: this.debug,
|
|
71
|
-
verbose: this.verbose
|
|
72
|
-
};
|
|
73
|
-
const output = await cli.executeCommandWithOutput(spoFileGetCommand, { options: { ...options, _: [] } });
|
|
74
|
-
const getFileOutput = JSON.parse(output.stdout);
|
|
75
|
-
return getFileOutput.ServerRelativeUrl;
|
|
66
|
+
const file = await spo.getFileById(args.options.webUrl, args.options.fileId, logger, this.verbose);
|
|
67
|
+
return file.ServerRelativeUrl;
|
|
76
68
|
}
|
|
77
69
|
}
|
|
78
70
|
_SpoFileRoleInheritanceBreakCommand_instances = new WeakSet(), _SpoFileRoleInheritanceBreakCommand_initTelemetry = function _SpoFileRoleInheritanceBreakCommand_initTelemetry() {
|
|
@@ -7,11 +7,11 @@ var _SpoFileRoleInheritanceResetCommand_instances, _SpoFileRoleInheritanceResetC
|
|
|
7
7
|
import { cli } from '../../../../cli/cli.js';
|
|
8
8
|
import request from '../../../../request.js';
|
|
9
9
|
import { formatting } from '../../../../utils/formatting.js';
|
|
10
|
+
import { spo } from '../../../../utils/spo.js';
|
|
10
11
|
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
11
12
|
import { validation } from '../../../../utils/validation.js';
|
|
12
13
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
14
|
import commands from '../../commands.js';
|
|
14
|
-
import spoFileGetCommand from './file-get.js';
|
|
15
15
|
class SpoFileRoleInheritanceResetCommand extends SpoCommand {
|
|
16
16
|
get name() {
|
|
17
17
|
return commands.FILE_ROLEINHERITANCE_RESET;
|
|
@@ -34,7 +34,7 @@ class SpoFileRoleInheritanceResetCommand extends SpoCommand {
|
|
|
34
34
|
await logger.logToStderr(`Resetting role inheritance for file ${args.options.fileId || args.options.fileUrl}`);
|
|
35
35
|
}
|
|
36
36
|
try {
|
|
37
|
-
const fileURL = await this.getFileURL(args);
|
|
37
|
+
const fileURL = await this.getFileURL(args, logger);
|
|
38
38
|
const requestOptions = {
|
|
39
39
|
url: `${args.options.webUrl}/_api/web/GetFileByServerRelativePath(DecodedUrl='${formatting.encodeQueryParameter(fileURL)}')/ListItemAllFields/resetroleinheritance`,
|
|
40
40
|
headers: {
|
|
@@ -58,20 +58,12 @@ class SpoFileRoleInheritanceResetCommand extends SpoCommand {
|
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
|
-
async getFileURL(args) {
|
|
61
|
+
async getFileURL(args, logger) {
|
|
62
62
|
if (args.options.fileUrl) {
|
|
63
63
|
return urlUtil.getServerRelativePath(args.options.webUrl, args.options.fileUrl);
|
|
64
64
|
}
|
|
65
|
-
const
|
|
66
|
-
|
|
67
|
-
id: args.options.fileId,
|
|
68
|
-
output: 'json',
|
|
69
|
-
debug: this.debug,
|
|
70
|
-
verbose: this.verbose
|
|
71
|
-
};
|
|
72
|
-
const output = await cli.executeCommandWithOutput(spoFileGetCommand, { options: { ...options, _: [] } });
|
|
73
|
-
const getFileOutput = JSON.parse(output.stdout);
|
|
74
|
-
return getFileOutput.ServerRelativeUrl;
|
|
65
|
+
const file = await spo.getFileById(args.options.webUrl, args.options.fileId, logger, this.verbose);
|
|
66
|
+
return file.ServerRelativeUrl;
|
|
75
67
|
}
|
|
76
68
|
}
|
|
77
69
|
_SpoFileRoleInheritanceResetCommand_instances = new WeakSet(), _SpoFileRoleInheritanceResetCommand_initTelemetry = function _SpoFileRoleInheritanceResetCommand_initTelemetry() {
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
3
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
|
+
};
|
|
6
|
+
var _SpoFolderSharingLinkAddCommand_instances, _SpoFolderSharingLinkAddCommand_initTelemetry, _SpoFolderSharingLinkAddCommand_initOptions, _SpoFolderSharingLinkAddCommand_initValidators, _SpoFolderSharingLinkAddCommand_initOptionSets, _SpoFolderSharingLinkAddCommand_initTypes;
|
|
7
|
+
import request from '../../../../request.js';
|
|
8
|
+
import { spo } from '../../../../utils/spo.js';
|
|
9
|
+
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
10
|
+
import { drive } from '../../../../utils/drive.js';
|
|
11
|
+
import { validation } from '../../../../utils/validation.js';
|
|
12
|
+
import { formatting } from '../../../../utils/formatting.js';
|
|
13
|
+
import SpoCommand from '../../../base/SpoCommand.js';
|
|
14
|
+
import commands from '../../commands.js';
|
|
15
|
+
class SpoFolderSharingLinkAddCommand extends SpoCommand {
|
|
16
|
+
get name() {
|
|
17
|
+
return commands.FOLDER_SHARINGLINK_ADD;
|
|
18
|
+
}
|
|
19
|
+
get description() {
|
|
20
|
+
return 'Creates a new sharing link to a folder';
|
|
21
|
+
}
|
|
22
|
+
constructor() {
|
|
23
|
+
super();
|
|
24
|
+
_SpoFolderSharingLinkAddCommand_instances.add(this);
|
|
25
|
+
this.allowedTypes = ['view', 'edit'];
|
|
26
|
+
this.allowedScopes = ['anonymous', 'organization', 'users'];
|
|
27
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkAddCommand_instances, "m", _SpoFolderSharingLinkAddCommand_initTelemetry).call(this);
|
|
28
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkAddCommand_instances, "m", _SpoFolderSharingLinkAddCommand_initOptions).call(this);
|
|
29
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkAddCommand_instances, "m", _SpoFolderSharingLinkAddCommand_initValidators).call(this);
|
|
30
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkAddCommand_instances, "m", _SpoFolderSharingLinkAddCommand_initOptionSets).call(this);
|
|
31
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkAddCommand_instances, "m", _SpoFolderSharingLinkAddCommand_initTypes).call(this);
|
|
32
|
+
}
|
|
33
|
+
async commandAction(logger, args) {
|
|
34
|
+
if (this.verbose) {
|
|
35
|
+
await logger.logToStderr(`Creating a sharing link to a folder ${args.options.folderId || args.options.folderUrl}...`);
|
|
36
|
+
}
|
|
37
|
+
try {
|
|
38
|
+
const relFolderUrl = await spo.getFolderServerRelativeUrl(args.options.webUrl, args.options.folderUrl, args.options.folderId, logger, args.options.verbose);
|
|
39
|
+
const absoluteFolderUrl = urlUtil.getAbsoluteUrl(args.options.webUrl, relFolderUrl);
|
|
40
|
+
const folderUrl = new URL(absoluteFolderUrl);
|
|
41
|
+
const siteId = await spo.getSiteId(args.options.webUrl);
|
|
42
|
+
const driveDetails = await drive.getDriveByUrl(siteId, folderUrl, logger, args.options.verbose);
|
|
43
|
+
const itemId = await drive.getDriveItemId(driveDetails, folderUrl, logger, args.options.verbose);
|
|
44
|
+
const requestOptions = {
|
|
45
|
+
url: `https://graph.microsoft.com/v1.0/drives/${driveDetails.id}/items/${itemId}/createLink`,
|
|
46
|
+
headers: {
|
|
47
|
+
accept: 'application/json;odata.metadata=none'
|
|
48
|
+
},
|
|
49
|
+
responseType: 'json',
|
|
50
|
+
data: {
|
|
51
|
+
type: args.options.type,
|
|
52
|
+
expirationDateTime: args.options.expirationDateTime,
|
|
53
|
+
scope: args.options.scope,
|
|
54
|
+
retainInheritedPermissions: !!args.options.retainInheritiedPermissions
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
if (args.options.scope === 'users' && args.options.recipients) {
|
|
58
|
+
const recipients = formatting.splitAndTrim(args.options.recipients).map(email => ({ email }));
|
|
59
|
+
requestOptions.data.recipients = recipients;
|
|
60
|
+
}
|
|
61
|
+
const sharingLink = await request.post(requestOptions);
|
|
62
|
+
// remove grantedToIdentities from the sharing link object
|
|
63
|
+
if (sharingLink.grantedToIdentities) {
|
|
64
|
+
delete sharingLink.grantedToIdentities;
|
|
65
|
+
}
|
|
66
|
+
await logger.log(sharingLink);
|
|
67
|
+
}
|
|
68
|
+
catch (err) {
|
|
69
|
+
this.handleRejectedODataJsonPromise(err);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
_SpoFolderSharingLinkAddCommand_instances = new WeakSet(), _SpoFolderSharingLinkAddCommand_initTelemetry = function _SpoFolderSharingLinkAddCommand_initTelemetry() {
|
|
74
|
+
this.telemetry.push((args) => {
|
|
75
|
+
Object.assign(this.telemetryProperties, {
|
|
76
|
+
folderId: typeof args.options.folderId !== 'undefined',
|
|
77
|
+
folderUrl: typeof args.options.folderUrl !== 'undefined',
|
|
78
|
+
type: typeof args.options.type !== 'undefined',
|
|
79
|
+
expirationDateTime: typeof args.options.expirationDateTime !== 'undefined',
|
|
80
|
+
scope: typeof args.options.scope !== 'undefined',
|
|
81
|
+
retainInheritiedPermissions: !!args.options.retainInheritiedPermissions,
|
|
82
|
+
recipients: typeof args.options.recipients !== 'undefined'
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
}, _SpoFolderSharingLinkAddCommand_initOptions = function _SpoFolderSharingLinkAddCommand_initOptions() {
|
|
86
|
+
this.options.unshift({
|
|
87
|
+
option: '-u, --webUrl <webUrl>'
|
|
88
|
+
}, {
|
|
89
|
+
option: '--folderId [folderId]'
|
|
90
|
+
}, {
|
|
91
|
+
option: '--folderUrl [folderUrl]'
|
|
92
|
+
}, {
|
|
93
|
+
option: '--type <type>',
|
|
94
|
+
autocomplete: this.allowedTypes
|
|
95
|
+
}, {
|
|
96
|
+
option: '--expirationDateTime [expirationDateTime]'
|
|
97
|
+
}, {
|
|
98
|
+
option: '--scope [scope]',
|
|
99
|
+
autocomplete: this.allowedScopes
|
|
100
|
+
}, {
|
|
101
|
+
option: '--retainInheritedPermissions [retainInheritedPermissions]'
|
|
102
|
+
}, {
|
|
103
|
+
option: '--recipients [recipients]'
|
|
104
|
+
});
|
|
105
|
+
}, _SpoFolderSharingLinkAddCommand_initValidators = function _SpoFolderSharingLinkAddCommand_initValidators() {
|
|
106
|
+
this.validators.push(async (args) => {
|
|
107
|
+
const isValidSharePointUrl = validation.isValidSharePointUrl(args.options.webUrl);
|
|
108
|
+
if (isValidSharePointUrl !== true) {
|
|
109
|
+
return isValidSharePointUrl;
|
|
110
|
+
}
|
|
111
|
+
if (args.options.folderId && !validation.isValidGuid(args.options.folderId)) {
|
|
112
|
+
return `${args.options.folderId} is not a valid GUID`;
|
|
113
|
+
}
|
|
114
|
+
if (args.options.type && !this.allowedTypes.some(type => type === args.options.type)) {
|
|
115
|
+
return `'${args.options.type}' is not a valid type. Allowed values are: ${this.allowedTypes.join(',')}`;
|
|
116
|
+
}
|
|
117
|
+
if (args.options.scope) {
|
|
118
|
+
if (!this.allowedScopes.includes(args.options.scope)) {
|
|
119
|
+
return `'${args.options.scope}' is not a valid scope. Allowed values are: ${this.allowedScopes.join(', ')}.`;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
if (args.options.expirationDateTime && !validation.isValidISODateTime(args.options.expirationDateTime)) {
|
|
123
|
+
return `${args.options.expirationDateTime} is not a valid ISO date string.`;
|
|
124
|
+
}
|
|
125
|
+
if (args.options.recipients) {
|
|
126
|
+
const isValidUPNArrayResult = validation.isValidUserPrincipalNameArray(args.options.recipients);
|
|
127
|
+
if (isValidUPNArrayResult !== true) {
|
|
128
|
+
return `The following user principal names are invalid for the option 'recipients': ${isValidUPNArrayResult}.`;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return true;
|
|
132
|
+
});
|
|
133
|
+
}, _SpoFolderSharingLinkAddCommand_initOptionSets = function _SpoFolderSharingLinkAddCommand_initOptionSets() {
|
|
134
|
+
this.optionSets.push({ options: ['folderId', 'folderUrl'] }, {
|
|
135
|
+
options: ['recipients'],
|
|
136
|
+
runsWhen: (args) => args.options.scope !== undefined && args.options.scope === 'users'
|
|
137
|
+
});
|
|
138
|
+
}, _SpoFolderSharingLinkAddCommand_initTypes = function _SpoFolderSharingLinkAddCommand_initTypes() {
|
|
139
|
+
this.types.string.push('webUrl', 'folderId', 'folderUrl', 'type', 'expirationDateTime', 'scope', 'recipients');
|
|
140
|
+
this.types.boolean.push('retainInheritiedPermissions');
|
|
141
|
+
};
|
|
142
|
+
export default new SpoFolderSharingLinkAddCommand();
|
|
143
|
+
//# sourceMappingURL=folder-sharinglink-add.js.map
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
3
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
|
+
};
|
|
6
|
+
var _SpoFolderSharingLinkClearCommand_instances, _SpoFolderSharingLinkClearCommand_initTelemetry, _SpoFolderSharingLinkClearCommand_initOptions, _SpoFolderSharingLinkClearCommand_initOptionSets, _SpoFolderSharingLinkClearCommand_initValidators, _SpoFolderSharingLinkClearCommand_initTypes;
|
|
7
|
+
import { cli } from '../../../../cli/cli.js';
|
|
8
|
+
import { spo } from '../../../../utils/spo.js';
|
|
9
|
+
import { odata } from '../../../../utils/odata.js';
|
|
10
|
+
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
11
|
+
import { drive } from '../../../../utils/drive.js';
|
|
12
|
+
import { validation } from '../../../../utils/validation.js';
|
|
13
|
+
import SpoCommand from '../../../base/SpoCommand.js';
|
|
14
|
+
import request from '../../../../request.js';
|
|
15
|
+
import commands from '../../commands.js';
|
|
16
|
+
class SpoFolderSharingLinkClearCommand extends SpoCommand {
|
|
17
|
+
get name() {
|
|
18
|
+
return commands.FOLDER_SHARINGLINK_CLEAR;
|
|
19
|
+
}
|
|
20
|
+
get description() {
|
|
21
|
+
return 'Removes all sharing links of a folder';
|
|
22
|
+
}
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
_SpoFolderSharingLinkClearCommand_instances.add(this);
|
|
26
|
+
this.allowedScopes = ['anonymous', 'users', 'organization'];
|
|
27
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkClearCommand_instances, "m", _SpoFolderSharingLinkClearCommand_initTelemetry).call(this);
|
|
28
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkClearCommand_instances, "m", _SpoFolderSharingLinkClearCommand_initOptions).call(this);
|
|
29
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkClearCommand_instances, "m", _SpoFolderSharingLinkClearCommand_initOptionSets).call(this);
|
|
30
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkClearCommand_instances, "m", _SpoFolderSharingLinkClearCommand_initValidators).call(this);
|
|
31
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkClearCommand_instances, "m", _SpoFolderSharingLinkClearCommand_initTypes).call(this);
|
|
32
|
+
}
|
|
33
|
+
async commandAction(logger, args) {
|
|
34
|
+
const clearSharingLinks = async () => {
|
|
35
|
+
if (this.verbose) {
|
|
36
|
+
await logger.logToStderr(`Clearing sharing links from folder ${args.options.folderId || args.options.folderUrl} for ${args.options.scope ? `${args.options.scope} scope` : 'all scopes'}`);
|
|
37
|
+
}
|
|
38
|
+
try {
|
|
39
|
+
const relFolderUrl = await spo.getFolderServerRelativeUrl(args.options.webUrl, args.options.folderUrl, args.options.folderId, logger, args.options.verbose);
|
|
40
|
+
const absoluteFolderUrl = urlUtil.getAbsoluteUrl(args.options.webUrl, relFolderUrl);
|
|
41
|
+
const folderUrl = new URL(absoluteFolderUrl);
|
|
42
|
+
const siteId = await spo.getSiteId(args.options.webUrl);
|
|
43
|
+
const driveDetails = await drive.getDriveByUrl(siteId, folderUrl, logger, args.options.verbose);
|
|
44
|
+
const itemId = await drive.getDriveItemId(driveDetails, folderUrl, logger, args.options.verbose);
|
|
45
|
+
let requestUrl = `https://graph.microsoft.com/v1.0/drives/${driveDetails.id}/items/${itemId}/permissions?$filter=Link ne null`;
|
|
46
|
+
if (args.options.scope) {
|
|
47
|
+
requestUrl += ` and Link/Scope eq '${args.options.scope}'`;
|
|
48
|
+
}
|
|
49
|
+
const sharingLinks = await odata.getAllItems(requestUrl);
|
|
50
|
+
for (const sharingLink of sharingLinks) {
|
|
51
|
+
const requestOptions = {
|
|
52
|
+
url: `https://graph.microsoft.com/v1.0/drives/${driveDetails.id}/items/${itemId}/permissions/${sharingLink.id}`,
|
|
53
|
+
headers: {
|
|
54
|
+
accept: 'application/json;odata.metadata=none'
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
await request.delete(requestOptions);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (err) {
|
|
61
|
+
this.handleRejectedODataJsonPromise(err);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
if (args.options.force) {
|
|
65
|
+
await clearSharingLinks();
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
const result = await cli.promptForConfirmation({ message: `Are you sure you want to clear sharing links from folder ${args.options.folderUrl || args.options.folderId}? for ${args.options.scope ? `${args.options.scope} scope` : 'all scopes'}` });
|
|
69
|
+
if (result) {
|
|
70
|
+
await clearSharingLinks();
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
_SpoFolderSharingLinkClearCommand_instances = new WeakSet(), _SpoFolderSharingLinkClearCommand_initTelemetry = function _SpoFolderSharingLinkClearCommand_initTelemetry() {
|
|
76
|
+
this.telemetry.push((args) => {
|
|
77
|
+
Object.assign(this.telemetryProperties, {
|
|
78
|
+
webUrl: typeof args.options.webUrl !== 'undefined',
|
|
79
|
+
folderUrl: typeof args.options.folderUrl !== 'undefined',
|
|
80
|
+
folderId: typeof args.options.folderId !== 'undefined',
|
|
81
|
+
scope: typeof args.options.scope !== 'undefined',
|
|
82
|
+
force: !!args.options.force
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
}, _SpoFolderSharingLinkClearCommand_initOptions = function _SpoFolderSharingLinkClearCommand_initOptions() {
|
|
86
|
+
this.options.unshift({ option: '-u, --webUrl <webUrl>' }, { option: '--folderUrl [folderUrl]' }, { option: '--folderId [folderId]' }, {
|
|
87
|
+
option: '--scope [scope]',
|
|
88
|
+
autocomplete: this.allowedScopes
|
|
89
|
+
}, { option: '-f, --force' });
|
|
90
|
+
}, _SpoFolderSharingLinkClearCommand_initOptionSets = function _SpoFolderSharingLinkClearCommand_initOptionSets() {
|
|
91
|
+
this.optionSets.push({ options: ['folderUrl', 'folderId'] });
|
|
92
|
+
}, _SpoFolderSharingLinkClearCommand_initValidators = function _SpoFolderSharingLinkClearCommand_initValidators() {
|
|
93
|
+
this.validators.push(async (args) => {
|
|
94
|
+
const isValidSharePointUrl = validation.isValidSharePointUrl(args.options.webUrl);
|
|
95
|
+
if (isValidSharePointUrl !== true) {
|
|
96
|
+
return isValidSharePointUrl;
|
|
97
|
+
}
|
|
98
|
+
if (args.options.folderId && !validation.isValidGuid(args.options.folderId)) {
|
|
99
|
+
return `${args.options.folderId} is not a valid GUID`;
|
|
100
|
+
}
|
|
101
|
+
if (args.options.scope && !this.allowedScopes.some(scope => scope === args.options.scope)) {
|
|
102
|
+
return `'${args.options.scope}' is not a valid scope. Allowed values are: ${this.allowedScopes.join(',')}`;
|
|
103
|
+
}
|
|
104
|
+
return true;
|
|
105
|
+
});
|
|
106
|
+
}, _SpoFolderSharingLinkClearCommand_initTypes = function _SpoFolderSharingLinkClearCommand_initTypes() {
|
|
107
|
+
this.types.string.push('webUrl', 'folderUrl', 'folderId', 'scope');
|
|
108
|
+
this.types.boolean.push('force');
|
|
109
|
+
};
|
|
110
|
+
export default new SpoFolderSharingLinkClearCommand();
|
|
111
|
+
//# sourceMappingURL=folder-sharinglink-clear.js.map
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
2
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
3
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
|
+
};
|
|
6
|
+
var _SpoFolderSharingLinkRemoveCommand_instances, _SpoFolderSharingLinkRemoveCommand_initTelemetry, _SpoFolderSharingLinkRemoveCommand_initOptions, _SpoFolderSharingLinkRemoveCommand_initOptionSets, _SpoFolderSharingLinkRemoveCommand_initValidators, _SpoFolderSharingLinkRemoveCommand_initTypes;
|
|
7
|
+
import { cli } from '../../../../cli/cli.js';
|
|
8
|
+
import { spo } from '../../../../utils/spo.js';
|
|
9
|
+
import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
10
|
+
import { drive } from '../../../../utils/drive.js';
|
|
11
|
+
import { validation } from '../../../../utils/validation.js';
|
|
12
|
+
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
|
+
import request from '../../../../request.js';
|
|
14
|
+
import commands from '../../commands.js';
|
|
15
|
+
class SpoFolderSharingLinkRemoveCommand extends SpoCommand {
|
|
16
|
+
get name() {
|
|
17
|
+
return commands.FOLDER_SHARINGLINK_REMOVE;
|
|
18
|
+
}
|
|
19
|
+
get description() {
|
|
20
|
+
return 'Removes a sharing link from a folder';
|
|
21
|
+
}
|
|
22
|
+
constructor() {
|
|
23
|
+
super();
|
|
24
|
+
_SpoFolderSharingLinkRemoveCommand_instances.add(this);
|
|
25
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkRemoveCommand_instances, "m", _SpoFolderSharingLinkRemoveCommand_initTelemetry).call(this);
|
|
26
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkRemoveCommand_instances, "m", _SpoFolderSharingLinkRemoveCommand_initOptions).call(this);
|
|
27
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkRemoveCommand_instances, "m", _SpoFolderSharingLinkRemoveCommand_initOptionSets).call(this);
|
|
28
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkRemoveCommand_instances, "m", _SpoFolderSharingLinkRemoveCommand_initValidators).call(this);
|
|
29
|
+
__classPrivateFieldGet(this, _SpoFolderSharingLinkRemoveCommand_instances, "m", _SpoFolderSharingLinkRemoveCommand_initTypes).call(this);
|
|
30
|
+
}
|
|
31
|
+
async commandAction(logger, args) {
|
|
32
|
+
const removeSharingLink = async () => {
|
|
33
|
+
if (this.verbose) {
|
|
34
|
+
await logger.logToStderr(`Removing sharing link of folder ${args.options.folderId || args.options.folderUrl} with id ${args.options.id}...`);
|
|
35
|
+
}
|
|
36
|
+
try {
|
|
37
|
+
const relFolderUrl = await spo.getFolderServerRelativeUrl(args.options.webUrl, args.options.folderUrl, args.options.folderId, logger, args.options.verbose);
|
|
38
|
+
const absoluteFolderUrl = urlUtil.getAbsoluteUrl(args.options.webUrl, relFolderUrl);
|
|
39
|
+
const folderUrl = new URL(absoluteFolderUrl);
|
|
40
|
+
const siteId = await spo.getSiteId(args.options.webUrl);
|
|
41
|
+
const driveDetails = await drive.getDriveByUrl(siteId, folderUrl, logger, args.options.verbose);
|
|
42
|
+
const itemId = await drive.getDriveItemId(driveDetails, folderUrl, logger, args.options.verbose);
|
|
43
|
+
const requestOptions = {
|
|
44
|
+
url: `https://graph.microsoft.com/v1.0/drives/${driveDetails.id}/items/${itemId}/permissions/${args.options.id}`,
|
|
45
|
+
headers: {
|
|
46
|
+
accept: 'application/json;odata.metadata=none'
|
|
47
|
+
},
|
|
48
|
+
responseType: 'json'
|
|
49
|
+
};
|
|
50
|
+
return request.delete(requestOptions);
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
this.handleRejectedODataJsonPromise(err);
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
if (args.options.force) {
|
|
57
|
+
await removeSharingLink();
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
const result = await cli.promptForConfirmation({ message: `Are you sure you want to remove sharing link ${args.options.id} of folder ${args.options.folderUrl || args.options.folderId}?` });
|
|
61
|
+
if (result) {
|
|
62
|
+
await removeSharingLink();
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
_SpoFolderSharingLinkRemoveCommand_instances = new WeakSet(), _SpoFolderSharingLinkRemoveCommand_initTelemetry = function _SpoFolderSharingLinkRemoveCommand_initTelemetry() {
|
|
68
|
+
this.telemetry.push((args) => {
|
|
69
|
+
Object.assign(this.telemetryProperties, {
|
|
70
|
+
folderUrl: typeof args.options.folderUrl !== 'undefined',
|
|
71
|
+
folderId: typeof args.options.folderId !== 'undefined',
|
|
72
|
+
force: !!args.options.force
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
}, _SpoFolderSharingLinkRemoveCommand_initOptions = function _SpoFolderSharingLinkRemoveCommand_initOptions() {
|
|
76
|
+
this.options.unshift({ option: '-u, --webUrl <webUrl>' }, { option: '--folderUrl [folderUrl]' }, { option: '--folderId [folderId]' }, { option: '-i, --id <id>' }, { option: '-f, --force' });
|
|
77
|
+
}, _SpoFolderSharingLinkRemoveCommand_initOptionSets = function _SpoFolderSharingLinkRemoveCommand_initOptionSets() {
|
|
78
|
+
this.optionSets.push({ options: ['folderUrl', 'folderId'] });
|
|
79
|
+
}, _SpoFolderSharingLinkRemoveCommand_initValidators = function _SpoFolderSharingLinkRemoveCommand_initValidators() {
|
|
80
|
+
this.validators.push(async (args) => {
|
|
81
|
+
const isValidSharePointUrl = validation.isValidSharePointUrl(args.options.webUrl);
|
|
82
|
+
if (isValidSharePointUrl !== true) {
|
|
83
|
+
return isValidSharePointUrl;
|
|
84
|
+
}
|
|
85
|
+
if (args.options.folderId && !validation.isValidGuid(args.options.folderId)) {
|
|
86
|
+
return `${args.options.folderId} is not a valid GUID`;
|
|
87
|
+
}
|
|
88
|
+
return true;
|
|
89
|
+
});
|
|
90
|
+
}, _SpoFolderSharingLinkRemoveCommand_initTypes = function _SpoFolderSharingLinkRemoveCommand_initTypes() {
|
|
91
|
+
this.types.string.push('webUrl', 'folderUrl', 'folderId', 'id');
|
|
92
|
+
this.types.boolean.push('force');
|
|
93
|
+
};
|
|
94
|
+
export default new SpoFolderSharingLinkRemoveCommand();
|
|
95
|
+
//# sourceMappingURL=folder-sharinglink-remove.js.map
|