@pnp/cli-microsoft365 5.9.0-beta.fd24b4e → 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 (152) hide show
  1. package/.eslintrc.js +15 -2
  2. package/README.md +5 -0
  3. package/dist/Command.js +16 -2
  4. package/dist/m365/aad/commands/app/app-add.js +37 -13
  5. package/dist/m365/commands/status.js +6 -1
  6. package/dist/m365/outlook/commands/mail/mail-send.js +55 -31
  7. package/dist/m365/planner/commands/bucket/bucket-get.js +1 -1
  8. package/dist/m365/pp/commands/Environment.js +3 -0
  9. package/dist/m365/pp/commands/card/card-get.js +110 -0
  10. package/dist/m365/pp/commands/card/card-list.js +68 -0
  11. package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +6 -12
  12. package/dist/m365/pp/commands/environment/environment-get.js +75 -0
  13. package/dist/m365/pp/commands/gateway/gateway-get.js +70 -0
  14. package/dist/m365/pp/commands/solution/solution-get.js +117 -0
  15. package/dist/m365/pp/commands.js +5 -0
  16. package/dist/m365/spfx/commands/project/project-doctor.js +4 -1
  17. package/dist/m365/spfx/commands/project/project-externalize.js +4 -1
  18. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010001_YORC_version.js +2 -1
  19. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010002_YORC_isCreatingSolution.js +2 -1
  20. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010003_YORC_packageManager.js +2 -1
  21. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010004_YORC_componentType.js +2 -1
  22. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010005_YORC_environment.js +2 -1
  23. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010006_YORC_framework.js +3 -2
  24. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010007_YORC_isDomainIsolated.js +2 -1
  25. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010008_YORC_nodeVersion.js +2 -1
  26. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010009_YORC_sdkVersions_microsoft_graph_client.js +56 -0
  27. package/dist/m365/spfx/commands/project/project-upgrade/rules/FN010010_YORC_sdkVersions_teams_js.js +56 -0
  28. package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.16.0-beta.1.js → upgrade-1.16.0-beta.2.js} +44 -28
  29. package/dist/m365/spfx/commands/project/project-upgrade.js +1 -1
  30. package/dist/m365/spfx/commands/spfx-doctor.js +3 -3
  31. package/dist/m365/spo/commands/contenttype/contenttype-add.js +82 -43
  32. package/dist/m365/spo/commands/contenttype/contenttype-field-remove.js +53 -21
  33. package/dist/m365/spo/commands/contenttype/contenttype-get.js +35 -14
  34. package/dist/m365/spo/commands/eventreceiver/EventReceiver.js +3 -0
  35. package/dist/m365/spo/commands/eventreceiver/eventreceiver-remove.js +182 -0
  36. package/dist/m365/spo/commands/field/field-add.js +26 -1
  37. package/dist/m365/spo/commands/field/field-set.js +23 -13
  38. package/dist/m365/spo/commands/file/file-roleinheritance-break.js +129 -0
  39. package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
  40. package/dist/m365/spo/commands/group/AssociatedGroupPropertiesCollection.js +3 -0
  41. package/dist/m365/spo/commands/group/group-list.js +49 -10
  42. package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
  43. package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
  44. package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
  45. package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
  46. package/dist/m365/spo/commands/list/list-roleassignment-add.js +10 -10
  47. package/dist/m365/spo/commands/list/list-roleassignment-remove.js +8 -8
  48. package/dist/m365/spo/commands/list/list-roleinheritance-break.js +14 -6
  49. package/dist/m365/spo/commands/list/list-roleinheritance-reset.js +15 -7
  50. package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
  51. package/dist/m365/spo/commands/list/list-webhook-get.js +17 -10
  52. package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
  53. package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
  54. package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
  55. package/dist/m365/spo/commands/listitem/listitem-add.js +24 -14
  56. package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +18 -8
  57. package/dist/m365/spo/commands/listitem/listitem-get.js +18 -8
  58. package/dist/m365/spo/commands/listitem/listitem-isrecord.js +20 -10
  59. package/dist/m365/spo/commands/listitem/listitem-list.js +27 -11
  60. package/dist/m365/spo/commands/listitem/listitem-record-declare.js +19 -12
  61. package/dist/m365/spo/commands/listitem/listitem-record-undeclare.js +24 -21
  62. package/dist/m365/spo/commands/listitem/listitem-remove.js +19 -11
  63. package/dist/m365/spo/commands/listitem/listitem-roleassignment-add.js +239 -0
  64. package/dist/m365/spo/commands/listitem/listitem-roleassignment-remove.js +8 -8
  65. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-break.js +13 -5
  66. package/dist/m365/spo/commands/listitem/listitem-roleinheritance-reset.js +14 -6
  67. package/dist/m365/spo/commands/listitem/listitem-set.js +52 -44
  68. package/dist/m365/spo/commands/web/web-roleassignment-add.js +10 -10
  69. package/dist/m365/spo/commands/web/web-roleassignment-remove.js +8 -8
  70. package/dist/m365/spo/commands/web/web-roleinheritance-break.js +100 -0
  71. package/dist/m365/spo/commands.js +5 -0
  72. package/dist/m365/teams/commands/channel/channel-add.js +9 -9
  73. package/dist/m365/todo/commands/list/list-get.js +89 -0
  74. package/dist/m365/todo/commands/task/task-add.js +55 -3
  75. package/dist/m365/todo/commands/task/task-get.js +108 -0
  76. package/dist/m365/todo/commands/task/task-set.js +53 -1
  77. package/dist/m365/todo/commands.js +2 -0
  78. package/docs/docs/_clisettings.md +19 -0
  79. package/docs/docs/cmd/outlook/mail/mail-send.md +13 -0
  80. package/docs/docs/cmd/planner/bucket/bucket-add.md +29 -0
  81. package/docs/docs/cmd/planner/bucket/bucket-get.md +29 -0
  82. package/docs/docs/cmd/planner/bucket/bucket-list.md +30 -0
  83. package/docs/docs/cmd/planner/bucket/bucket-remove.md +4 -0
  84. package/docs/docs/cmd/planner/bucket/bucket-set.md +4 -0
  85. package/docs/docs/cmd/planner/plan/plan-add.md +123 -0
  86. package/docs/docs/cmd/planner/plan/plan-get.md +75 -0
  87. package/docs/docs/cmd/planner/plan/plan-list.md +45 -0
  88. package/docs/docs/cmd/planner/plan/plan-remove.md +4 -0
  89. package/docs/docs/cmd/pp/card/card-get.md +51 -0
  90. package/docs/docs/cmd/pp/card/card-list.md +33 -0
  91. package/docs/docs/cmd/pp/dataverse/dataverse-table-list.md +2 -2
  92. package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
  93. package/docs/docs/cmd/pp/environment/environment-list.md +1 -1
  94. package/docs/docs/cmd/pp/gateway/gateway-get.md +24 -0
  95. package/docs/docs/cmd/pp/solution/solution-get.md +51 -0
  96. package/docs/docs/cmd/pp/solution/solution-list.md +2 -2
  97. package/docs/docs/cmd/spfx/project/project-rename.md +1 -14
  98. package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
  99. package/docs/docs/cmd/spo/contenttype/contenttype-add.md +20 -2
  100. package/docs/docs/cmd/spo/contenttype/contenttype-field-remove.md +22 -4
  101. package/docs/docs/cmd/spo/contenttype/contenttype-get.md +21 -3
  102. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
  103. package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +69 -0
  104. package/docs/docs/cmd/spo/field/field-add.md +20 -2
  105. package/docs/docs/cmd/spo/field/field-set.md +11 -2
  106. package/docs/docs/cmd/spo/file/file-roleinheritance-break.md +54 -0
  107. package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
  108. package/docs/docs/cmd/spo/group/group-list.md +10 -1
  109. package/docs/docs/cmd/spo/list/list-contenttype-add.md +16 -7
  110. package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
  111. package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
  112. package/docs/docs/cmd/spo/list/list-contenttype-remove.md +17 -8
  113. package/docs/docs/cmd/spo/list/list-roleinheritance-break.md +11 -8
  114. package/docs/docs/cmd/spo/list/list-roleinheritance-reset.md +14 -5
  115. package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
  116. package/docs/docs/cmd/spo/list/list-webhook-get.md +16 -7
  117. package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
  118. package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
  119. package/docs/docs/cmd/spo/list/list-webhook-set.md +14 -12
  120. package/docs/docs/cmd/spo/listitem/listitem-add.md +11 -2
  121. package/docs/docs/cmd/spo/listitem/listitem-attachment-list.md +11 -2
  122. package/docs/docs/cmd/spo/listitem/listitem-get.md +11 -2
  123. package/docs/docs/cmd/spo/listitem/listitem-isrecord.md +12 -2
  124. package/docs/docs/cmd/spo/listitem/listitem-list.md +12 -3
  125. package/docs/docs/cmd/spo/listitem/listitem-record-declare.md +7 -4
  126. package/docs/docs/cmd/spo/listitem/listitem-record-undeclare.md +11 -2
  127. package/docs/docs/cmd/spo/listitem/listitem-remove.md +11 -2
  128. package/docs/docs/cmd/spo/listitem/listitem-roleassignment-add.md +81 -0
  129. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-break.md +7 -4
  130. package/docs/docs/cmd/spo/listitem/listitem-roleinheritance-reset.md +11 -2
  131. package/docs/docs/cmd/spo/listitem/listitem-set.md +7 -4
  132. package/docs/docs/cmd/spo/web/web-roleinheritance-break.md +44 -0
  133. package/docs/docs/cmd/teams/channel/channel-add.md +4 -4
  134. package/docs/docs/cmd/tenant/id/id-get.md +20 -0
  135. package/docs/docs/cmd/tenant/report/report-activeusercounts.md +35 -0
  136. package/docs/docs/cmd/tenant/report/report-activeuserdetail.md +49 -0
  137. package/docs/docs/cmd/tenant/report/report-office365activationcounts.md +32 -0
  138. package/docs/docs/cmd/tenant/report/report-office365activationsusercounts.md +30 -0
  139. package/docs/docs/cmd/tenant/report/report-office365activationsuserdetail.md +36 -0
  140. package/docs/docs/cmd/tenant/report/report-servicesusercounts.md +41 -0
  141. package/docs/docs/cmd/tenant/security/security-alerts-list.md +105 -0
  142. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-get.md +87 -0
  143. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-list.md +91 -0
  144. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-get.md +62 -0
  145. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-list.md +51 -0
  146. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-get.md +64 -0
  147. package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-list.md +52 -0
  148. package/docs/docs/cmd/todo/list/list-get.md +61 -0
  149. package/docs/docs/cmd/todo/task/task-add.md +32 -5
  150. package/docs/docs/cmd/todo/task/task-get.md +75 -0
  151. package/docs/docs/cmd/todo/task/task-set.md +29 -2
  152. package/package.json +12 -3
@@ -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
@@ -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");
@@ -40,15 +41,19 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
40
41
  return __awaiter(this, void 0, void 0, function* () {
41
42
  const removeWebhook = () => __awaiter(this, void 0, void 0, function* () {
42
43
  if (this.verbose) {
43
- const list = (args.options.listId ? args.options.listId : args.options.listTitle);
44
+ const list = (args.options.listId || args.options.listId || args.options.listUrl);
44
45
  logger.logToStderr(`Webhook ${args.options.id} is about to be removed from list ${list} located at site ${args.options.webUrl}...`);
45
46
  }
46
- let requestUrl = '';
47
+ let requestUrl = `${args.options.webUrl}/_api/web`;
47
48
  if (args.options.listId) {
48
- requestUrl = `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
49
50
  }
50
- else {
51
- requestUrl = `${args.options.webUrl}/_api/web/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
51
+ else if (args.options.listTitle) {
52
+ requestUrl += `/lists/GetByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
53
+ }
54
+ else if (args.options.listUrl) {
55
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
56
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')/Subscriptions('${formatting_1.formatting.encodeQueryParameter(args.options.id)}')`;
52
57
  }
53
58
  const requestOptions = {
54
59
  url: requestUrl,
@@ -74,7 +79,7 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
74
79
  type: 'confirm',
75
80
  name: 'continue',
76
81
  default: false,
77
- message: `Are you sure you want to remove webhook ${args.options.id} from list ${args.options.listTitle || args.options.listId} located at site ${args.options.webUrl}?`
82
+ message: `Are you sure you want to remove webhook ${args.options.id} from list ${args.options.listTitle || args.options.listId || args.options.listUrl} located at site ${args.options.webUrl}?`
78
83
  });
79
84
  if (result.continue) {
80
85
  yield removeWebhook();
@@ -86,10 +91,11 @@ class SpoListWebhookRemoveCommand extends SpoCommand_1.default {
86
91
  _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCommand_initTelemetry = function _SpoListWebhookRemoveCommand_initTelemetry() {
87
92
  this.telemetry.push((args) => {
88
93
  Object.assign(this.telemetryProperties, {
89
- listId: (!(!args.options.listId)).toString(),
90
- listTitle: (!(!args.options.listTitle)).toString(),
91
- id: (!(!args.options.id)).toString(),
92
- confirm: (!(!args.options.confirm)).toString()
94
+ listId: typeof args.options.listId !== 'undefined',
95
+ listTitle: typeof args.options.listTitle !== 'undefined',
96
+ listUrl: typeof args.options.listUrl !== 'undefined',
97
+ id: typeof args.options.id !== 'undefined',
98
+ confirm: !!args.options.confirm
93
99
  });
94
100
  });
95
101
  }, _SpoListWebhookRemoveCommand_initOptions = function _SpoListWebhookRemoveCommand_initOptions() {
@@ -99,6 +105,8 @@ _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCom
99
105
  option: '-l, --listId [listId]'
100
106
  }, {
101
107
  option: '-t, --listTitle [listTitle]'
108
+ }, {
109
+ option: '--listUrl [listUrl]'
102
110
  }, {
103
111
  option: '-i, --id <id>'
104
112
  }, {
@@ -121,7 +129,7 @@ _SpoListWebhookRemoveCommand_instances = new WeakSet(), _SpoListWebhookRemoveCom
121
129
  return true;
122
130
  }));
123
131
  }, _SpoListWebhookRemoveCommand_initOptionSets = function _SpoListWebhookRemoveCommand_initOptionSets() {
124
- this.optionSets.push(['listId', 'listTitle']);
132
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
125
133
  };
126
134
  module.exports = new SpoListWebhookRemoveCommand();
127
135
  //# sourceMappingURL=list-webhook-remove.js.map
@@ -18,6 +18,7 @@ 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");
@@ -39,14 +40,18 @@ class SpoListWebhookSetCommand extends SpoCommand_1.default {
39
40
  commandAction(logger, args) {
40
41
  return __awaiter(this, void 0, void 0, function* () {
41
42
  if (this.verbose) {
42
- logger.logToStderr(`Updating webhook ${args.options.id} belonging to list ${args.options.listId ? args.options.listId : args.options.listTitle} located at site ${args.options.webUrl}...`);
43
+ logger.logToStderr(`Updating webhook ${args.options.id} belonging to list ${args.options.listId || args.options.listTitle || args.options.listUrl} located at site ${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 requestBody = {};
52
57
  if (args.options.notificationUrl) {
@@ -77,10 +82,11 @@ class SpoListWebhookSetCommand extends SpoCommand_1.default {
77
82
  _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_initTelemetry = function _SpoListWebhookSetCommand_initTelemetry() {
78
83
  this.telemetry.push((args) => {
79
84
  Object.assign(this.telemetryProperties, {
80
- listId: (!(!args.options.listId)).toString(),
81
- listTitle: (!(!args.options.listTitle)).toString(),
82
- notificationUrl: (!(!args.options.notificationUrl)).toString(),
83
- expirationDateTime: (!(!args.options.expirationDateTime)).toString()
85
+ listId: typeof args.options.listId !== 'undefined',
86
+ listTitle: typeof args.options.listTitle !== 'undefined',
87
+ listUrl: typeof args.options.listUrl !== 'undefined',
88
+ notificationUrl: typeof args.options.notificationUrl !== 'undefined',
89
+ expirationDateTime: typeof args.options.expirationDateTime !== 'undefined'
84
90
  });
85
91
  });
86
92
  }, _SpoListWebhookSetCommand_initOptions = function _SpoListWebhookSetCommand_initOptions() {
@@ -90,6 +96,8 @@ _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_i
90
96
  option: '-l, --listId [listId]'
91
97
  }, {
92
98
  option: '-t, --listTitle [listTitle]'
99
+ }, {
100
+ option: '--listUrl [listUrl]'
93
101
  }, {
94
102
  option: '-i, --id <id>'
95
103
  }, {
@@ -125,7 +133,7 @@ _SpoListWebhookSetCommand_instances = new WeakSet(), _SpoListWebhookSetCommand_i
125
133
  return true;
126
134
  }));
127
135
  }, _SpoListWebhookSetCommand_initOptionSets = function _SpoListWebhookSetCommand_initOptionSets() {
128
- this.optionSets.push(['listId', 'listTitle']);
136
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
129
137
  };
130
138
  module.exports = new SpoListWebhookSetCommand();
131
139
  //# sourceMappingURL=list-webhook-set.js.map
@@ -44,18 +44,24 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
44
44
  commandAction(logger, args) {
45
45
  return __awaiter(this, void 0, void 0, function* () {
46
46
  try {
47
- const listIdArgument = args.options.listId || '';
48
- const listTitleArgument = args.options.listTitle || '';
49
- const listRestUrl = (args.options.listId ?
50
- `${args.options.webUrl}/_api/web/lists(guid'${formatting_1.formatting.encodeQueryParameter(listIdArgument)}')`
51
- : `${args.options.webUrl}/_api/web/lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(listTitleArgument)}')`);
47
+ let requestUrl = `${args.options.webUrl}/_api/web`;
48
+ if (args.options.listId) {
49
+ requestUrl += `/lists(guid'${formatting_1.formatting.encodeQueryParameter(args.options.listId)}')`;
50
+ }
51
+ else if (args.options.listTitle) {
52
+ requestUrl += `/lists/getByTitle('${formatting_1.formatting.encodeQueryParameter(args.options.listTitle)}')`;
53
+ }
54
+ else if (args.options.listUrl) {
55
+ const listServerRelativeUrl = urlUtil_1.urlUtil.getServerRelativePath(args.options.webUrl, args.options.listUrl);
56
+ requestUrl += `/GetList('${formatting_1.formatting.encodeQueryParameter(listServerRelativeUrl)}')`;
57
+ }
52
58
  let contentTypeName = '';
53
59
  let targetFolderServerRelativeUrl = '';
54
60
  if (this.verbose) {
55
- logger.logToStderr(`Getting content types for list...`);
61
+ logger.logToStderr(`Getting content types for list ${args.options.listId || args.options.listTitle || args.options.listUrl}...`);
56
62
  }
57
63
  let requestOptions = {
58
- url: `${listRestUrl}/contenttypes?$select=Name,Id`,
64
+ url: `${requestUrl}/contenttypes?$select=Name,Id`,
59
65
  headers: {
60
66
  'accept': 'application/json;odata=nometadata'
61
67
  },
@@ -90,7 +96,7 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
90
96
  logger.logToStderr('setting up folder lookup response ...');
91
97
  }
92
98
  requestOptions = {
93
- url: `${listRestUrl}/rootFolder`,
99
+ url: `${requestUrl}/rootFolder`,
94
100
  headers: {
95
101
  'accept': 'application/json;odata=nometadata'
96
102
  },
@@ -101,7 +107,7 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
101
107
  yield spo_1.spo.ensureFolder(args.options.webUrl, targetFolderServerRelativeUrl, logger, this.debug);
102
108
  }
103
109
  if (this.verbose) {
104
- logger.logToStderr(`Creating item in list ${args.options.listId || args.options.listTitle} in site ${args.options.webUrl}...`);
110
+ logger.logToStderr(`Creating item in list ${args.options.listId || args.options.listTitle || args.options.listUrl} in site ${args.options.webUrl}...`);
105
111
  }
106
112
  const requestBody = {
107
113
  formValues: this.mapRequestBody(args.options)
@@ -123,7 +129,7 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
123
129
  });
124
130
  }
125
131
  requestOptions = {
126
- url: `${listRestUrl}/AddValidateUpdateItemUsingPath()`,
132
+ url: `${requestUrl}/AddValidateUpdateItemUsingPath()`,
127
133
  headers: {
128
134
  'accept': 'application/json;odata=nometadata'
129
135
  },
@@ -142,10 +148,10 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
142
148
  logger.logToStderr(`Id returned by AddValidateUpdateItemUsingPath: ${idField}`);
143
149
  }
144
150
  if (idField.length === 0) {
145
- return Promise.reject(`Item didn't add successfully`);
151
+ throw `Item didn't add successfully`;
146
152
  }
147
153
  requestOptions = {
148
- url: `${listRestUrl}/items(${idField[0].FieldValue})`,
154
+ url: `${requestUrl}/items(${idField[0].FieldValue})`,
149
155
  headers: {
150
156
  'accept': 'application/json;odata=nometadata'
151
157
  },
@@ -164,6 +170,7 @@ class SpoListItemAddCommand extends SpoCommand_1.default {
164
170
  const excludeOptions = [
165
171
  'listTitle',
166
172
  'listId',
173
+ 'listUrl',
167
174
  'webUrl',
168
175
  'contentType',
169
176
  'folder',
@@ -184,6 +191,7 @@ _SpoListItemAddCommand_instances = new WeakSet(), _SpoListItemAddCommand_initTel
184
191
  Object.assign(this.telemetryProperties, {
185
192
  listId: typeof args.options.listId !== 'undefined',
186
193
  listTitle: typeof args.options.listTitle !== 'undefined',
194
+ listUrl: typeof args.options.listUrl !== 'undefined',
187
195
  contentType: typeof args.options.contentType !== 'undefined',
188
196
  folder: typeof args.options.folder !== 'undefined'
189
197
  });
@@ -195,6 +203,8 @@ _SpoListItemAddCommand_instances = new WeakSet(), _SpoListItemAddCommand_initTel
195
203
  option: '-l, --listId [listId]'
196
204
  }, {
197
205
  option: '-t, --listTitle [listTitle]'
206
+ }, {
207
+ option: '--listUrl [listUrl]'
198
208
  }, {
199
209
  option: '-c, --contentType [contentType]'
200
210
  }, {
@@ -213,9 +223,9 @@ _SpoListItemAddCommand_instances = new WeakSet(), _SpoListItemAddCommand_initTel
213
223
  return true;
214
224
  }));
215
225
  }, _SpoListItemAddCommand_initTypes = function _SpoListItemAddCommand_initTypes() {
216
- this.types.string.push('webUrl', 'listId', 'listTitle', 'contentType', 'folder');
226
+ this.types.string.push('webUrl', 'listId', 'listTitle', 'listUrl', 'contentType', 'folder');
217
227
  }, _SpoListItemAddCommand_initOptionSets = function _SpoListItemAddCommand_initOptionSets() {
218
- this.optionSets.push(['listId', 'listTitle']);
228
+ this.optionSets.push(['listId', 'listTitle', 'listUrl']);
219
229
  };
220
230
  module.exports = new SpoListItemAddCommand();
221
231
  //# sourceMappingURL=listitem-add.js.map