@pnp/cli-microsoft365 7.0.0-beta.093ef31 → 7.0.0-beta.18ce559
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/dist/Auth.js +10 -1
- package/dist/Command.js +2 -2
- package/dist/cli/Cli.js +4 -4
- package/dist/m365/aad/commands/app/app-get.js +4 -1
- package/dist/m365/aad/commands/app/app-remove.js +3 -1
- package/dist/m365/aad/commands/app/app-role-add.js +4 -1
- package/dist/m365/aad/commands/app/app-role-list.js +4 -1
- package/dist/m365/aad/commands/app/app-role-remove.js +5 -2
- package/dist/m365/aad/commands/app/app-set.js +8 -5
- package/dist/m365/aad/commands/approleassignment/approleassignment-add.js +11 -6
- package/dist/m365/aad/commands/approleassignment/approleassignment-remove.js +4 -4
- package/dist/m365/aad/commands/group/group-get.js +4 -4
- package/dist/m365/aad/commands/group/group-list.js +1 -23
- package/dist/m365/aad/commands/group/group-remove.js +98 -0
- package/dist/m365/aad/commands/m365group/m365group-add.js +21 -12
- package/dist/m365/aad/commands/m365group/m365group-conversation-list.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-conversation-post-list.js +4 -0
- package/dist/m365/aad/commands/m365group/m365group-get.js +4 -3
- package/dist/m365/aad/commands/m365group/m365group-recyclebinitem-remove.js +3 -1
- package/dist/m365/aad/commands/m365group/m365group-recyclebinitem-restore.js +4 -1
- package/dist/m365/aad/commands/m365group/m365group-remove.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-renew.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-set.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-teamify.js +14 -6
- package/dist/m365/aad/commands/m365group/m365group-user-add.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-user-list.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-user-remove.js +5 -0
- package/dist/m365/aad/commands/m365group/m365group-user-set.js +5 -0
- package/dist/m365/aad/commands/sp/sp-add.js +4 -1
- package/dist/m365/aad/commands/sp/sp-get.js +4 -1
- package/dist/m365/aad/commands/user/user-get.js +7 -2
- package/dist/m365/aad/commands.js +1 -0
- package/dist/m365/booking/commands/business/business-get.js +4 -1
- package/dist/m365/commands/login.js +2 -2
- package/dist/m365/flow/commands/flow-export.js +13 -13
- package/dist/m365/graph/commands/subscription/subscription-add.js +5 -5
- package/dist/m365/outlook/commands/message/message-list.js +4 -2
- package/dist/m365/outlook/commands/message/message-move.js +4 -2
- package/dist/m365/pa/commands/app/app-export.js +7 -7
- package/dist/m365/pa/commands/connector/connector-export.js +5 -5
- package/dist/m365/planner/commands/bucket/bucket-add.js +4 -1
- package/dist/m365/planner/commands/bucket/bucket-get.js +9 -2
- package/dist/m365/planner/commands/bucket/bucket-list.js +4 -1
- package/dist/m365/planner/commands/bucket/bucket-remove.js +7 -2
- package/dist/m365/planner/commands/bucket/bucket-set.js +8 -2
- package/dist/m365/planner/commands/plan/plan-add.js +4 -1
- package/dist/m365/planner/commands/plan/plan-get.js +4 -1
- package/dist/m365/planner/commands/plan/plan-list.js +4 -1
- package/dist/m365/planner/commands/plan/plan-remove.js +4 -1
- package/dist/m365/planner/commands/plan/plan-set.js +4 -1
- package/dist/m365/planner/commands/roster/roster-get.js +4 -1
- package/dist/m365/planner/commands/roster/roster-member-add.js +4 -1
- package/dist/m365/planner/commands/roster/roster-member-get.js +4 -1
- package/dist/m365/planner/commands/roster/roster-member-list.js +4 -1
- package/dist/m365/planner/commands/roster/roster-member-remove.js +4 -1
- package/dist/m365/planner/commands/roster/roster-plan-list.js +4 -1
- package/dist/m365/planner/commands/roster/roster-remove.js +4 -1
- package/dist/m365/planner/commands/task/task-add.js +4 -1
- package/dist/m365/planner/commands/task/task-checklistitem-add.js +4 -1
- package/dist/m365/planner/commands/task/task-checklistitem-list.js +4 -1
- package/dist/m365/planner/commands/task/task-checklistitem-remove.js +4 -1
- package/dist/m365/planner/commands/task/task-get.js +11 -3
- package/dist/m365/planner/commands/task/task-list.js +10 -2
- package/dist/m365/planner/commands/task/task-reference-add.js +4 -1
- package/dist/m365/planner/commands/task/task-reference-list.js +4 -1
- package/dist/m365/planner/commands/task/task-reference-remove.js +4 -1
- package/dist/m365/planner/commands/task/task-remove.js +10 -4
- package/dist/m365/planner/commands/task/task-set.js +4 -1
- package/dist/m365/pp/commands/aibuildermodel/aibuildermodel-get.js +4 -1
- package/dist/m365/pp/commands/card/card-get.js +3 -5
- package/dist/m365/pp/commands/chatbot/chatbot-get.js +3 -1
- package/dist/m365/pp/commands/chatbot/chatbot-list.js +2 -2
- package/dist/m365/pp/commands/managementapp/managementapp-add.js +4 -1
- package/dist/m365/search/commands/externalconnection/externalconnection-remove.js +3 -1
- package/dist/m365/spfx/commands/project/project-doctor/{doctor-1.18.0-beta.5.js → doctor-1.18.0.js} +2 -2
- package/dist/m365/spfx/commands/project/project-doctor.js +1 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN001022_DEP_office_ui_fabric_react.js +1 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN002028_DEVDEP_microsoft_rush_stack_compiler_4_7.js +13 -0
- package/dist/m365/spfx/commands/project/project-upgrade/{upgrade-1.18.0-beta.5.js → upgrade-1.18.0.js} +35 -27
- package/dist/m365/spfx/commands/project/project-upgrade.js +13 -15
- package/dist/m365/spfx/commands/spfx-doctor.js +3 -3
- package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-get.js +5 -3
- package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-remove.js +2 -2
- package/dist/m365/spo/commands/applicationcustomizer/applicationcustomizer-set.js +3 -2
- package/dist/m365/spo/commands/commandset/commandset-get.js +4 -2
- package/dist/m365/spo/commands/commandset/commandset-remove.js +2 -1
- package/dist/m365/spo/commands/commandset/commandset-set.js +3 -1
- package/dist/m365/spo/commands/customaction/customaction-get.js +5 -2
- package/dist/m365/spo/commands/customaction/customaction-remove.js +3 -1
- package/dist/m365/spo/commands/eventreceiver/eventreceiver-get.js +3 -1
- package/dist/m365/spo/commands/file/file-get.js +11 -8
- package/dist/m365/spo/commands/file/file-remove.js +2 -2
- package/dist/m365/spo/commands/file/file-version-clear.js +2 -2
- package/dist/m365/spo/commands/file/file-version-get.js +2 -2
- package/dist/m365/spo/commands/file/file-version-list.js +2 -2
- package/dist/m365/spo/commands/file/file-version-remove.js +2 -2
- package/dist/m365/spo/commands/file/file-version-restore.js +2 -2
- package/dist/m365/spo/commands/group/group-member-add.js +24 -24
- package/dist/m365/spo/commands/hubsite/hubsite-connect.js +7 -4
- package/dist/m365/spo/commands/hubsite/hubsite-disconnect.js +4 -1
- package/dist/m365/spo/commands/hubsite/hubsite-get.js +3 -1
- package/dist/m365/spo/commands/listitem/listitem-add.js +1 -0
- package/dist/m365/spo/commands/listitem/listitem-attachment-add.js +127 -0
- package/dist/m365/spo/commands/listitem/listitem-attachment-get.js +97 -0
- package/dist/m365/spo/commands/listitem/listitem-attachment-remove.js +121 -0
- package/dist/m365/spo/commands/listitem/listitem-attachment-set.js +115 -0
- package/dist/m365/spo/commands/listitem/listitem-set.js +3 -2
- package/dist/m365/spo/commands/page/clientsidepages.js +18 -0
- package/dist/m365/spo/commands/page/page-get.js +1 -0
- package/dist/m365/spo/commands/page/page-list.js +4 -3
- package/dist/m365/spo/commands/page/page-section-add.js +56 -21
- package/dist/m365/spo/commands/page/page-set.js +13 -2
- package/dist/m365/spo/commands/site/site-commsite-enable.js +34 -5
- package/dist/m365/spo/commands/site/site-list.js +5 -7
- package/dist/m365/spo/commands/tenant/tenant-appcatalog-add.js +1 -1
- package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-get.js +8 -3
- package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-list.js +3 -2
- package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-remove.js +2 -1
- package/dist/m365/spo/commands/tenant/tenant-applicationcustomizer-set.js +3 -2
- package/dist/m365/spo/commands/tenant/tenant-commandset-get.js +8 -3
- package/dist/m365/spo/commands/tenant/tenant-commandset-list.js +3 -2
- package/dist/m365/spo/commands/tenant/tenant-commandset-remove.js +3 -1
- package/dist/m365/spo/commands/term/term-get.js +6 -6
- package/dist/m365/spo/commands/user/user-get.js +10 -10
- package/dist/m365/spo/commands.js +4 -0
- package/dist/m365/teams/commands/app/app-remove.js +49 -15
- package/dist/m365/teams/commands/channel/channel-add.js +5 -1
- package/dist/m365/teams/commands/channel/channel-member-add.js +12 -10
- package/dist/m365/teams/commands/channel/channel-member-remove.js +3 -1
- package/dist/m365/teams/commands/channel/channel-member-set.js +4 -1
- package/dist/m365/teams/commands/chat/chat-get.js +7 -10
- package/dist/m365/teams/commands/chat/chat-message-send.js +8 -10
- package/dist/m365/teams/commands/team/team-clone.js +5 -10
- package/dist/m365/teams/commands/team/team-list.js +94 -30
- package/dist/m365/tenant/commands/info/info-get.js +83 -0
- package/dist/m365/tenant/commands.js +1 -0
- package/dist/utils/aadGroup.js +21 -3
- package/dist/utils/formatting.js +7 -0
- package/dist/utils/powerPlatform.js +1 -1
- package/docs/docs/_clisettings.mdx +1 -1
- package/docs/docs/cmd/aad/app/app-set.mdx +15 -15
- package/docs/docs/cmd/aad/approleassignment/approleassignment-add.mdx +9 -9
- package/docs/docs/cmd/aad/approleassignment/approleassignment-remove.mdx +10 -10
- package/docs/docs/cmd/aad/group/group-get.mdx +5 -5
- package/docs/docs/cmd/aad/group/group-list.mdx +0 -11
- package/docs/docs/cmd/aad/group/group-remove.mdx +44 -0
- package/docs/docs/cmd/aad/m365group/m365group-add.mdx +13 -3
- package/docs/docs/cmd/aad/policy/policy-list.mdx +5 -5
- package/docs/docs/cmd/cli/config/config-list.mdx +1 -1
- package/docs/docs/cmd/flow/flow-export.mdx +11 -11
- package/docs/docs/cmd/graph/subscription/subscription-add.mdx +10 -10
- package/docs/docs/cmd/pa/app/app-export.mdx +5 -5
- package/docs/docs/cmd/pa/connector/connector-export.mdx +3 -3
- package/docs/docs/cmd/pp/chatbot/chatbot-list.mdx +4 -4
- package/docs/docs/cmd/pp/solution/solution-publisher-get.mdx +2 -2
- package/docs/docs/cmd/pp/solution/solution-publisher-remove.mdx +2 -2
- package/docs/docs/cmd/spfx/project/project-upgrade.mdx +1 -1
- package/docs/docs/cmd/spo/file/file-get.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-remove.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-version-clear.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-version-get.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-version-list.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-version-remove.mdx +2 -2
- package/docs/docs/cmd/spo/file/file-version-restore.mdx +2 -2
- package/docs/docs/cmd/spo/group/group-member-add.mdx +27 -27
- package/docs/docs/cmd/spo/list/list-contenttype-remove.mdx +1 -1
- package/docs/docs/cmd/spo/listitem/listitem-add.mdx +2 -5
- package/docs/docs/cmd/spo/listitem/listitem-attachment-add.mdx +110 -0
- package/docs/docs/cmd/spo/listitem/listitem-attachment-get.mdx +104 -0
- package/docs/docs/cmd/spo/listitem/listitem-attachment-remove.mdx +58 -0
- package/docs/docs/cmd/spo/listitem/listitem-attachment-set.mdx +58 -0
- package/docs/docs/cmd/spo/listitem/listitem-set.mdx +2 -5
- package/docs/docs/cmd/spo/page/page-get.mdx +0 -1
- package/docs/docs/cmd/spo/page/page-list.mdx +0 -1
- package/docs/docs/cmd/spo/page/page-section-add.mdx +25 -1
- package/docs/docs/cmd/spo/page/page-set.mdx +23 -0
- package/docs/docs/cmd/spo/site/site-commsite-enable.mdx +11 -2
- package/docs/docs/cmd/spo/tenant/tenant-applicationcustomizer-list.mdx +2 -4
- package/docs/docs/cmd/spo/tenant/tenant-commandset-list.mdx +2 -4
- package/docs/docs/cmd/spo/user/user-get.mdx +8 -8
- package/docs/docs/cmd/teams/app/app-remove.mdx +9 -6
- package/docs/docs/cmd/teams/channel/channel-member-add.mdx +4 -4
- package/docs/docs/cmd/teams/team/team-clone.mdx +3 -3
- package/docs/docs/cmd/teams/team/team-list.mdx +47 -22
- package/docs/docs/cmd/tenant/info/info-get.mdx +101 -0
- package/npm-shrinkwrap.json +24 -24
- package/package.json +8 -12
|
@@ -3,7 +3,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
3
3
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
|
-
var _SpoSiteCommSiteEnableCommand_instances, _SpoSiteCommSiteEnableCommand_initTelemetry, _SpoSiteCommSiteEnableCommand_initOptions, _SpoSiteCommSiteEnableCommand_initValidators;
|
|
6
|
+
var _SpoSiteCommSiteEnableCommand_instances, _SpoSiteCommSiteEnableCommand_initTelemetry, _SpoSiteCommSiteEnableCommand_initOptions, _SpoSiteCommSiteEnableCommand_initOptionSets, _SpoSiteCommSiteEnableCommand_initValidators;
|
|
7
7
|
import request from '../../../../request.js';
|
|
8
8
|
import { validation } from '../../../../utils/validation.js';
|
|
9
9
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
@@ -21,11 +21,12 @@ class SpoSiteCommSiteEnableCommand extends SpoCommand {
|
|
|
21
21
|
__classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initTelemetry).call(this);
|
|
22
22
|
__classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initOptions).call(this);
|
|
23
23
|
__classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initValidators).call(this);
|
|
24
|
+
__classPrivateFieldGet(this, _SpoSiteCommSiteEnableCommand_instances, "m", _SpoSiteCommSiteEnableCommand_initOptionSets).call(this);
|
|
24
25
|
}
|
|
25
26
|
async commandAction(logger, args) {
|
|
26
|
-
const designPackageId = args.options
|
|
27
|
+
const designPackageId = this.getDesignPackageId(args.options);
|
|
27
28
|
if (this.verbose) {
|
|
28
|
-
logger.logToStderr(`Enabling communication site at ${args.options.url}...`);
|
|
29
|
+
logger.logToStderr(`Enabling communication site with design package '${designPackageId}' at '${args.options.url}'...`);
|
|
29
30
|
}
|
|
30
31
|
try {
|
|
31
32
|
const requestOptions = {
|
|
@@ -42,11 +43,26 @@ class SpoSiteCommSiteEnableCommand extends SpoCommand {
|
|
|
42
43
|
this.handleRejectedODataJsonPromise(err);
|
|
43
44
|
}
|
|
44
45
|
}
|
|
46
|
+
getDesignPackageId(options) {
|
|
47
|
+
if (options.designPackageId) {
|
|
48
|
+
return options.designPackageId;
|
|
49
|
+
}
|
|
50
|
+
switch (options.designPackage) {
|
|
51
|
+
case 'Blank':
|
|
52
|
+
return 'f6cc5403-0d63-442e-96c0-285923709ffc';
|
|
53
|
+
case 'Showcase':
|
|
54
|
+
return '6142d2a0-63a5-4ba0-aede-d9fefca2c767';
|
|
55
|
+
case 'Topic':
|
|
56
|
+
default:
|
|
57
|
+
return '96c933ac-3698-44c7-9f4a-5fd17d71af9e';
|
|
58
|
+
}
|
|
59
|
+
}
|
|
45
60
|
}
|
|
46
61
|
_SpoSiteCommSiteEnableCommand_instances = new WeakSet(), _SpoSiteCommSiteEnableCommand_initTelemetry = function _SpoSiteCommSiteEnableCommand_initTelemetry() {
|
|
47
62
|
this.telemetry.push((args) => {
|
|
48
63
|
Object.assign(this.telemetryProperties, {
|
|
49
|
-
designPackageId: typeof args.options.designPackageId !== 'undefined'
|
|
64
|
+
designPackageId: typeof args.options.designPackageId !== 'undefined',
|
|
65
|
+
designPackage: typeof args.options.designPackage !== 'undefined'
|
|
50
66
|
});
|
|
51
67
|
});
|
|
52
68
|
}, _SpoSiteCommSiteEnableCommand_initOptions = function _SpoSiteCommSiteEnableCommand_initOptions() {
|
|
@@ -54,12 +70,25 @@ _SpoSiteCommSiteEnableCommand_instances = new WeakSet(), _SpoSiteCommSiteEnableC
|
|
|
54
70
|
option: '-u, --url <url>'
|
|
55
71
|
}, {
|
|
56
72
|
option: '-i, --designPackageId [designPackageId]'
|
|
73
|
+
}, {
|
|
74
|
+
option: '-p, --designPackage [designPackage]',
|
|
75
|
+
autocomplete: ["Topic", "Showcase", "Blank"]
|
|
76
|
+
});
|
|
77
|
+
}, _SpoSiteCommSiteEnableCommand_initOptionSets = function _SpoSiteCommSiteEnableCommand_initOptionSets() {
|
|
78
|
+
this.optionSets.push({
|
|
79
|
+
options: ['designPackageId', 'designPackage'],
|
|
80
|
+
runsWhen: (args) => args.options.designPackageId || args.options.designPackage
|
|
57
81
|
});
|
|
58
82
|
}, _SpoSiteCommSiteEnableCommand_initValidators = function _SpoSiteCommSiteEnableCommand_initValidators() {
|
|
59
83
|
this.validators.push(async (args) => {
|
|
60
84
|
if (args.options.designPackageId &&
|
|
61
85
|
!validation.isValidGuid(args.options.designPackageId)) {
|
|
62
|
-
return `${args.options.designPackageId} is not a valid GUID
|
|
86
|
+
return `${args.options.designPackageId} is not a valid GUID.`;
|
|
87
|
+
}
|
|
88
|
+
if (args.options.designPackage) {
|
|
89
|
+
if (['Topic', 'Showcase', 'Blank'].indexOf(args.options.designPackage) === -1) {
|
|
90
|
+
return `${args.options.designPackage} is not a valid designPackage. Allowed values are Topic|Showcase|Blank`;
|
|
91
|
+
}
|
|
63
92
|
}
|
|
64
93
|
return validation.isValidSharePointUrl(args.options.url);
|
|
65
94
|
});
|
|
@@ -54,16 +54,14 @@ class SpoSiteListCommand extends SpoCommand {
|
|
|
54
54
|
},
|
|
55
55
|
data: requestBody
|
|
56
56
|
};
|
|
57
|
-
const
|
|
58
|
-
const json = JSON.parse(
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
throw response.ErrorInfo.ErrorMessage;
|
|
57
|
+
const response = await request.post(requestOptions);
|
|
58
|
+
const json = JSON.parse(response);
|
|
59
|
+
const responseContent = json[0];
|
|
60
|
+
if (responseContent.ErrorInfo) {
|
|
61
|
+
throw responseContent.ErrorInfo.ErrorMessage;
|
|
63
62
|
}
|
|
64
63
|
else {
|
|
65
64
|
const sites = json[json.length - 1];
|
|
66
|
-
logger.log(sites);
|
|
67
65
|
this.allSites.push(...sites._Child_Items_);
|
|
68
66
|
if (sites.NextStartIndexFromSharePoint) {
|
|
69
67
|
await this.getAllSites(spoAdminUrl, filter, sites.NextStartIndexFromSharePoint, personalSite, webTemplate, formDigest, logger);
|
|
@@ -11,6 +11,7 @@ import { urlUtil } from '../../../../utils/urlUtil.js';
|
|
|
11
11
|
import { validation } from '../../../../utils/validation.js';
|
|
12
12
|
import SpoCommand from '../../../base/SpoCommand.js';
|
|
13
13
|
import commands from '../../commands.js';
|
|
14
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
14
15
|
class SpoTenantApplicationCustomizerGetCommand extends SpoCommand {
|
|
15
16
|
get name() {
|
|
16
17
|
return commands.TENANT_APPLICATIONCUSTOMIZER_GET;
|
|
@@ -48,11 +49,15 @@ class SpoTenantApplicationCustomizerGetCommand extends SpoCommand {
|
|
|
48
49
|
if (listItemInstances.length === 0) {
|
|
49
50
|
throw 'The specified application customizer was not found';
|
|
50
51
|
}
|
|
52
|
+
listItemInstances.forEach(v => delete v['ID']);
|
|
51
53
|
if (listItemInstances.length > 1) {
|
|
52
|
-
|
|
54
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
|
|
55
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
|
|
56
|
+
await logger.log(result);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
await logger.log(listItemInstances[0]);
|
|
53
60
|
}
|
|
54
|
-
listItemInstances.forEach(v => delete v['ID']);
|
|
55
|
-
await logger.log(listItemInstances[0]);
|
|
56
61
|
}
|
|
57
62
|
else {
|
|
58
63
|
throw 'The specified application customizer was not found';
|
|
@@ -22,8 +22,9 @@ class SpoTenantApplicationCustomizerListCommand extends SpoCommand {
|
|
|
22
22
|
}
|
|
23
23
|
const listServerRelativeUrl = urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
|
|
24
24
|
try {
|
|
25
|
-
const
|
|
26
|
-
|
|
25
|
+
const listItems = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=TenantWideExtensionLocation eq 'ClientSideExtension.ApplicationCustomizer'`);
|
|
26
|
+
listItems.forEach(i => delete i.ID);
|
|
27
|
+
await logger.log(listItems);
|
|
27
28
|
}
|
|
28
29
|
catch (err) {
|
|
29
30
|
this.handleRejectedODataJsonPromise(err);
|
|
@@ -66,7 +66,8 @@ class SpoTenantApplicationCustomizerRemoveCommand extends SpoCommand {
|
|
|
66
66
|
throw 'The specified application customizer was not found';
|
|
67
67
|
}
|
|
68
68
|
if (listItemInstances.length > 1) {
|
|
69
|
-
|
|
69
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
|
|
70
|
+
listItemInstances[0] = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
|
|
70
71
|
}
|
|
71
72
|
return listItemInstances[0].Id;
|
|
72
73
|
}
|
|
@@ -4,7 +4,6 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
6
|
var _SpoTenantApplicationCustomizerSetCommand_instances, _SpoTenantApplicationCustomizerSetCommand_initTelemetry, _SpoTenantApplicationCustomizerSetCommand_initOptions, _SpoTenantApplicationCustomizerSetCommand_initValidators, _SpoTenantApplicationCustomizerSetCommand_initOptionSets;
|
|
7
|
-
import os from 'os';
|
|
8
7
|
import { Cli } from '../../../../cli/Cli.js';
|
|
9
8
|
import request from '../../../../request.js';
|
|
10
9
|
import { formatting } from '../../../../utils/formatting.js';
|
|
@@ -69,7 +68,9 @@ class SpoTenantApplicationCustomizerSetCommand extends SpoCommand {
|
|
|
69
68
|
throw 'The specified application customizer was not found';
|
|
70
69
|
}
|
|
71
70
|
if (listItemInstances.length > 1) {
|
|
72
|
-
|
|
71
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
|
|
72
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple application customizers with ${title ? `title '${title}'` : `ClientSideComponentId '${clientSideComponentId}'`} found.`, resultAsKeyValuePair);
|
|
73
|
+
return result.Id;
|
|
73
74
|
}
|
|
74
75
|
return listItemInstances[0].Id;
|
|
75
76
|
}
|
|
@@ -4,6 +4,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
6
|
var _SpoTenantCommandSetGetCommand_instances, _SpoTenantCommandSetGetCommand_initTelemetry, _SpoTenantCommandSetGetCommand_initOptions, _SpoTenantCommandSetGetCommand_initValidators, _SpoTenantCommandSetGetCommand_initOptionSets;
|
|
7
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
7
8
|
import { CommandError } from '../../../../Command.js';
|
|
8
9
|
import request from '../../../../request.js';
|
|
9
10
|
import { formatting } from '../../../../utils/formatting.js';
|
|
@@ -53,11 +54,15 @@ class SpoTenantCommandSetGetCommand extends SpoCommand {
|
|
|
53
54
|
try {
|
|
54
55
|
const listItemInstances = await request.get(reqOptions);
|
|
55
56
|
if (listItemInstances?.value.length > 0) {
|
|
57
|
+
listItemInstances.value.forEach(v => delete v['ID']);
|
|
56
58
|
if (listItemInstances.value.length > 1) {
|
|
57
|
-
|
|
59
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances.value);
|
|
60
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple ListView Command Sets with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
|
|
61
|
+
await logger.log(result);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
await logger.log(listItemInstances.value[0]);
|
|
58
65
|
}
|
|
59
|
-
listItemInstances.value.forEach(v => delete v['ID']);
|
|
60
|
-
await logger.log(listItemInstances.value[0]);
|
|
61
66
|
}
|
|
62
67
|
else {
|
|
63
68
|
throw 'The specified ListView Command Set was not found';
|
|
@@ -25,8 +25,9 @@ class SpoTenantCommandSetListCommand extends SpoCommand {
|
|
|
25
25
|
}
|
|
26
26
|
const listServerRelativeUrl = urlUtil.getServerRelativePath(appCatalogUrl, '/lists/TenantWideExtensions');
|
|
27
27
|
try {
|
|
28
|
-
const
|
|
29
|
-
|
|
28
|
+
const listItems = await odata.getAllItems(`${appCatalogUrl}/_api/web/GetList('${formatting.encodeQueryParameter(listServerRelativeUrl)}')/items?$filter=startswith(TenantWideExtensionLocation, 'ClientSideExtension.ListViewCommandSet')`);
|
|
29
|
+
listItems.forEach(i => delete i.ID);
|
|
30
|
+
await logger.log(listItems);
|
|
30
31
|
}
|
|
31
32
|
catch (err) {
|
|
32
33
|
this.handleRejectedODataJsonPromise(err);
|
|
@@ -90,7 +90,9 @@ class SpoTenantCommandSetRemoveCommand extends SpoCommand {
|
|
|
90
90
|
throw 'The specified command set was not found';
|
|
91
91
|
}
|
|
92
92
|
if (listItemInstances.length > 1) {
|
|
93
|
-
|
|
93
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', listItemInstances);
|
|
94
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple command sets with ${args.options.title || args.options.clientSideComponentId} were found.`, resultAsKeyValuePair);
|
|
95
|
+
return result.Id;
|
|
94
96
|
}
|
|
95
97
|
return listItemInstances[0].Id;
|
|
96
98
|
}
|
|
@@ -4,7 +4,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
6
|
var _SpoTermGetCommand_instances, _SpoTermGetCommand_initTelemetry, _SpoTermGetCommand_initOptions, _SpoTermGetCommand_initValidators, _SpoTermGetCommand_initOptionSets;
|
|
7
|
-
import
|
|
7
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
8
8
|
import config from '../../../../config.js';
|
|
9
9
|
import request from '../../../../request.js';
|
|
10
10
|
import { formatting } from '../../../../utils/formatting.js';
|
|
@@ -52,12 +52,12 @@ class SpoTermGetCommand extends SpoCommand {
|
|
|
52
52
|
throw `Term with name '${args.options.name}' could not be found.`;
|
|
53
53
|
}
|
|
54
54
|
if (terms._Child_Items_.length > 1) {
|
|
55
|
-
const
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
55
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('Id', terms._Child_Items_);
|
|
56
|
+
term = await Cli.handleMultipleResultsFound(`Multiple terms with the specific term name found.`, resultAsKeyValuePair);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
term = terms._Child_Items_[0];
|
|
59
60
|
}
|
|
60
|
-
term = terms._Child_Items_[0];
|
|
61
61
|
}
|
|
62
62
|
else {
|
|
63
63
|
term = csomResponse;
|
|
@@ -26,23 +26,23 @@ class SpoUserGetCommand extends SpoCommand {
|
|
|
26
26
|
}
|
|
27
27
|
async commandAction(logger, args) {
|
|
28
28
|
if (this.verbose) {
|
|
29
|
-
await logger.logToStderr(`Retrieving information for
|
|
29
|
+
await logger.logToStderr(`Retrieving information for user in site '${args.options.webUrl}'...`);
|
|
30
30
|
}
|
|
31
31
|
let requestUrl = '';
|
|
32
32
|
if (args.options.id) {
|
|
33
|
-
requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetById('${formatting.encodeQueryParameter(args.options.id)}')`;
|
|
33
|
+
requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetById('${formatting.encodeQueryParameter(args.options.id.toString())}')`;
|
|
34
34
|
}
|
|
35
35
|
else if (args.options.email) {
|
|
36
36
|
requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByEmail('${formatting.encodeQueryParameter(args.options.email)}')`;
|
|
37
37
|
}
|
|
38
|
-
else if (args.options.
|
|
39
|
-
requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.
|
|
38
|
+
else if (args.options.loginName) {
|
|
39
|
+
requestUrl = `${args.options.webUrl}/_api/web/siteusers/GetByLoginName('${formatting.encodeQueryParameter(args.options.loginName)}')`;
|
|
40
40
|
}
|
|
41
41
|
const requestOptions = {
|
|
42
42
|
url: requestUrl,
|
|
43
43
|
method: 'GET',
|
|
44
44
|
headers: {
|
|
45
|
-
|
|
45
|
+
accept: 'application/json;odata=nometadata'
|
|
46
46
|
},
|
|
47
47
|
responseType: 'json'
|
|
48
48
|
};
|
|
@@ -58,9 +58,9 @@ class SpoUserGetCommand extends SpoCommand {
|
|
|
58
58
|
_SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry = function _SpoUserGetCommand_initTelemetry() {
|
|
59
59
|
this.telemetry.push((args) => {
|
|
60
60
|
Object.assign(this.telemetryProperties, {
|
|
61
|
-
id:
|
|
62
|
-
email:
|
|
63
|
-
|
|
61
|
+
id: typeof args.options.id !== 'undefined',
|
|
62
|
+
email: typeof args.options.email !== 'undefined',
|
|
63
|
+
loginName: typeof args.options.loginName !== 'undefined'
|
|
64
64
|
});
|
|
65
65
|
});
|
|
66
66
|
}, _SpoUserGetCommand_initOptions = function _SpoUserGetCommand_initOptions() {
|
|
@@ -71,7 +71,7 @@ _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry =
|
|
|
71
71
|
}, {
|
|
72
72
|
option: '--email [email]'
|
|
73
73
|
}, {
|
|
74
|
-
option: '--
|
|
74
|
+
option: '--loginName [loginName]'
|
|
75
75
|
});
|
|
76
76
|
}, _SpoUserGetCommand_initValidators = function _SpoUserGetCommand_initValidators() {
|
|
77
77
|
this.validators.push(async (args) => {
|
|
@@ -82,7 +82,7 @@ _SpoUserGetCommand_instances = new WeakSet(), _SpoUserGetCommand_initTelemetry =
|
|
|
82
82
|
return validation.isValidSharePointUrl(args.options.webUrl);
|
|
83
83
|
});
|
|
84
84
|
}, _SpoUserGetCommand_initOptionSets = function _SpoUserGetCommand_initOptionSets() {
|
|
85
|
-
this.optionSets.push({ options: ['id', 'email', '
|
|
85
|
+
this.optionSets.push({ options: ['id', 'email', 'loginName'] });
|
|
86
86
|
};
|
|
87
87
|
export default new SpoUserGetCommand();
|
|
88
88
|
//# sourceMappingURL=user-get.js.map
|
|
@@ -156,7 +156,11 @@ export default {
|
|
|
156
156
|
LIST_WEBHOOK_REMOVE: `${prefix} list webhook remove`,
|
|
157
157
|
LIST_WEBHOOK_SET: `${prefix} list webhook set`,
|
|
158
158
|
LISTITEM_ADD: `${prefix} listitem add`,
|
|
159
|
+
LISTITEM_ATTACHMENT_ADD: `${prefix} listitem attachment add`,
|
|
160
|
+
LISTITEM_ATTACHMENT_GET: `${prefix} listitem attachment get`,
|
|
159
161
|
LISTITEM_ATTACHMENT_LIST: `${prefix} listitem attachment list`,
|
|
162
|
+
LISTITEM_ATTACHMENT_REMOVE: `${prefix} listitem attachment remove`,
|
|
163
|
+
LISTITEM_ATTACHMENT_SET: `${prefix} listitem attachment set`,
|
|
160
164
|
LISTITEM_BATCH_ADD: `${prefix} listitem batch add`,
|
|
161
165
|
LISTITEM_BATCH_SET: `${prefix} listitem batch set`,
|
|
162
166
|
LISTITEM_GET: `${prefix} listitem get`,
|
|
@@ -3,9 +3,10 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
3
3
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
|
-
var _TeamsAppRemoveCommand_instances, _TeamsAppRemoveCommand_initTelemetry, _TeamsAppRemoveCommand_initOptions, _TeamsAppRemoveCommand_initValidators;
|
|
6
|
+
var _TeamsAppRemoveCommand_instances, _TeamsAppRemoveCommand_initTelemetry, _TeamsAppRemoveCommand_initOptions, _TeamsAppRemoveCommand_initValidators, _TeamsAppRemoveCommand_initOptionSets;
|
|
7
7
|
import { Cli } from '../../../../cli/Cli.js';
|
|
8
8
|
import request from '../../../../request.js';
|
|
9
|
+
import { formatting } from '../../../../utils/formatting.js';
|
|
9
10
|
import { validation } from '../../../../utils/validation.js';
|
|
10
11
|
import GraphCommand from '../../../base/GraphCommand.js';
|
|
11
12
|
import commands from '../../commands.js';
|
|
@@ -22,20 +23,21 @@ class TeamsAppRemoveCommand extends GraphCommand {
|
|
|
22
23
|
__classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initTelemetry).call(this);
|
|
23
24
|
__classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initOptions).call(this);
|
|
24
25
|
__classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initValidators).call(this);
|
|
26
|
+
__classPrivateFieldGet(this, _TeamsAppRemoveCommand_instances, "m", _TeamsAppRemoveCommand_initOptionSets).call(this);
|
|
25
27
|
}
|
|
26
28
|
async commandAction(logger, args) {
|
|
27
|
-
const { id: appId } = args.options;
|
|
28
29
|
const removeApp = async () => {
|
|
29
|
-
if (this.verbose) {
|
|
30
|
-
await logger.logToStderr(`Removing app with ID ${args.options.id}`);
|
|
31
|
-
}
|
|
32
|
-
const requestOptions = {
|
|
33
|
-
url: `${this.resource}/v1.0/appCatalogs/teamsApps/${appId}`,
|
|
34
|
-
headers: {
|
|
35
|
-
accept: 'application/json;odata.metadata=none'
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
30
|
try {
|
|
31
|
+
const appId = await this.getAppId(args.options, logger);
|
|
32
|
+
if (this.verbose) {
|
|
33
|
+
await logger.logToStderr(`Removing app with ID ${appId}`);
|
|
34
|
+
}
|
|
35
|
+
const requestOptions = {
|
|
36
|
+
url: `${this.resource}/v1.0/appCatalogs/teamsApps/${appId}`,
|
|
37
|
+
headers: {
|
|
38
|
+
accept: 'application/json;odata.metadata=none'
|
|
39
|
+
}
|
|
40
|
+
};
|
|
39
41
|
await request.delete(requestOptions);
|
|
40
42
|
}
|
|
41
43
|
catch (err) {
|
|
@@ -50,33 +52,65 @@ class TeamsAppRemoveCommand extends GraphCommand {
|
|
|
50
52
|
type: 'confirm',
|
|
51
53
|
name: 'continue',
|
|
52
54
|
default: false,
|
|
53
|
-
message: `Are you sure you want to remove the Teams app ${
|
|
55
|
+
message: `Are you sure you want to remove the Teams app ${args.options.id || args.options.name} from the app catalog?`
|
|
54
56
|
});
|
|
55
57
|
if (result.continue) {
|
|
56
58
|
await removeApp();
|
|
57
59
|
}
|
|
58
60
|
}
|
|
59
61
|
}
|
|
62
|
+
async getAppId(options, logger) {
|
|
63
|
+
if (options.id) {
|
|
64
|
+
return options.id;
|
|
65
|
+
}
|
|
66
|
+
if (this.verbose) {
|
|
67
|
+
await logger.logToStderr(`Retrieving app Id...`);
|
|
68
|
+
}
|
|
69
|
+
const requestOptions = {
|
|
70
|
+
url: `${this.resource}/v1.0/appCatalogs/teamsApps?$filter=displayName eq '${formatting.encodeQueryParameter(options.name)}'&$select=id`,
|
|
71
|
+
headers: {
|
|
72
|
+
accept: 'application/json;odata.metadata=none'
|
|
73
|
+
},
|
|
74
|
+
responseType: 'json'
|
|
75
|
+
};
|
|
76
|
+
const response = await request.get(requestOptions);
|
|
77
|
+
const app = response.value[0];
|
|
78
|
+
if (!app) {
|
|
79
|
+
throw `The specified Teams app does not exist`;
|
|
80
|
+
}
|
|
81
|
+
if (response.value.length > 1) {
|
|
82
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
|
|
83
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple Teams apps with name '${options.name}' found.`, resultAsKeyValuePair);
|
|
84
|
+
return result.id;
|
|
85
|
+
}
|
|
86
|
+
return app.id;
|
|
87
|
+
}
|
|
60
88
|
}
|
|
61
89
|
_TeamsAppRemoveCommand_instances = new WeakSet(), _TeamsAppRemoveCommand_initTelemetry = function _TeamsAppRemoveCommand_initTelemetry() {
|
|
62
90
|
this.telemetry.push((args) => {
|
|
63
91
|
Object.assign(this.telemetryProperties, {
|
|
64
|
-
force: (!(!args.options.force)).toString()
|
|
92
|
+
force: (!(!args.options.force)).toString(),
|
|
93
|
+
id: typeof args.options.id !== 'undefined',
|
|
94
|
+
name: typeof args.options.name !== 'undefined'
|
|
65
95
|
});
|
|
66
96
|
});
|
|
67
97
|
}, _TeamsAppRemoveCommand_initOptions = function _TeamsAppRemoveCommand_initOptions() {
|
|
68
98
|
this.options.unshift({
|
|
69
|
-
option: '-i, --id
|
|
99
|
+
option: '-i, --id [id]'
|
|
100
|
+
}, {
|
|
101
|
+
option: '-n, --name [name]'
|
|
70
102
|
}, {
|
|
71
103
|
option: '-f, --force'
|
|
72
104
|
});
|
|
73
105
|
}, _TeamsAppRemoveCommand_initValidators = function _TeamsAppRemoveCommand_initValidators() {
|
|
74
106
|
this.validators.push(async (args) => {
|
|
75
|
-
if (!validation.isValidGuid(args.options.id)) {
|
|
107
|
+
if (args.options.id && !validation.isValidGuid(args.options.id)) {
|
|
76
108
|
return `${args.options.id} is not a valid GUID`;
|
|
77
109
|
}
|
|
78
110
|
return true;
|
|
79
111
|
});
|
|
112
|
+
}, _TeamsAppRemoveCommand_initOptionSets = function _TeamsAppRemoveCommand_initOptionSets() {
|
|
113
|
+
this.optionSets.push({ options: ['id', 'name'] });
|
|
80
114
|
};
|
|
81
115
|
export default new TeamsAppRemoveCommand();
|
|
82
116
|
//# sourceMappingURL=app-remove.js.map
|
|
@@ -8,6 +8,8 @@ import request from '../../../../request.js';
|
|
|
8
8
|
import { validation } from '../../../../utils/validation.js';
|
|
9
9
|
import GraphCommand from "../../../base/GraphCommand.js";
|
|
10
10
|
import commands from '../../commands.js';
|
|
11
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
12
|
+
import { formatting } from '../../../../utils/formatting.js';
|
|
11
13
|
class TeamsChannelAddCommand extends GraphCommand {
|
|
12
14
|
get name() {
|
|
13
15
|
return commands.CHANNEL_ADD;
|
|
@@ -42,7 +44,9 @@ class TeamsChannelAddCommand extends GraphCommand {
|
|
|
42
44
|
throw `The specified team does not exist in the Microsoft Teams`;
|
|
43
45
|
}
|
|
44
46
|
if (matchingTeams.length > 1) {
|
|
45
|
-
|
|
47
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
|
|
48
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams teams with name ${args.options.teamName} found.`, resultAsKeyValuePair);
|
|
49
|
+
return result.id;
|
|
46
50
|
}
|
|
47
51
|
return matchingTeams[0];
|
|
48
52
|
}
|
|
@@ -4,13 +4,13 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
6
|
var _TeamsChannelMemberAddCommand_instances, _TeamsChannelMemberAddCommand_initTelemetry, _TeamsChannelMemberAddCommand_initOptions, _TeamsChannelMemberAddCommand_initValidators, _TeamsChannelMemberAddCommand_initOptionSets;
|
|
7
|
-
import os from 'os';
|
|
8
7
|
import request from '../../../../request.js';
|
|
9
8
|
import { aadGroup } from '../../../../utils/aadGroup.js';
|
|
10
9
|
import { formatting } from '../../../../utils/formatting.js';
|
|
11
10
|
import { validation } from '../../../../utils/validation.js';
|
|
12
11
|
import GraphCommand from '../../../base/GraphCommand.js';
|
|
13
12
|
import commands from '../../commands.js';
|
|
13
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
14
14
|
class TeamsChannelMemberAddCommand extends GraphCommand {
|
|
15
15
|
get name() {
|
|
16
16
|
return commands.CHANNEL_MEMBER_ADD;
|
|
@@ -91,11 +91,11 @@ class TeamsChannelMemberAddCommand extends GraphCommand {
|
|
|
91
91
|
return channelItem.id;
|
|
92
92
|
}
|
|
93
93
|
async getUserId(args) {
|
|
94
|
-
if (args.options.
|
|
95
|
-
return args.options.
|
|
94
|
+
if (args.options.userIds) {
|
|
95
|
+
return args.options.userIds.split(',').map(u => u.trim());
|
|
96
96
|
}
|
|
97
97
|
const tasks = [];
|
|
98
|
-
const userDisplayNames = args.options.
|
|
98
|
+
const userDisplayNames = args.options.userDisplayNames && args.options.userDisplayNames.split(',').map(u => u.trim());
|
|
99
99
|
for (const userName of userDisplayNames) {
|
|
100
100
|
tasks.push(this.getSingleUser(userName));
|
|
101
101
|
}
|
|
@@ -115,7 +115,9 @@ class TeamsChannelMemberAddCommand extends GraphCommand {
|
|
|
115
115
|
throw `The specified user '${userDisplayName}' does not exist`;
|
|
116
116
|
}
|
|
117
117
|
if (response.value.length > 1) {
|
|
118
|
-
|
|
118
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', response.value);
|
|
119
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple users with display name '${userDisplayName}' found.`, resultAsKeyValuePair);
|
|
120
|
+
return result.id;
|
|
119
121
|
}
|
|
120
122
|
return userItem.id;
|
|
121
123
|
}
|
|
@@ -127,8 +129,8 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
|
|
|
127
129
|
teamName: typeof args.options.teamName !== 'undefined',
|
|
128
130
|
channelId: typeof args.options.channelId !== 'undefined',
|
|
129
131
|
channelName: typeof args.options.channelName !== 'undefined',
|
|
130
|
-
|
|
131
|
-
|
|
132
|
+
userIds: typeof args.options.userIds !== 'undefined',
|
|
133
|
+
userDisplayNames: typeof args.options.userDisplayNames !== 'undefined',
|
|
132
134
|
owner: args.options.owner
|
|
133
135
|
});
|
|
134
136
|
});
|
|
@@ -142,9 +144,9 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
|
|
|
142
144
|
}, {
|
|
143
145
|
option: '--channelName [channelName]'
|
|
144
146
|
}, {
|
|
145
|
-
option: '--
|
|
147
|
+
option: '--userIds [userIds]'
|
|
146
148
|
}, {
|
|
147
|
-
option: '--
|
|
149
|
+
option: '--userDisplayNames [userDisplayNames]'
|
|
148
150
|
}, {
|
|
149
151
|
option: '--owner'
|
|
150
152
|
});
|
|
@@ -159,7 +161,7 @@ _TeamsChannelMemberAddCommand_instances = new WeakSet(), _TeamsChannelMemberAddC
|
|
|
159
161
|
return true;
|
|
160
162
|
});
|
|
161
163
|
}, _TeamsChannelMemberAddCommand_initOptionSets = function _TeamsChannelMemberAddCommand_initOptionSets() {
|
|
162
|
-
this.optionSets.push({ options: ['teamId', 'teamName'] }, { options: ['channelId', 'channelName'] }, { options: ['
|
|
164
|
+
this.optionSets.push({ options: ['teamId', 'teamName'] }, { options: ['channelId', 'channelName'] }, { options: ['userIds', 'userDisplayNames'] });
|
|
163
165
|
};
|
|
164
166
|
export default new TeamsChannelMemberAddCommand();
|
|
165
167
|
//# sourceMappingURL=channel-member-add.js.map
|
|
@@ -123,7 +123,9 @@ class TeamsChannelMemberRemoveCommand extends GraphCommand {
|
|
|
123
123
|
throw 'The specified member does not exist in the Microsoft Teams channel';
|
|
124
124
|
}
|
|
125
125
|
if (conversationMembers.length > 1) {
|
|
126
|
-
|
|
126
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', conversationMembers);
|
|
127
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams channel members with name ${args.options.userName} found.`, resultAsKeyValuePair);
|
|
128
|
+
return result.id;
|
|
127
129
|
}
|
|
128
130
|
return conversationMember.id;
|
|
129
131
|
}
|
|
@@ -10,6 +10,7 @@ import { formatting } from '../../../../utils/formatting.js';
|
|
|
10
10
|
import { validation } from '../../../../utils/validation.js';
|
|
11
11
|
import GraphCommand from '../../../base/GraphCommand.js';
|
|
12
12
|
import commands from '../../commands.js';
|
|
13
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
13
14
|
class TeamsChannelMemberSetCommand extends GraphCommand {
|
|
14
15
|
get name() {
|
|
15
16
|
return commands.CHANNEL_MEMBER_SET;
|
|
@@ -101,7 +102,9 @@ class TeamsChannelMemberSetCommand extends GraphCommand {
|
|
|
101
102
|
throw 'The specified member does not exist in the Microsoft Teams channel';
|
|
102
103
|
}
|
|
103
104
|
if (conversationMembers.length > 1) {
|
|
104
|
-
|
|
105
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', conversationMembers);
|
|
106
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple Microsoft Teams channel members with name ${args.options.userName} found.`, resultAsKeyValuePair);
|
|
107
|
+
return result.id;
|
|
105
108
|
}
|
|
106
109
|
return conversationMember.id;
|
|
107
110
|
}
|
|
@@ -4,7 +4,6 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
4
4
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
5
5
|
};
|
|
6
6
|
var _TeamsChatGetCommand_instances, _TeamsChatGetCommand_initTelemetry, _TeamsChatGetCommand_initOptions, _TeamsChatGetCommand_initValidators, _TeamsChatGetCommand_initOptionSets;
|
|
7
|
-
import os from 'os';
|
|
8
7
|
import auth from '../../../../Auth.js';
|
|
9
8
|
import request from '../../../../request.js';
|
|
10
9
|
import { accessToken } from '../../../../utils/accessToken.js';
|
|
@@ -13,6 +12,7 @@ import { validation } from '../../../../utils/validation.js';
|
|
|
13
12
|
import GraphCommand from '../../../base/GraphCommand.js';
|
|
14
13
|
import commands from '../../commands.js';
|
|
15
14
|
import { chatUtil } from './chatUtil.js';
|
|
15
|
+
import { Cli } from '../../../../cli/Cli.js';
|
|
16
16
|
class TeamsChatGetCommand extends GraphCommand {
|
|
17
17
|
get name() {
|
|
18
18
|
return commands.CHAT_GET;
|
|
@@ -66,10 +66,9 @@ class TeamsChatGetCommand extends GraphCommand {
|
|
|
66
66
|
if (existingChats.length === 1) {
|
|
67
67
|
return existingChats[0].id;
|
|
68
68
|
}
|
|
69
|
-
const
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
throw `Multiple chat conversations with these participants found. Please disambiguate:${os.EOL}${disambiguationText}`;
|
|
69
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', existingChats);
|
|
70
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple chat conversations with these participants found.`, resultAsKeyValuePair);
|
|
71
|
+
return result.id;
|
|
73
72
|
}
|
|
74
73
|
async getChatIdByName(name) {
|
|
75
74
|
const existingChats = await chatUtil.findExistingGroupChatsByName(name);
|
|
@@ -79,11 +78,9 @@ class TeamsChatGetCommand extends GraphCommand {
|
|
|
79
78
|
if (existingChats.length === 1) {
|
|
80
79
|
return existingChats[0].id;
|
|
81
80
|
}
|
|
82
|
-
const
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
}).join(os.EOL);
|
|
86
|
-
throw `Multiple chat conversations with this name found. Please disambiguate:${os.EOL}${disambiguationText}`;
|
|
81
|
+
const resultAsKeyValuePair = formatting.convertArrayToHashTable('id', existingChats);
|
|
82
|
+
const result = await Cli.handleMultipleResultsFound(`Multiple chat conversations with this name found.`, resultAsKeyValuePair);
|
|
83
|
+
return result.id;
|
|
87
84
|
}
|
|
88
85
|
}
|
|
89
86
|
_TeamsChatGetCommand_instances = new WeakSet(), _TeamsChatGetCommand_initTelemetry = function _TeamsChatGetCommand_initTelemetry() {
|