@pnp/cli-microsoft365 5.9.0-beta.fd6d022 → 5.9.0

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 (177) hide show
  1. package/.eslintrc.js +17 -2
  2. package/README.md +5 -0
  3. package/dist/Command.js +16 -2
  4. package/dist/appInsights.js +2 -0
  5. package/dist/m365/aad/commands/app/app-add.js +37 -13
  6. package/dist/m365/commands/status.js +6 -1
  7. package/dist/m365/outlook/commands/mail/mail-send.js +55 -31
  8. package/dist/m365/planner/commands/bucket/bucket-get.js +1 -1
  9. package/dist/m365/pp/commands/Environment.js +3 -0
  10. package/dist/m365/pp/commands/card/card-get.js +110 -0
  11. package/dist/m365/pp/commands/card/card-list.js +68 -0
  12. package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +69 -0
  13. package/dist/m365/pp/commands/environment/environment-get.js +75 -0
  14. package/dist/m365/pp/commands/gateway/gateway-get.js +70 -0
  15. package/dist/m365/pp/commands/solution/Solution.js +3 -0
  16. package/dist/m365/pp/commands/solution/solution-get.js +117 -0
  17. package/dist/m365/pp/commands/solution/solution-list.js +87 -0
  18. package/dist/m365/pp/commands/tenant/tenant-settings-list.js +45 -0
  19. package/dist/m365/pp/commands.js +9 -1
  20. package/dist/m365/spfx/commands/project/project-doctor.js +4 -1
  21. package/dist/m365/spfx/commands/project/project-externalize.js +4 -1
  22. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010001_YORC_version.js +2 -1
  23. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010002_YORC_isCreatingSolution.js +2 -1
  24. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010003_YORC_packageManager.js +2 -1
  25. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010004_YORC_componentType.js +2 -1
  26. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010005_YORC_environment.js +2 -1
  27. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010006_YORC_framework.js +3 -2
  28. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010007_YORC_isDomainIsolated.js +2 -1
  29. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010008_YORC_nodeVersion.js +2 -1
  30. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010009_YORC_sdkVersions_microsoft_graph_client.js +56 -0
  31. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010010_YORC_sdkVersions_teams_js.js +56 -0
  32. package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.14.0.js +0 -2
  33. package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.16.0-beta.1.js → upgrade-1.16.0-beta.2.js} +44 -28
  34. package/dist/m365/spfx/commands/project/project-upgrade.js +1 -1
  35. package/dist/m365/spfx/commands/spfx-doctor.js +54 -9
  36. package/dist/m365/spo/commands/contenttype/contenttype-add.js +82 -43
  37. package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +53 -21
  38. package/dist/m365/spo/commands/contenttype/contenttype-get.js +35 -14
  39. package/dist/m365/spo/commands/eventreceiver/EventReceiver.js +3 -0
  40. package/dist/m365/spo/commands/eventreceiver/eventreceiver-remove.js +182 -0
  41. package/dist/m365/spo/commands/field/field-add.js +26 -1
  42. package/dist/m365/spo/commands/field/field-set.js +23 -13
  43. package/dist/m365/spo/commands/file/file-copy.js +25 -39
  44. package/dist/m365/spo/commands/file/file-move.js +24 -37
  45. package/dist/m365/spo/commands/file/file-rename.js +19 -16
  46. package/dist/m365/spo/commands/file/file-roleassignment-add.js +231 -0
  47. package/dist/m365/spo/commands/file/file-roleassignment-remove.js +180 -0
  48. package/dist/m365/spo/commands/file/file-roleinheritance-break.js +129 -0
  49. package/dist/m365/spo/commands/file/file-roleinheritance-reset.js +1 -1
  50. package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
  51. package/dist/m365/spo/commands/folder/folder-roleinheritance-break.js +94 -0
  52. package/dist/m365/spo/commands/folder/folder-roleinheritance-reset.js +1 -1
  53. package/dist/m365/spo/commands/group/AssociatedGroupPropertiesCollection.js +3 -0
  54. package/dist/m365/spo/commands/group/group-list.js +49 -10
  55. package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
  56. package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
  57. package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
  58. package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
  59. package/dist/m365/spo/commands/list/list-roleassignment-add.js +10 -10
  60. package/dist/m365/spo/commands/list/list-roleassignment-remove.js +8 -8
  61. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +14 -6
  62. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +15 -7
  63. package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
  64. package/dist/m365/spo/commands/list/list-webhook-get.js +17 -10
  65. package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
  66. package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
  67. package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
  68. package/dist/m365/spo/commands/listitem/listitem-add.js +24 -14
  69. package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +18 -8
  70. package/dist/m365/spo/commands/listitem/listitem-get.js +18 -8
  71. package/dist/m365/spo/commands/listitem/listitem-isrecord.js +20 -10
  72. package/dist/m365/spo/commands/listitem/listitem-list.js +27 -11
  73. package/dist/m365/spo/commands/listitem/listitem-record-declare.js +19 -12
  74. package/dist/m365/spo/commands/listitem/listitem-record-undeclare.js +24 -21
  75. package/dist/m365/spo/commands/listitem/listitem-remove.js +19 -11
  76. package/dist/m365/spo/commands/listitem/listitem-roleassignment-add.js +239 -0
  77. package/dist/m365/spo/commands/listitem/listitem-roleassignment-remove.js +8 -8
  78. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +13 -5
  79. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +14 -6
  80. package/dist/m365/spo/commands/listitem/listitem-set.js +52 -44
  81. package/dist/m365/spo/commands/web/web-roleassignment-add.js +10 -10
  82. package/dist/m365/spo/commands/web/web-roleassignment-remove.js +8 -8
  83. package/dist/m365/spo/commands/web/web-roleinheritance-break.js +100 -0
  84. package/dist/m365/spo/commands.js +8 -0
  85. package/dist/m365/teams/commands/channel/channel-add.js +9 -9
  86. package/dist/m365/todo/commands/list/list-get.js +89 -0
  87. package/dist/m365/todo/commands/task/task-add.js +55 -3
  88. package/dist/m365/todo/commands/task/task-get.js +108 -0
  89. package/dist/m365/todo/commands/task/task-set.js +53 -1
  90. package/dist/m365/todo/commands.js +2 -0
  91. package/dist/utils/cache.js +81 -0
  92. package/dist/utils/pid.js +57 -0
  93. package/dist/utils/powerPlatform.js +42 -0
  94. package/docs/docs/_clisettings.md +19 -0
  95. package/docs/docs/cmd/outlook/mail/mail-send.md +13 -0
  96. package/docs/docs/cmd/planner/bucket/bucket-add.md +29 -0
  97. package/docs/docs/cmd/planner/bucket/bucket-get.md +29 -0
  98. package/docs/docs/cmd/planner/bucket/bucket-list.md +30 -0
  99. package/docs/docs/cmd/planner/bucket/bucket-remove.md +4 -0
  100. package/docs/docs/cmd/planner/bucket/bucket-set.md +4 -0
  101. package/docs/docs/cmd/planner/plan/plan-add.md +123 -0
  102. package/docs/docs/cmd/planner/plan/plan-get.md +75 -0
  103. package/docs/docs/cmd/planner/plan/plan-list.md +45 -0
  104. package/docs/docs/cmd/planner/plan/plan-remove.md +4 -0
  105. package/docs/docs/cmd/pp/card/card-get.md +51 -0
  106. package/docs/docs/cmd/pp/card/card-list.md +33 -0
  107. package/docs/docs/cmd/pp/dataverse/dataverse-table-list.md +33 -0
  108. package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
  109. package/docs/docs/cmd/pp/environment/environment-list.md +1 -1
  110. package/docs/docs/cmd/pp/gateway/gateway-get.md +24 -0
  111. package/docs/docs/cmd/pp/solution/solution-get.md +51 -0
  112. package/docs/docs/cmd/pp/solution/solution-list.md +33 -0
  113. package/docs/docs/cmd/pp/tenant/tenant-settings-list.md +26 -0
  114. package/docs/docs/cmd/spfx/project/project-rename.md +1 -14
  115. package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
  116. package/docs/docs/cmd/spfx/spfx-doctor.md +10 -1
  117. package/docs/docs/cmd/spo/contenttype/contenttype-add.md +20 -2
  118. package/docs/docs/cmd/spo/contenttype/contenttype-field-remove.md +22 -4
  119. package/docs/docs/cmd/spo/contenttype/contenttype-get.md +21 -3
  120. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
  121. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +69 -0
  122. package/docs/docs/cmd/spo/field/field-add.md +20 -2
  123. package/docs/docs/cmd/spo/field/field-set.md +11 -2
  124. package/docs/docs/cmd/spo/file/file-roleassignment-add.md +57 -0
  125. package/docs/docs/cmd/spo/file/file-roleassignment-remove.md +54 -0
  126. package/docs/docs/cmd/spo/file/file-roleinheritance-break.md +54 -0
  127. package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
  128. package/docs/docs/cmd/spo/folder/folder-roleinheritance-break.md +39 -0
  129. package/docs/docs/cmd/spo/folder/folder-roleinheritance-reset.md +2 -2
  130. package/docs/docs/cmd/spo/group/group-list.md +10 -1
  131. package/docs/docs/cmd/spo/hubsite/hubsite-disconnect.md +1 -1
  132. package/docs/docs/cmd/spo/hubsite/hubsite-get.md +3 -3
  133. package/docs/docs/cmd/spo/list/list-contenttype-add.md +16 -7
  134. package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
  135. package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
  136. package/docs/docs/cmd/spo/list/list-contenttype-remove.md +17 -8
  137. package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +11 -8
  138. package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +14 -5
  139. package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
  140. package/docs/docs/cmd/spo/list/list-webhook-get.md +16 -7
  141. package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
  142. package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
  143. package/docs/docs/cmd/spo/list/list-webhook-set.md +14 -12
  144. package/docs/docs/cmd/spo/listitem/listitem-add.md +11 -2
  145. package/docs/docs/cmd/spo/listitem/listitem-attachment-list.md +11 -2
  146. package/docs/docs/cmd/spo/listitem/listitem-get.md +11 -2
  147. package/docs/docs/cmd/spo/listitem/listitem-isrecord.md +12 -2
  148. package/docs/docs/cmd/spo/listitem/listitem-list.md +12 -3
  149. package/docs/docs/cmd/spo/listitem/listitem-record-declare.md +7 -4
  150. package/docs/docs/cmd/spo/listitem/listitem-record-undeclare.md +11 -2
  151. package/docs/docs/cmd/spo/listitem/listitem-remove.md +11 -2
  152. package/docs/docs/cmd/spo/listitem/listitem-roleassignment-add.md +81 -0
  153. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +7 -4
  154. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +11 -2
  155. package/docs/docs/cmd/spo/listitem/listitem-set.md +7 -4
  156. package/docs/docs/cmd/spo/web/web-roleinheritance-break.md +44 -0
  157. package/docs/docs/cmd/teams/channel/channel-add.md +4 -4
  158. package/docs/docs/cmd/tenant/id/id-get.md +20 -0
  159. package/docs/docs/cmd/tenant/report/report-activeusercounts.md +35 -0
  160. package/docs/docs/cmd/tenant/report/report-activeuserdetail.md +49 -0
  161. package/docs/docs/cmd/tenant/report/report-office365activationcounts.md +32 -0
  162. package/docs/docs/cmd/tenant/report/report-office365activationsusercounts.md +30 -0
  163. package/docs/docs/cmd/tenant/report/report-office365activationsuserdetail.md +36 -0
  164. package/docs/docs/cmd/tenant/report/report-servicesusercounts.md +41 -0
  165. package/docs/docs/cmd/tenant/security/security-alerts-list.md +105 -0
  166. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-get.md +87 -0
  167. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-list.md +91 -0
  168. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-get.md +62 -0
  169. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-list.md +51 -0
  170. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-get.md +64 -0
  171. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-list.md +52 -0
  172. package/docs/docs/cmd/todo/list/list-get.md +61 -0
  173. package/docs/docs/cmd/todo/task/task-add.md +32 -5
  174. package/docs/docs/cmd/todo/task/task-get.md +75 -0
  175. package/docs/docs/cmd/todo/task/task-set.md +29 -2
  176. package/package.json +13 -3
  177. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006006_CFG_PS_features.js +0 -60
@@ -17,6 +17,7 @@ var _SpoListContentTypeListCommand_instances, _SpoListContentTypeListCommand_ini
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -41,18 +42,22 @@ class SpoListContentTypeListCommand extends SpoCommand_1.default {
41
42
  commandAction(logger, args) {
42
43
  return __awaiter(this, void 0, void 0, function* () {
43
44
  if (this.verbose) {
44
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
45
+ const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
45
46
  logger.logToStderr(`Retrieving content types information for list ${list} in site at ${args.options.webUrl}...`);
46
47
  }
47
- let requestUrl = '';
48
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
48
49
  if (args.options.listId) {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/ContentTypes`;
50
+ requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
50
51
  }
51
- else {
52
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/ContentTypes`;
52
+ else if (args.options.listTitle) {
53
+ requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
54
+ }
55
+ else if (args.options.listUrl) {
56
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
+ requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
53
58
  }
54
59
  const requestOptions = {
55
- url: requestUrl,
60
+ url: `${requestUrl}/ContentTypes`,
56
61
  method: 'GET',
57
62
  headers: {
58
63
  'accept': 'application/json;odata=nometadata'
@@ -73,7 +78,8 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
73
78
  this.telemetry.push((args) => {
74
79
  Object.assign(this.telemetryProperties, {
75
80
  listId: typeof args.options.listId !== 'undefined',
76
- listTitle: typeof args.options.listTitle !== 'undefined'
81
+ listTitle: typeof args.options.listTitle !== 'undefined',
82
+ listUrl: typeof args.options.listUrl !== 'undefined'
77
83
  });
78
84
  });
79
85
  }, _SpoListContentTypeListCommand_initOptions = function _SpoListContentTypeListCommand_initOptions() {
@@ -83,6 +89,8 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
83
89
  option: '-l, --listId [listId]'
84
90
  }, {
85
91
  option: '-t, --listTitle [listTitle]'
92
+ }, {
93
+ option: '--listUrl [listUrl]'
86
94
  });
87
95
  }, _SpoListContentTypeListCommand_initValidators = function _SpoListContentTypeListCommand_initValidators() {
88
96
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -98,7 +106,7 @@ _SpoListContentTypeListCommand_instances = new WeakSet(), _SpoListContentTypeLis
98
106
  return true;
99
107
  }));
100
108
  }, _SpoListContentTypeListCommand_initOptionSets = function _SpoListContentTypeListCommand_initOptionSets() {
101
- this.optionSets.push(['listId', 'listTitle']);
109
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
102
110
  };
103
111
  module.exports = new SpoListContentTypeListCommand();
104
112
  //# sourceMappingURL=list-contenttype-list.js.map
@@ -18,6 +18,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const Cli_1 = require("../../../../cli/Cli");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -41,18 +42,22 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
41
42
  return __awaiter(this, void 0, void 0, function* () {
42
43
  const removeContentTypeFromList = () => __awaiter(this, void 0, void 0, function* () {
43
44
  if (this.verbose) {
44
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
45
+ const list = (args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl);
45
46
  logger.logToStderr(`Removing content type ${args.options.contentTypeId} from list ${list} in site at ${args.options.webUrl}...`);
46
47
  }
47
- let requestUrl = '';
48
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
48
49
  if (args.options.listId) {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`;
50
+ requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
50
51
  }
51
- else {
52
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`;
52
+ else if (args.options.listTitle) {
53
+ requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
54
+ }
55
+ else if (args.options.listUrl) {
56
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
+ requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
53
58
  }
54
59
  const requestOptions = {
55
- url: requestUrl,
60
+ url: `${requestUrl}/ContentTypes('${encodeURIComponent(args.options.contentTypeId)}')`,
56
61
  headers: {
57
62
  'X-HTTP-Method': 'DELETE',
58
63
  'If-Match': '*',
@@ -75,7 +80,7 @@ class SpoListContentTypeRemoveCommand extends SpoCommand_1.default {
75
80
  type: 'confirm',
76
81
  name: 'continue',
77
82
  default: false,
78
- message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId || args.options.listTitle} in site ${args.options.webUrl}?`
83
+ message: `Are you sure you want to remove the content type ${args.options.contentTypeId} from the list ${args.options.listId ? args.options.listId : args.options.listTitle ? args.options.listTitle : args.options.listUrl} in site ${args.options.webUrl}?`
79
84
  });
80
85
  if (result.continue) {
81
86
  yield removeContentTypeFromList();
@@ -89,6 +94,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
89
94
  Object.assign(this.telemetryProperties, {
90
95
  listId: typeof args.options.listId !== 'undefined',
91
96
  listTitle: typeof args.options.listTitle !== 'undefined',
97
+ listUrl: typeof args.options.listUrl !== 'undefined',
92
98
  confirm: (!(!args.options.confirm)).toString()
93
99
  });
94
100
  });
@@ -99,6 +105,8 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
99
105
  option: '-l, --listId [listId]'
100
106
  }, {
101
107
  option: '-t, --listTitle [listTitle]'
108
+ }, {
109
+ option: '--listUrl [listUrl]'
102
110
  }, {
103
111
  option: '-c, --contentTypeId <contentTypeId>'
104
112
  }, {
@@ -120,7 +128,7 @@ _SpoListContentTypeRemoveCommand_instances = new WeakSet(), _SpoListContentTypeR
120
128
  }, _SpoListContentTypeRemoveCommand_initTypes = function _SpoListContentTypeRemoveCommand_initTypes() {
121
129
  this.types.string.push('contentTypeId', 'c');
122
130
  }, _SpoListContentTypeRemoveCommand_initOptionSets = function _SpoListContentTypeRemoveCommand_initOptionSets() {
123
- this.optionSets.push(['listId', 'listTitle']);
131
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
124
132
  };
125
133
  module.exports = new SpoListContentTypeRemoveCommand();
126
134
  //# sourceMappingURL=list-contenttype-remove.js.map
@@ -56,17 +56,17 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
56
56
  const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
57
  requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
58
58
  }
59
- args.options.roleDefinitionId = yield this.GetRoleDefinitionId(args.options);
59
+ args.options.roleDefinitionId = yield this.getRoleDefinitionId(args.options);
60
60
  if (args.options.upn) {
61
- args.options.principalId = yield this.GetUserPrincipalId(args.options);
62
- yield this.AddRoleAssignment(requestUrl, logger, args.options);
61
+ args.options.principalId = yield this.getUserPrincipalId(args.options);
62
+ yield this.addRoleAssignment(requestUrl, logger, args.options);
63
63
  }
64
64
  else if (args.options.groupName) {
65
- args.options.principalId = yield this.GetGroupPrincipalId(args.options);
66
- this.AddRoleAssignment(requestUrl, logger, args.options);
65
+ args.options.principalId = yield this.getGroupPrincipalId(args.options);
66
+ yield this.addRoleAssignment(requestUrl, logger, args.options);
67
67
  }
68
68
  else {
69
- yield this.AddRoleAssignment(requestUrl, logger, args.options);
69
+ yield this.addRoleAssignment(requestUrl, logger, args.options);
70
70
  }
71
71
  }
72
72
  catch (err) {
@@ -74,7 +74,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
74
74
  }
75
75
  });
76
76
  }
77
- AddRoleAssignment(requestUrl, logger, options) {
77
+ addRoleAssignment(requestUrl, logger, options) {
78
78
  const requestOptions = {
79
79
  url: `${requestUrl}roleassignments/addroleassignment(principalid='${options.principalId}',roledefid='${options.roleDefinitionId}')`,
80
80
  method: 'POST',
@@ -89,7 +89,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
89
89
  .then(_ => Promise.resolve())
90
90
  .catch((err) => Promise.reject(err));
91
91
  }
92
- GetRoleDefinitionId(options) {
92
+ getRoleDefinitionId(options) {
93
93
  if (!options.roleDefinitionName) {
94
94
  return Promise.resolve(options.roleDefinitionId);
95
95
  }
@@ -108,7 +108,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
108
108
  return Promise.reject(err);
109
109
  });
110
110
  }
111
- GetGroupPrincipalId(options) {
111
+ getGroupPrincipalId(options) {
112
112
  const groupGetCommandOptions = {
113
113
  webUrl: options.webUrl,
114
114
  name: options.groupName,
@@ -124,7 +124,7 @@ class SpoListRoleAssignmentAddCommand extends SpoCommand_1.default {
124
124
  return Promise.reject(err);
125
125
  });
126
126
  }
127
- GetUserPrincipalId(options) {
127
+ getUserPrincipalId(options) {
128
128
  const userGetCommandOptions = {
129
129
  webUrl: options.webUrl,
130
130
  email: options.upn,
@@ -57,15 +57,15 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
57
57
  requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
58
58
  }
59
59
  if (args.options.upn) {
60
- args.options.principalId = yield this.GetUserPrincipalId(args.options);
61
- yield this.RemoveRoleAssignment(requestUrl, logger, args.options);
60
+ args.options.principalId = yield this.getUserPrincipalId(args.options);
61
+ yield this.removeRoleAssignment(requestUrl, logger, args.options);
62
62
  }
63
63
  else if (args.options.groupName) {
64
- args.options.principalId = yield this.GetGroupPrincipalId(args.options);
65
- yield this.RemoveRoleAssignment(requestUrl, logger, args.options);
64
+ args.options.principalId = yield this.getGroupPrincipalId(args.options);
65
+ yield this.removeRoleAssignment(requestUrl, logger, args.options);
66
66
  }
67
67
  else {
68
- yield this.RemoveRoleAssignment(requestUrl, logger, args.options);
68
+ yield this.removeRoleAssignment(requestUrl, logger, args.options);
69
69
  }
70
70
  }
71
71
  catch (err) {
@@ -88,7 +88,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
88
88
  }
89
89
  });
90
90
  }
91
- RemoveRoleAssignment(requestUrl, logger, options) {
91
+ removeRoleAssignment(requestUrl, logger, options) {
92
92
  const requestOptions = {
93
93
  url: `${requestUrl}roleassignments/removeroleassignment(principalid='${options.principalId}')`,
94
94
  method: 'POST',
@@ -103,7 +103,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
103
103
  .then(_ => Promise.resolve())
104
104
  .catch((err) => Promise.reject(err));
105
105
  }
106
- GetGroupPrincipalId(options) {
106
+ getGroupPrincipalId(options) {
107
107
  const groupGetCommandOptions = {
108
108
  webUrl: options.webUrl,
109
109
  name: options.groupName,
@@ -119,7 +119,7 @@ class SpoListRoleAssignmentRemoveCommand extends SpoCommand_1.default {
119
119
  return Promise.reject(err);
120
120
  });
121
121
  }
122
- GetUserPrincipalId(options) {
122
+ getUserPrincipalId(options) {
123
123
  const userGetCommandOptions = {
124
124
  webUrl: options.webUrl,
125
125
  email: options.upn,
@@ -17,6 +17,7 @@ var _SpoListRoleInheritanceBreakCommand_instances, _SpoListRoleInheritanceBreakC
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -40,19 +41,23 @@ class SpoListRoleInheritanceBreakCommand extends SpoCommand_1.default {
40
41
  if (this.verbose) {
41
42
  logger.logToStderr(`Breaking role inheritance of list in site at ${args.options.webUrl}...`);
42
43
  }
43
- let requestUrl = `${args.options.webUrl}/_api/web/lists`;
44
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
44
45
  if (args.options.listId) {
45
- requestUrl += `(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
46
+ requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/`;
46
47
  }
47
- else {
48
- requestUrl += `/getbytitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
48
+ else if (args.options.listTitle) {
49
+ requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/`;
50
+ }
51
+ else if (args.options.listUrl) {
52
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
53
+ requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
49
54
  }
50
55
  let keepExistingPermissions = true;
51
56
  if (args.options.clearExistingPermissions) {
52
57
  keepExistingPermissions = !args.options.clearExistingPermissions;
53
58
  }
54
59
  const requestOptions = {
55
- url: `${requestUrl}/breakroleinheritance(${keepExistingPermissions})`,
60
+ url: `${requestUrl}breakroleinheritance(${keepExistingPermissions})`,
56
61
  method: 'POST',
57
62
  headers: {
58
63
  'accept': 'application/json;odata=nometadata',
@@ -74,6 +79,7 @@ _SpoListRoleInheritanceBreakCommand_instances = new WeakSet(), _SpoListRoleInher
74
79
  Object.assign(this.telemetryProperties, {
75
80
  listId: typeof args.options.listId !== 'undefined',
76
81
  listTitle: typeof args.options.listTitle !== 'undefined',
82
+ listUrl: typeof args.options.listUrl !== 'undefined',
77
83
  clearExistingPermissions: args.options.clearExistingPermissions === true
78
84
  });
79
85
  });
@@ -84,6 +90,8 @@ _SpoListRoleInheritanceBreakCommand_instances = new WeakSet(), _SpoListRoleInher
84
90
  option: '-i, --listId [listId]'
85
91
  }, {
86
92
  option: '-t, --listTitle [listTitle]'
93
+ }, {
94
+ option: '--listUrl [listUrl]'
87
95
  }, {
88
96
  option: '-c, --clearExistingPermissions'
89
97
  });
@@ -99,7 +107,7 @@ _SpoListRoleInheritanceBreakCommand_instances = new WeakSet(), _SpoListRoleInher
99
107
  return true;
100
108
  }));
101
109
  }, _SpoListRoleInheritanceBreakCommand_initOptionSets = function _SpoListRoleInheritanceBreakCommand_initOptionSets() {
102
- this.optionSets.push(['listId', 'listTitle']);
110
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
103
111
  };
104
112
  module.exports = new SpoListRoleInheritanceBreakCommand();
105
113
  //# sourceMappingURL=list-roleinheritance-break.js.map
@@ -17,6 +17,7 @@ var _SpoListRoleInheritanceResetCommand_instances, _SpoListRoleInheritanceResetC
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -40,15 +41,19 @@ class SpoListRoleInheritanceResetCommand extends SpoCommand_1.default {
40
41
  if (this.verbose) {
41
42
  logger.logToStderr(`Restore role inheritance of list in site at ${args.options.webUrl}...`);
42
43
  }
43
- let requestUrl = `${args.options.webUrl}/_api/web/lists`;
44
+ let requestUrl = `${args.options.webUrl}/_api/web/`;
44
45
  if (args.options.listId) {
45
- requestUrl += `(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
46
+ requestUrl += `lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/`;
46
47
  }
47
- else {
48
- requestUrl += `/getbytitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
48
+ else if (args.options.listTitle) {
49
+ requestUrl += `lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/`;
50
+ }
51
+ else if (args.options.listUrl) {
52
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
53
+ requestUrl += `GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/`;
49
54
  }
50
55
  const requestOptions = {
51
- url: `${requestUrl}/resetroleinheritance`,
56
+ url: `${requestUrl}resetroleinheritance`,
52
57
  method: 'POST',
53
58
  headers: {
54
59
  'accept': 'application/json;odata=nometadata',
@@ -69,7 +74,8 @@ _SpoListRoleInheritanceResetCommand_instances = new WeakSet(), _SpoListRoleInher
69
74
  this.telemetry.push((args) => {
70
75
  Object.assign(this.telemetryProperties, {
71
76
  listId: typeof args.options.listId !== 'undefined',
72
- listTitle: typeof args.options.listTitle !== 'undefined'
77
+ listTitle: typeof args.options.listTitle !== 'undefined',
78
+ listUrl: typeof args.options.listUrl !== 'undefined'
73
79
  });
74
80
  });
75
81
  }, _SpoListRoleInheritanceResetCommand_initOptions = function _SpoListRoleInheritanceResetCommand_initOptions() {
@@ -79,6 +85,8 @@ _SpoListRoleInheritanceResetCommand_instances = new WeakSet(), _SpoListRoleInher
79
85
  option: '-i, --listId [listId]'
80
86
  }, {
81
87
  option: '-t, --listTitle [listTitle]'
88
+ }, {
89
+ option: '--listUrl [listUrl]'
82
90
  });
83
91
  }, _SpoListRoleInheritanceResetCommand_initValidators = function _SpoListRoleInheritanceResetCommand_initValidators() {
84
92
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -92,7 +100,7 @@ _SpoListRoleInheritanceResetCommand_instances = new WeakSet(), _SpoListRoleInher
92
100
  return true;
93
101
  }));
94
102
  }, _SpoListRoleInheritanceResetCommand_initOptionSets = function _SpoListRoleInheritanceResetCommand_initOptionSets() {
95
- this.optionSets.push(['listId', 'listTitle']);
103
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
96
104
  };
97
105
  module.exports = new SpoListRoleInheritanceResetCommand();
98
106
  //# sourceMappingURL=list-roleinheritance-reset.js.map
@@ -17,6 +17,7 @@ var _SpoListWebhookAddCommand_instances, _SpoListWebhookAddCommand_initTelemetry
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -42,17 +43,21 @@ class SpoListWebhookAddCommand extends SpoCommand_1.default {
42
43
  commandAction(logger, args) {
43
44
  return __awaiter(this, void 0, void 0, function* () {
44
45
  if (this.verbose) {
45
- logger.logToStderr(`Adding webhook to list ${args.options.listId ? args.options.listId : args.options.listTitle} located at site ${args.options.webUrl}...`);
46
+ logger.logToStderr(`Adding webhook to list ${args.options.listId || args.options.listTitle || args.options.listUrl} located at site ${args.options.webUrl}...`);
46
47
  }
47
- let requestUrl = '';
48
+ let requestUrl = `${args.options.webUrl}/_api/web`;
48
49
  if (args.options.listId) {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions')`;
50
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
50
51
  }
51
- else {
52
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions')`;
52
+ else if (args.options.listTitle) {
53
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
54
+ }
55
+ else if (args.options.listUrl) {
56
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
57
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions`;
53
58
  }
54
59
  const requestBody = {};
55
- requestBody.resource = args.options.listId ? args.options.listId : args.options.listTitle;
60
+ requestBody.resource = args.options.listId || args.options.listTitle || args.options.listUrl;
56
61
  requestBody.notificationUrl = args.options.notificationUrl;
57
62
  // If no expiration date has been provided we will default to the
58
63
  // maximum expiration date of 180 days from now
@@ -84,10 +89,11 @@ class SpoListWebhookAddCommand extends SpoCommand_1.default {
84
89
  _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_initTelemetry = function _SpoListWebhookAddCommand_initTelemetry() {
85
90
  this.telemetry.push((args) => {
86
91
  Object.assign(this.telemetryProperties, {
87
- listId: (!(!args.options.listId)).toString(),
88
- listTitle: (!(!args.options.listTitle)).toString(),
89
- expirationDateTime: (!(!args.options.expirationDateTime)).toString(),
90
- clientState: (!(!args.options.clientState)).toString()
92
+ listId: typeof args.options.listId !== 'undefined',
93
+ listTitle: typeof args.options.listTitle !== 'undefined',
94
+ listUrl: typeof args.options.listUrl !== 'undefined',
95
+ expirationDateTime: typeof args.options.expirationDateTime !== 'undefined',
96
+ clientState: typeof args.options.clientState !== 'undefined'
91
97
  });
92
98
  });
93
99
  }, _SpoListWebhookAddCommand_initOptions = function _SpoListWebhookAddCommand_initOptions() {
@@ -97,6 +103,8 @@ _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_i
97
103
  option: '-l, --listId [listId]'
98
104
  }, {
99
105
  option: '-t, --listTitle [listTitle]'
106
+ }, {
107
+ option: '--listUrl [listUrl]'
100
108
  }, {
101
109
  option: '-n, --notificationUrl <notificationUrl>'
102
110
  }, {
@@ -129,7 +137,7 @@ _SpoListWebhookAddCommand_instances = new WeakSet(), _SpoListWebhookAddCommand_i
129
137
  return true;
130
138
  }));
131
139
  }, _SpoListWebhookAddCommand_initOptionSets = function _SpoListWebhookAddCommand_initOptionSets() {
132
- this.optionSets.push(['listId', 'listTitle']);
140
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
133
141
  };
134
142
  module.exports = new SpoListWebhookAddCommand();
135
143
  //# sourceMappingURL=list-webhook-add.js.map
@@ -17,6 +17,7 @@ var _SpoListWebhookGetCommand_instances, _SpoListWebhookGetCommand_initTelemetry
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const request_1 = require("../../../../request");
19
19
  const formatting_1 = require("../../../../utils/formatting");
20
+ const urlUtil_1 = require("../../../../utils/urlUtil");
20
21
  const validation_1 = require("../../../../utils/validation");
21
22
  const SpoCommand_1 = require("../../../base/SpoCommand");
22
23
  const commands_1 = require("../../commands");
@@ -38,15 +39,19 @@ class SpoListWebhookGetCommand extends SpoCommand_1.default {
38
39
  commandAction(logger, args) {
39
40
  return __awaiter(this, void 0, void 0, function* () {
40
41
  if (this.verbose) {
41
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
42
+ const list = (args.options.listId || args.options.listTitle || args.options.listUrl);
42
43
  logger.logToStderr(`Retrieving information for webhook ${args.options.id} belonging to list ${list} in site at ${args.options.webUrl}...`);
43
44
  }
44
- let requestUrl = '';
45
+ let requestUrl = `${args.options.webUrl}/_api/web`;
45
46
  if (args.options.listId) {
46
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
47
48
  }
48
- else {
49
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
+ else if (args.options.listTitle) {
50
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
51
+ }
52
+ else if (args.options.listUrl) {
53
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
54
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
50
55
  }
51
56
  const requestOptions = {
52
57
  url: requestUrl,
@@ -72,9 +77,9 @@ class SpoListWebhookGetCommand extends SpoCommand_1.default {
72
77
  _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_initTelemetry = function _SpoListWebhookGetCommand_initTelemetry() {
73
78
  this.telemetry.push((args) => {
74
79
  Object.assign(this.telemetryProperties, {
75
- listId: (!(!args.options.listId)).toString(),
76
- listTitle: (!(!args.options.listTitle)).toString(),
77
- id: (!(!args.options.id)).toString()
80
+ listId: typeof args.options.listId !== 'undefined',
81
+ listTitle: typeof args.options.listTitle !== 'undefined',
82
+ listUrl: typeof args.options.listUrl !== 'undefined'
78
83
  });
79
84
  });
80
85
  }, _SpoListWebhookGetCommand_initOptions = function _SpoListWebhookGetCommand_initOptions() {
@@ -85,7 +90,9 @@ _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_i
85
90
  }, {
86
91
  option: '-t, --listTitle [listTitle]'
87
92
  }, {
88
- option: '-i, --id [id]'
93
+ option: '--listUrl [listUrl]'
94
+ }, {
95
+ option: '-i, --id <id>'
89
96
  });
90
97
  }, _SpoListWebhookGetCommand_initValidators = function _SpoListWebhookGetCommand_initValidators() {
91
98
  this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
@@ -104,7 +111,7 @@ _SpoListWebhookGetCommand_instances = new WeakSet(), _SpoListWebhookGetCommand_i
104
111
  return true;
105
112
  }));
106
113
  }, _SpoListWebhookGetCommand_initOptionSets = function _SpoListWebhookGetCommand_initOptionSets() {
107
- this.optionSets.push(['listId', 'listTitle']);
114
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
108
115
  };
109
116
  module.exports = new SpoListWebhookGetCommand();
110
117
  //# sourceMappingURL=list-webhook-get.js.map
@@ -13,11 +13,12 @@ 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 _SpoListWebhookListCommand_instances, _SpoListWebhookListCommand_initTelemetry, _SpoListWebhookListCommand_initOptions, _SpoListWebhookListCommand_initValidators;
16
+ var _SpoListWebhookListCommand_instances, _SpoListWebhookListCommand_initTelemetry, _SpoListWebhookListCommand_initOptions, _SpoListWebhookListCommand_initValidators, _SpoListWebhookListCommand_initOptionSets;
17
17
  Object.defineProperty(exports, "__esModule", { value: true });
18
18
  const chalk = require("chalk");
19
19
  const request_1 = require("../../../../request");
20
20
  const formatting_1 = require("../../../../utils/formatting");
21
+ const urlUtil_1 = require("../../../../utils/urlUtil");
21
22
  const validation_1 = require("../../../../utils/validation");
22
23
  const SpoCommand_1 = require("../../../base/SpoCommand");
23
24
  const commands_1 = require("../../commands");
@@ -28,6 +29,7 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
28
29
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initTelemetry).call(this);
29
30
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initOptions).call(this);
30
31
  __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initValidators).call(this);
32
+ __classPrivateFieldGet(this, _SpoListWebhookListCommand_instances, "m", _SpoListWebhookListCommand_initOptionSets).call(this);
31
33
  }
32
34
  get name() {
33
35
  return commands_1.default.LIST_WEBHOOK_LIST;
@@ -47,21 +49,24 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
47
49
  logger.logToStderr(chalk.yellow(`Option 'id' is deprecated. Please use 'listId' instead`));
48
50
  }
49
51
  if (this.verbose) {
50
- const list = args.options.id ? formatting_1.formatting.encodeQueryParameter(args.options.id) : (args.options.listId ? formatting_1.formatting.encodeQueryParameter(args.options.listId) : (args.options.title ? formatting_1.formatting.encodeQueryParameter(args.options.title) : formatting_1.formatting.encodeQueryParameter(args.options.listTitle)));
51
- logger.logToStderr(`Retrieving webhook information for list ${list} in site at ${args.options.webUrl}...`);
52
+ logger.logToStderr(`Retrieving webhook information for list ${args.options.id || args.options.listId || args.options.listUrl} in site at ${args.options.webUrl}...`);
52
53
  }
53
- let requestUrl = '';
54
+ let requestUrl = `${args.options.webUrl}/_api/web`;
54
55
  if (args.options.id) {
55
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.id)}')/Subscriptions`;
56
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.id)}')/Subscriptions`;
56
57
  }
57
58
  else if (args.options.listId) {
58
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
59
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions`;
59
60
  }
60
61
  else if (args.options.listTitle) {
61
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
62
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions`;
62
63
  }
63
- else {
64
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.title)}')/Subscriptions`;
64
+ else if (args.options.title) {
65
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.title)}')/Subscriptions`;
66
+ }
67
+ else if (args.options.listUrl) {
68
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
69
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions`;
65
70
  }
66
71
  const requestOptions = {
67
72
  url: requestUrl,
@@ -94,10 +99,11 @@ class SpoListWebhookListCommand extends SpoCommand_1.default {
94
99
  _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand_initTelemetry = function _SpoListWebhookListCommand_initTelemetry() {
95
100
  this.telemetry.push((args) => {
96
101
  Object.assign(this.telemetryProperties, {
97
- id: (!(!args.options.id)).toString(),
98
- listId: (!(!args.options.listId)).toString(),
99
- listTitle: (!(!args.options.listTitle)).toString(),
100
- title: (!(!args.options.title)).toString()
102
+ id: typeof args.options.id !== 'undefined',
103
+ listId: typeof args.options.listId !== 'undefined',
104
+ listTitle: typeof args.options.listTitle !== 'undefined',
105
+ listUrl: typeof args.options.listUrl !== 'undefined',
106
+ title: typeof args.options.title !== 'undefined'
101
107
  });
102
108
  });
103
109
  }, _SpoListWebhookListCommand_initOptions = function _SpoListWebhookListCommand_initOptions() {
@@ -107,6 +113,8 @@ _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand
107
113
  option: '-i, --listId [listId]'
108
114
  }, {
109
115
  option: '-t, --listTitle [listTitle]'
116
+ }, {
117
+ option: '--listUrl [listUrl]'
110
118
  }, {
111
119
  option: '--id [id]'
112
120
  }, {
@@ -128,19 +136,10 @@ _SpoListWebhookListCommand_instances = new WeakSet(), _SpoListWebhookListCommand
128
136
  return `${args.options.listId} is not a valid GUID`;
129
137
  }
130
138
  }
131
- if (args.options.id && args.options.title) {
132
- return 'Specify id or title, but not both';
133
- }
134
- if (args.options.listId && args.options.listTitle) {
135
- return 'Specify listId or listTitle, but not both';
136
- }
137
- if (!args.options.id && !args.options.title) {
138
- if (!args.options.listId && !args.options.listTitle) {
139
- return 'Specify listId or listTitle, one is required';
140
- }
141
- }
142
139
  return true;
143
140
  }));
141
+ }, _SpoListWebhookListCommand_initOptionSets = function _SpoListWebhookListCommand_initOptionSets() {
142
+ this.optionSets.push(['id', 'title', 'listId', 'listTitle', 'listUrl']);
144
143
  };
145
144
  module.exports = new SpoListWebhookListCommand();
146
145
  //# sourceMappingURL=list-webhook-list.js.map