@pnp/cli-microsoft365 5.9.0-beta.3de06bc → 5.9.0-beta.42a0949

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (80) hide show
  1. package/.eslintrc.js +17 -2
  2. package/README.md +5 -0
  3. package/dist/m365/aad/commands/app/app-add.js +37 -13
  4. package/dist/m365/outlook/commands/mail/mail-send.js +55 -31
  5. package/dist/m365/planner/commands/bucket/bucket-get.js +1 -1
  6. package/dist/m365/pp/commands/Environment.js +3 -0
  7. package/dist/m365/pp/commands/card/card-list.js +68 -0
  8. package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +69 -0
  9. package/dist/m365/pp/commands/environment/environment-get.js +75 -0
  10. package/dist/m365/pp/commands/solution/Solution.js +3 -0
  11. package/dist/m365/pp/commands/solution/solution-list.js +87 -0
  12. package/dist/m365/pp/commands.js +4 -0
  13. package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.14.0.js +0 -2
  14. package/dist/m365/spfx/commands/spfx-doctor.js +37 -7
  15. package/dist/m365/spo/commands/eventreceiver/EventReceiver.js +3 -0
  16. package/dist/m365/spo/commands/eventreceiver/eventreceiver-remove.js +182 -0
  17. package/dist/m365/spo/commands/file/file-copy.js +25 -39
  18. package/dist/m365/spo/commands/file/file-move.js +24 -37
  19. package/dist/m365/spo/commands/file/file-rename.js +19 -16
  20. package/dist/m365/spo/commands/file/file-roleassignment-add.js +231 -0
  21. package/dist/m365/spo/commands/file/file-roleinheritance-break.js +129 -0
  22. package/dist/m365/spo/commands/file/file-roleinheritance-reset.js +1 -1
  23. package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
  24. package/dist/m365/spo/commands/folder/folder-roleinheritance-break.js +94 -0
  25. package/dist/m365/spo/commands/folder/folder-roleinheritance-reset.js +1 -1
  26. package/dist/m365/spo/commands/group/AssociatedGroupPropertiesCollection.js +3 -0
  27. package/dist/m365/spo/commands/group/group-list.js +49 -10
  28. package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
  29. package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
  30. package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
  31. package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
  32. package/dist/m365/spo/commands/list/list-roleassignment-add.js +10 -10
  33. package/dist/m365/spo/commands/list/list-roleassignment-remove.js +8 -8
  34. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +14 -6
  35. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +15 -7
  36. package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
  37. package/dist/m365/spo/commands/list/list-webhook-get.js +17 -9
  38. package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
  39. package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
  40. package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
  41. package/dist/m365/spo/commands/listitem/listitem-roleassignment-remove.js +8 -8
  42. package/dist/m365/spo/commands/web/web-roleassignment-add.js +10 -10
  43. package/dist/m365/spo/commands/web/web-roleassignment-remove.js +8 -8
  44. package/dist/m365/spo/commands.js +5 -0
  45. package/dist/m365/teams/commands/channel/channel-add.js +9 -9
  46. package/dist/m365/todo/commands/task/task-set.js +53 -1
  47. package/dist/utils/powerPlatform.js +42 -0
  48. package/docs/docs/_clisettings.md +19 -0
  49. package/docs/docs/cmd/outlook/mail/mail-send.md +13 -0
  50. package/docs/docs/cmd/pp/card/card-list.md +33 -0
  51. package/docs/docs/cmd/pp/dataverse/dataverse-table-list.md +33 -0
  52. package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
  53. package/docs/docs/cmd/pp/environment/environment-list.md +1 -1
  54. package/docs/docs/cmd/pp/solution/solution-list.md +33 -0
  55. package/docs/docs/cmd/spfx/spfx-doctor.md +10 -1
  56. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
  57. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +69 -0
  58. package/docs/docs/cmd/spo/file/file-roleassignment-add.md +57 -0
  59. package/docs/docs/cmd/spo/file/file-roleinheritance-break.md +54 -0
  60. package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
  61. package/docs/docs/cmd/spo/folder/folder-roleinheritance-break.md +39 -0
  62. package/docs/docs/cmd/spo/folder/folder-roleinheritance-reset.md +2 -2
  63. package/docs/docs/cmd/spo/group/group-list.md +10 -1
  64. package/docs/docs/cmd/spo/hubsite/hubsite-disconnect.md +1 -1
  65. package/docs/docs/cmd/spo/hubsite/hubsite-get.md +3 -3
  66. package/docs/docs/cmd/spo/list/list-contenttype-add.md +16 -7
  67. package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
  68. package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
  69. package/docs/docs/cmd/spo/list/list-contenttype-remove.md +17 -8
  70. package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +11 -8
  71. package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +14 -5
  72. package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
  73. package/docs/docs/cmd/spo/list/list-webhook-get.md +15 -6
  74. package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
  75. package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
  76. package/docs/docs/cmd/spo/list/list-webhook-set.md +13 -11
  77. package/docs/docs/cmd/teams/channel/channel-add.md +4 -4
  78. package/docs/docs/cmd/todo/task/task-set.md +29 -2
  79. package/package.json +5 -1
  80. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006006_CFG_PS_features.js +0 -60
@@ -25,7 +25,6 @@ const FN002009_DEVDEP_microsoft_sp_tslint_rules_1 = require("./rules/FN002009_DE
25
25
  const FN002019_DEVDEP_spfx_fast_serve_helpers_1 = require("./rules/FN002019_DEVDEP_spfx_fast_serve_helpers");
26
26
  const FN006004_CFG_PS_developer_1 = require("./rules/FN006004_CFG_PS_developer");
27
27
  const FN006005_CFG_PS_metadata_1 = require("./rules/FN006005_CFG_PS_metadata");
28
- const FN006006_CFG_PS_features_1 = require("./rules/FN006006_CFG_PS_features");
29
28
  const FN010001_YORC_version_1 = require("./rules/FN010001_YORC_version");
30
29
  const FN014008_CODE_launch_hostedWorkbench_type_1 = require("./rules/FN014008_CODE_launch_hostedWorkbench_type");
31
30
  module.exports = [
@@ -54,7 +53,6 @@ module.exports = [
54
53
  new FN002019_DEVDEP_spfx_fast_serve_helpers_1.FN002019_DEVDEP_spfx_fast_serve_helpers('1.14.0'),
55
54
  new FN006004_CFG_PS_developer_1.FN006004_CFG_PS_developer('1.14.0'),
56
55
  new FN006005_CFG_PS_metadata_1.FN006005_CFG_PS_metadata(),
57
- new FN006006_CFG_PS_features_1.FN006006_CFG_PS_features(),
58
56
  new FN010001_YORC_version_1.FN010001_YORC_version('1.14.0'),
59
57
  new FN014008_CODE_launch_hostedWorkbench_type_1.FN014008_CODE_launch_hostedWorkbench_type('pwa-chrome')
60
58
  ];
@@ -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 _SpfxDoctorCommand_instances, _SpfxDoctorCommand_initTelemetry, _SpfxDoctorCommand_initOptions, _SpfxDoctorCommand_initValidators, _SpfxDoctorCommand_initTypes;
16
+ var _SpfxDoctorCommand_instances, _SpfxDoctorCommand_initTelemetry, _SpfxDoctorCommand_initOptions, _SpfxDoctorCommand_initValidators;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const chalk = require("chalk");
19
19
  const child_process = require("child_process");
@@ -448,7 +448,6 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
448
448
  __classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initTelemetry).call(this);
449
449
  __classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initOptions).call(this);
450
450
  __classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initValidators).call(this);
451
- __classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initTypes).call(this);
452
451
  }
453
452
  get name() {
454
453
  return commands_1.default.DOCTOR;
@@ -457,6 +456,7 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
457
456
  return 'Verifies environment configuration for using the specific version of the SharePoint Framework';
458
457
  }
459
458
  commandAction(logger, args) {
459
+ var _a;
460
460
  return __awaiter(this, void 0, void 0, function* () {
461
461
  if (!args.options.output) {
462
462
  args.options.output = 'text';
@@ -469,7 +469,7 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
469
469
  let prerequisites;
470
470
  const fixes = [];
471
471
  try {
472
- spfxVersion = yield this.getSharePointFrameworkVersion(logger);
472
+ spfxVersion = (_a = args.options.spfxVersion) !== null && _a !== void 0 ? _a : yield this.getSharePointFrameworkVersion(logger);
473
473
  if (!spfxVersion) {
474
474
  logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework`));
475
475
  throw `SharePoint Framework not found`;
@@ -479,7 +479,13 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
479
479
  logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework v${spfxVersion}`));
480
480
  throw `spfx doctor doesn't support SPFx v${spfxVersion} at this moment`;
481
481
  }
482
- logger.log(this.getStatus(CheckStatus.Success, `SharePoint Framework v${spfxVersion}`));
482
+ if (args.options.spfxVersion) {
483
+ yield this.checkSharePointFrameworkVersion(args.options.spfxVersion, fixes, logger);
484
+ }
485
+ else {
486
+ // spfx was detected and if we are here, it means that we support it
487
+ logger.log(this.getStatus(CheckStatus.Success, `SharePoint Framework v${spfxVersion}`));
488
+ }
483
489
  yield this.checkSharePointCompatibility(spfxVersion, prerequisites, args, fixes, logger);
484
490
  yield this.checkNodeVersion(prerequisites, fixes, logger);
485
491
  yield this.checkYo(prerequisites, fixes, logger);
@@ -532,6 +538,23 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
532
538
  this.checkStatus('Node', nodeVersion, prerequisites.node, OptionalOrRequired.Required, fixes, logger);
533
539
  });
534
540
  }
541
+ checkSharePointFrameworkVersion(spfxVersionRequested, fixes, logger) {
542
+ return this
543
+ .getPackageVersion('@microsoft/generator-sharepoint', PackageSearchMode.GlobalOnly, HandlePromise.Continue, logger)
544
+ .then((spfxVersionDetected) => {
545
+ const versionCheck = {
546
+ range: spfxVersionRequested,
547
+ fix: `npm i -g @microsoft/generator-sharepoint@${spfxVersionRequested}`
548
+ };
549
+ if (spfxVersionDetected) {
550
+ this.checkStatus(`SharePoint Framework`, spfxVersionDetected, versionCheck, OptionalOrRequired.Required, fixes, logger);
551
+ }
552
+ else {
553
+ logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework v${spfxVersionRequested} not found`));
554
+ fixes.push(versionCheck.fix);
555
+ }
556
+ });
557
+ }
535
558
  checkYo(prerequisites, fixes, logger) {
536
559
  return this
537
560
  .getPackageVersion('yo', PackageSearchMode.GlobalOnly, HandlePromise.Continue, logger)
@@ -710,13 +733,17 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
710
733
  _SpfxDoctorCommand_instances = new WeakSet(), _SpfxDoctorCommand_initTelemetry = function _SpfxDoctorCommand_initTelemetry() {
711
734
  this.telemetry.push((args) => {
712
735
  Object.assign(this.telemetryProperties, {
713
- env: args.options.env
736
+ env: args.options.env,
737
+ spfxVersion: args.options.spfxVersion
714
738
  });
715
739
  });
716
740
  }, _SpfxDoctorCommand_initOptions = function _SpfxDoctorCommand_initOptions() {
717
741
  this.options.unshift({
718
742
  option: '-e, --env [env]',
719
743
  autocomplete: ['sp2016', 'sp2019', 'spo']
744
+ }, {
745
+ option: '-v, --spfxVersion [spfxVersion]',
746
+ autocomplete: Object.keys(this.versions)
720
747
  });
721
748
  }, _SpfxDoctorCommand_initValidators = function _SpfxDoctorCommand_initValidators() {
722
749
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -726,13 +753,16 @@ _SpfxDoctorCommand_instances = new WeakSet(), _SpfxDoctorCommand_initTelemetry =
726
753
  return `${args.options.env} is not a valid SharePoint version. Valid versions are sp2016, sp2019 or spo`;
727
754
  }
728
755
  }
756
+ if (args.options.spfxVersion) {
757
+ if (!this.versions[args.options.spfxVersion]) {
758
+ return `${args.options.spfxVersion} is not a supported SharePoint Framework version. Supported versions are ${Object.keys(this.versions).join(', ')}`;
759
+ }
760
+ }
729
761
  if (args.options.output && args.options.output !== 'text') {
730
762
  return `The output option only accepts the type 'text'`;
731
763
  }
732
764
  return true;
733
765
  }));
734
- }, _SpfxDoctorCommand_initTypes = function _SpfxDoctorCommand_initTypes() {
735
- this.types.string.push('e', 'env');
736
766
  };
737
767
  module.exports = new SpfxDoctorCommand();
738
768
  //# sourceMappingURL=spfx-doctor.js.map
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=EventReceiver.js.map
@@ -0,0 +1,182 @@
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 _SpoEventreceiverRemoveCommand_instances, _SpoEventreceiverRemoveCommand_initTelemetry, _SpoEventreceiverRemoveCommand_initOptions, _SpoEventreceiverRemoveCommand_initValidators, _SpoEventreceiverRemoveCommand_initOptionSets;
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ const Cli_1 = require("../../../../cli/Cli");
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
+ const request_1 = require("../../../../request");
25
+ const getCommand = require('./eventreceiver-get');
26
+ class SpoEventreceiverRemoveCommand extends SpoCommand_1.default {
27
+ constructor() {
28
+ super();
29
+ _SpoEventreceiverRemoveCommand_instances.add(this);
30
+ __classPrivateFieldGet(this, _SpoEventreceiverRemoveCommand_instances, "m", _SpoEventreceiverRemoveCommand_initTelemetry).call(this);
31
+ __classPrivateFieldGet(this, _SpoEventreceiverRemoveCommand_instances, "m", _SpoEventreceiverRemoveCommand_initOptions).call(this);
32
+ __classPrivateFieldGet(this, _SpoEventreceiverRemoveCommand_instances, "m", _SpoEventreceiverRemoveCommand_initValidators).call(this);
33
+ __classPrivateFieldGet(this, _SpoEventreceiverRemoveCommand_instances, "m", _SpoEventreceiverRemoveCommand_initOptionSets).call(this);
34
+ }
35
+ get name() {
36
+ return commands_1.default.EVENTRECEIVER_REMOVE;
37
+ }
38
+ get description() {
39
+ return 'Removes event receivers for the specified web, site, or list.';
40
+ }
41
+ commandAction(logger, args) {
42
+ return __awaiter(this, void 0, void 0, function* () {
43
+ try {
44
+ const getEventReceiversOutput = yield this.getEventReceivers(args.options);
45
+ const eventReceivers = JSON.parse(getEventReceiversOutput.stdout);
46
+ if (!eventReceivers.length) {
47
+ throw Error(`Specified event receiver with ${args.options.id !== undefined ? `id ${args.options.id}` : `name ${args.options.name}`} cannot be found`);
48
+ }
49
+ if (eventReceivers.length > 1) {
50
+ throw Error(`Multiple eventreceivers with ${args.options.id !== undefined ? `id ${args.options.id} found` : `name ${args.options.name}, ids: ${eventReceivers.map(x => x.ReceiverId)} found`}`);
51
+ }
52
+ if (args.options.confirm) {
53
+ yield this.removeEventReceiver(args.options);
54
+ }
55
+ else {
56
+ const result = yield Cli_1.Cli.prompt({
57
+ type: 'confirm',
58
+ name: 'continue',
59
+ default: false,
60
+ message: `Are you sure you want to remove event receiver with ${args.options.id !== undefined ? `id ${args.options.id}` : `name ${args.options.name}`}?`
61
+ });
62
+ if (result.continue) {
63
+ yield this.removeEventReceiver(args.options);
64
+ }
65
+ }
66
+ }
67
+ catch (err) {
68
+ this.handleRejectedODataJsonPromise(err);
69
+ }
70
+ });
71
+ }
72
+ removeEventReceiver(options) {
73
+ return __awaiter(this, void 0, void 0, function* () {
74
+ let requestUrl = `${options.webUrl}/_api/`;
75
+ let listUrl = '';
76
+ let filter = '?$filter=';
77
+ if (options.listId) {
78
+ listUrl = `lists(guid'${formatting_1.formatting.encodeQueryParameter(options.listId)}')/`;
79
+ }
80
+ else if (options.listTitle) {
81
+ listUrl = `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(options.listTitle)}')/`;
82
+ }
83
+ else if (options.listUrl) {
84
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(options.webUrl, options.listUrl);
85
+ listUrl = `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
86
+ }
87
+ if (!options.scope || options.scope === 'web') {
88
+ requestUrl += `web/${listUrl}eventreceivers`;
89
+ }
90
+ else {
91
+ requestUrl += 'site/eventreceivers';
92
+ }
93
+ if (options.id) {
94
+ filter += `receiverid eq (guid'${options.id}')`;
95
+ }
96
+ else {
97
+ filter += `receivername eq '${options.name}'`;
98
+ }
99
+ const requestOptions = {
100
+ url: requestUrl + filter,
101
+ headers: {
102
+ 'accept': 'application/json;odata=nometadata'
103
+ },
104
+ responseType: 'json'
105
+ };
106
+ yield request_1.default.delete(requestOptions);
107
+ });
108
+ }
109
+ getEventReceivers(options) {
110
+ return __awaiter(this, void 0, void 0, function* () {
111
+ const getOptions = {
112
+ webUrl: options.webUrl,
113
+ listId: options.listId,
114
+ listTitle: options.listTitle,
115
+ listUrl: options.listUrl,
116
+ scope: options.scope,
117
+ id: options.id,
118
+ name: options.name,
119
+ debug: this.debug,
120
+ verbose: this.verbose
121
+ };
122
+ return yield Cli_1.Cli.executeCommandWithOutput(getCommand, { options: Object.assign(Object.assign({}, getOptions), { _: [] }) });
123
+ });
124
+ }
125
+ }
126
+ _SpoEventreceiverRemoveCommand_instances = new WeakSet(), _SpoEventreceiverRemoveCommand_initTelemetry = function _SpoEventreceiverRemoveCommand_initTelemetry() {
127
+ this.telemetry.push((args) => {
128
+ Object.assign(this.telemetryProperties, {
129
+ listId: typeof args.options.listId !== 'undefined',
130
+ listTitle: typeof args.options.listTitle !== 'undefined',
131
+ listUrl: typeof args.options.listUrl !== 'undefined',
132
+ scope: typeof args.options.scope !== 'undefined',
133
+ id: typeof args.options.id !== 'undefined',
134
+ name: typeof args.options.name !== 'undefined',
135
+ confirm: (!(!args.options.confirm)).toString()
136
+ });
137
+ });
138
+ }, _SpoEventreceiverRemoveCommand_initOptions = function _SpoEventreceiverRemoveCommand_initOptions() {
139
+ this.options.unshift({
140
+ option: '-u, --webUrl <webUrl>'
141
+ }, {
142
+ option: '--listTitle [listTitle]'
143
+ }, {
144
+ option: '--listId [listId]'
145
+ }, {
146
+ option: '--listUrl [listUrl]'
147
+ }, {
148
+ option: '-n, --name [name]'
149
+ }, {
150
+ option: '-i, --id [id]'
151
+ }, {
152
+ option: '-s, --scope [scope]',
153
+ autocomplete: ['web', 'site']
154
+ }, {
155
+ option: '--confirm'
156
+ });
157
+ }, _SpoEventreceiverRemoveCommand_initValidators = function _SpoEventreceiverRemoveCommand_initValidators() {
158
+ this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
159
+ const isValidSharePointUrl = validation_1.validation.isValidSharePointUrl(args.options.webUrl);
160
+ if (isValidSharePointUrl !== true) {
161
+ return isValidSharePointUrl;
162
+ }
163
+ const listOptions = [args.options.listId, args.options.listTitle, args.options.listUrl];
164
+ if (listOptions.some(item => item !== undefined) && listOptions.filter(item => item !== undefined).length > 1) {
165
+ return `Specify either list id or title or list url`;
166
+ }
167
+ if (args.options.listId && !validation_1.validation.isValidGuid(args.options.listId)) {
168
+ return `${args.options.listId} is not a valid GUID`;
169
+ }
170
+ if (args.options.scope && ['web', 'site'].indexOf(args.options.scope) === -1) {
171
+ return `${args.options.scope} is not a valid type value. Allowed values web|site.`;
172
+ }
173
+ if (args.options.scope && args.options.scope === 'site' && (args.options.listId || args.options.listUrl || args.options.listTitle)) {
174
+ return 'Scope cannot be set to site when retrieving list event receivers.';
175
+ }
176
+ return true;
177
+ }));
178
+ }, _SpoEventreceiverRemoveCommand_initOptionSets = function _SpoEventreceiverRemoveCommand_initOptionSets() {
179
+ this.optionSets.push(['name', 'id']);
180
+ };
181
+ module.exports = new SpoEventreceiverRemoveCommand();
182
+ //# sourceMappingURL=eventreceiver-remove.js.map
@@ -16,12 +16,14 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
16
16
  var _SpoFileCopyCommand_instances, _SpoFileCopyCommand_initTelemetry, _SpoFileCopyCommand_initOptions, _SpoFileCopyCommand_initValidators;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const url = require("url");
19
+ const Cli_1 = require("../../../../cli/Cli");
19
20
  const request_1 = require("../../../../request");
20
21
  const spo_1 = require("../../../../utils/spo");
21
22
  const urlUtil_1 = require("../../../../utils/urlUtil");
22
23
  const validation_1 = require("../../../../utils/validation");
23
24
  const SpoCommand_1 = require("../../../base/SpoCommand");
24
25
  const commands_1 = require("../../commands");
26
+ const removeCommand = require('./file-remove');
25
27
  class SpoFileCopyCommand extends SpoCommand_1.default {
26
28
  constructor() {
27
29
  super();
@@ -123,50 +125,34 @@ class SpoFileCopyCommand extends SpoCommand_1.default {
123
125
  * Moves file in the site recycle bin
124
126
  */
125
127
  recycleFile(tenantUrl, targetUrl, filename, logger) {
126
- return new Promise((resolve, reject) => {
128
+ return __awaiter(this, void 0, void 0, function* () {
127
129
  const targetFolderAbsoluteUrl = urlUtil_1.urlUtil.urlCombine(tenantUrl, targetUrl);
128
- // since the target WebFullUrl is unknown we can use getRequestDigestForSite
130
+ // since the target WebFullUrl is unknown we can use getRequestDigest
129
131
  // to get it from target folder absolute url.
130
132
  // Similar approach used here Microsoft.SharePoint.Client.Web.WebUrlFromFolderUrlDirect
131
- spo_1.spo
132
- .getRequestDigest(targetFolderAbsoluteUrl)
133
- .then((contextResponse) => {
134
- if (this.debug) {
135
- logger.logToStderr(`contextResponse.WebFullUrl: ${contextResponse.WebFullUrl}`);
136
- }
137
- if (targetUrl.charAt(0) !== '/') {
138
- targetUrl = `/${targetUrl}`;
133
+ const contextResponse = yield spo_1.spo.getRequestDigest(targetFolderAbsoluteUrl);
134
+ if (this.debug) {
135
+ logger.logToStderr(`contextResponse.WebFullUrl: ${contextResponse.WebFullUrl}`);
136
+ }
137
+ const targetFileServerRelativeUrl = `${urlUtil_1.urlUtil.getServerRelativePath(contextResponse.WebFullUrl, targetUrl)}/${filename}`;
138
+ const removeOptions = {
139
+ webUrl: contextResponse.WebFullUrl,
140
+ url: targetFileServerRelativeUrl,
141
+ recycle: true,
142
+ confirm: true,
143
+ debug: this.debug,
144
+ verbose: this.verbose
145
+ };
146
+ try {
147
+ yield Cli_1.Cli.executeCommand(removeCommand, { options: Object.assign(Object.assign({}, removeOptions), { _: [] }) });
148
+ }
149
+ catch (err) {
150
+ if (err.error !== undefined && err.error.message !== undefined && err.error.message.includes('does not exist')) {
139
151
  }
140
- if (targetUrl.lastIndexOf('/') !== targetUrl.length - 1) {
141
- targetUrl = `${targetUrl}/`;
152
+ else {
153
+ throw err;
142
154
  }
143
- const requestUrl = `${contextResponse.WebFullUrl}/_api/web/GetFileByServerRelativeUrl('${encodeURIComponent(`${targetUrl}${filename}`)}')/recycle()`;
144
- const requestOptions = {
145
- url: requestUrl,
146
- method: 'POST',
147
- headers: {
148
- 'X-HTTP-Method': 'DELETE',
149
- 'If-Match': '*',
150
- 'accept': 'application/json;odata=nometadata'
151
- },
152
- responseType: 'json'
153
- };
154
- request_1.default.post(requestOptions)
155
- .then(() => {
156
- resolve();
157
- })
158
- .catch((err) => {
159
- if (err.statusCode === 404) {
160
- // file does not exist so can proceed
161
- return resolve();
162
- }
163
- if (this.debug) {
164
- logger.logToStderr(`recycleFile error...`);
165
- logger.logToStderr(err);
166
- }
167
- reject(err);
168
- });
169
- }, (e) => reject(e));
155
+ }
170
156
  });
171
157
  }
172
158
  }
@@ -16,12 +16,14 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
16
16
  var _SpoFileMoveCommand_instances, _SpoFileMoveCommand_initTelemetry, _SpoFileMoveCommand_initOptions, _SpoFileMoveCommand_initValidators;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const url = require("url");
19
+ const Cli_1 = require("../../../../cli/Cli");
19
20
  const request_1 = require("../../../../request");
20
21
  const spo_1 = require("../../../../utils/spo");
21
22
  const urlUtil_1 = require("../../../../utils/urlUtil");
22
23
  const validation_1 = require("../../../../utils/validation");
23
24
  const SpoCommand_1 = require("../../../base/SpoCommand");
24
25
  const commands_1 = require("../../commands");
26
+ const removeCommand = require('./file-remove');
25
27
  class SpoFileMoveCommand extends SpoCommand_1.default {
26
28
  constructor() {
27
29
  super();
@@ -124,49 +126,34 @@ class SpoFileMoveCommand extends SpoCommand_1.default {
124
126
  * Moves file in the site recycle bin
125
127
  */
126
128
  recycleFile(tenantUrl, targetUrl, filename, logger) {
127
- return new Promise((resolve, reject) => {
129
+ return __awaiter(this, void 0, void 0, function* () {
128
130
  const targetFolderAbsoluteUrl = urlUtil_1.urlUtil.urlCombine(tenantUrl, targetUrl);
129
131
  // since the target WebFullUrl is unknown we can use getRequestDigest
130
132
  // to get it from target folder absolute url.
131
133
  // Similar approach used here Microsoft.SharePoint.Client.Web.WebUrlFromFolderUrlDirect
132
- spo_1.spo.getRequestDigest(targetFolderAbsoluteUrl)
133
- .then((contextResponse) => {
134
- if (this.debug) {
135
- logger.logToStderr(`contextResponse.WebFullUrl: ${contextResponse.WebFullUrl}`);
136
- }
137
- if (targetUrl.charAt(0) !== '/') {
138
- targetUrl = `/${targetUrl}`;
134
+ const contextResponse = yield spo_1.spo.getRequestDigest(targetFolderAbsoluteUrl);
135
+ if (this.debug) {
136
+ logger.logToStderr(`contextResponse.WebFullUrl: ${contextResponse.WebFullUrl}`);
137
+ }
138
+ const targetFileServerRelativeUrl = `${urlUtil_1.urlUtil.getServerRelativePath(contextResponse.WebFullUrl, targetUrl)}/${filename}`;
139
+ const removeOptions = {
140
+ webUrl: contextResponse.WebFullUrl,
141
+ url: targetFileServerRelativeUrl,
142
+ recycle: true,
143
+ confirm: true,
144
+ debug: this.debug,
145
+ verbose: this.verbose
146
+ };
147
+ try {
148
+ yield Cli_1.Cli.executeCommand(removeCommand, { options: Object.assign(Object.assign({}, removeOptions), { _: [] }) });
149
+ }
150
+ catch (err) {
151
+ if (err.error !== undefined && err.error.message !== undefined && err.error.message.includes('does not exist')) {
139
152
  }
140
- if (targetUrl.lastIndexOf('/') !== targetUrl.length - 1) {
141
- targetUrl = `${targetUrl}/`;
153
+ else {
154
+ throw err;
142
155
  }
143
- const requestUrl = `${contextResponse.WebFullUrl}/_api/web/GetFileByServerRelativeUrl('${encodeURIComponent(`${targetUrl}${filename}`)}')/recycle()`;
144
- const requestOptions = {
145
- url: requestUrl,
146
- method: 'POST',
147
- headers: {
148
- 'X-HTTP-Method': 'DELETE',
149
- 'If-Match': '*',
150
- 'accept': 'application/json;odata=nometadata'
151
- },
152
- responseType: 'json'
153
- };
154
- request_1.default.post(requestOptions)
155
- .then(() => {
156
- resolve();
157
- })
158
- .catch((err) => {
159
- if (err.statusCode === 404) {
160
- // file does not exist so can proceed
161
- return resolve();
162
- }
163
- if (this.debug) {
164
- logger.logToStderr(`recycleFile error...`);
165
- logger.logToStderr(err);
166
- }
167
- reject(err);
168
- });
169
- }, (e) => reject(e));
156
+ }
170
157
  });
171
158
  }
172
159
  }
@@ -79,23 +79,26 @@ class SpoFileRenameCommand extends SpoCommand_1.default {
79
79
  return request_1.default.get(requestOptions);
80
80
  }
81
81
  deleteFile(webUrl, sourceUrl, targetFileName) {
82
- const targetFileServerRelativeUrl = `${urlUtil_1.urlUtil.getServerRelativePath(webUrl, sourceUrl.substring(0, sourceUrl.lastIndexOf('/')))}/${targetFileName}`;
83
- const options = {
84
- webUrl: webUrl,
85
- url: targetFileServerRelativeUrl,
86
- recycle: true,
87
- confirm: true,
88
- debug: this.debug,
89
- verbose: this.verbose
90
- };
91
- return Cli_1.Cli.executeCommandWithOutput(removeCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) })
92
- .then(_ => {
93
- return Promise.resolve();
94
- }, (err) => {
95
- if (err.error !== null && err.error.message !== null && err.error.message.includes('does not exist')) {
96
- return Promise.resolve();
82
+ return __awaiter(this, void 0, void 0, function* () {
83
+ const targetFileServerRelativeUrl = `${urlUtil_1.urlUtil.getServerRelativePath(webUrl, sourceUrl.substring(0, sourceUrl.lastIndexOf('/')))}/${targetFileName}`;
84
+ const removeOptions = {
85
+ webUrl: webUrl,
86
+ url: targetFileServerRelativeUrl,
87
+ recycle: true,
88
+ confirm: true,
89
+ debug: this.debug,
90
+ verbose: this.verbose
91
+ };
92
+ try {
93
+ yield Cli_1.Cli.executeCommand(removeCommand, { options: Object.assign(Object.assign({}, removeOptions), { _: [] }) });
94
+ }
95
+ catch (err) {
96
+ if (err.error !== undefined && err.error.message !== undefined && err.error.message.includes('does not exist')) {
97
+ }
98
+ else {
99
+ throw err;
100
+ }
97
101
  }
98
- return Promise.reject(err);
99
102
  });
100
103
  }
101
104
  }