@pnp/cli-microsoft365 5.0.0-beta.aff293c → 5.0.0-beta.c4100fe
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/.devcontainer/Dockerfile +2 -2
- package/.devcontainer/devcontainer.json +13 -2
- package/.eslintrc.js +3 -0
- package/.mocharc.json +9 -0
- package/README.md +3 -3
- package/dist/Command.js +1 -1
- package/dist/Utils.js +7 -0
- package/dist/api.d.ts +11 -0
- package/dist/api.js +17 -0
- package/dist/appInsights.js +5 -2
- package/dist/cli/Cli.js +42 -7
- package/dist/m365/aad/commands/app/app-add.js +101 -12
- package/dist/m365/aad/commands/app/app-delete.js +123 -0
- package/dist/m365/aad/commands/app/app-get.js +142 -0
- package/dist/m365/aad/commands/app/app-set.js +98 -3
- package/dist/m365/aad/commands/group/group-list.js +54 -0
- package/dist/m365/aad/commands/o365group/{GroupUser.js → GroupExtended.js} +1 -1
- package/dist/m365/aad/commands/o365group/o365group-add.js +56 -50
- package/dist/m365/aad/commands/o365group/o365group-conversation-list.js +41 -0
- package/dist/m365/aad/commands/o365group/o365group-user-set.js +3 -3
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-add.js +5 -8
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-list.js +7 -7
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-remove.js +36 -12
- package/dist/m365/aad/commands/oauth2grant/oauth2grant-set.js +3 -3
- package/dist/m365/aad/commands/sp/sp-add.js +107 -0
- package/dist/m365/aad/commands/sp/sp-get.js +44 -21
- package/dist/m365/aad/commands/user/user-get.js +33 -6
- package/dist/m365/aad/commands/user/user-hibp.js +67 -0
- package/dist/m365/aad/commands/user/user-list.js +7 -4
- package/dist/m365/aad/commands/user/user-password-validate.js +42 -0
- package/dist/m365/aad/commands.js +7 -0
- package/dist/m365/app/commands/permission/permission-list.js +266 -0
- package/dist/m365/app/commands.js +7 -0
- package/dist/m365/base/AppCommand.js +76 -0
- package/dist/m365/{aad/commands/o365group/Group.js → base/M365RcJson.js} +1 -1
- package/dist/m365/cli/commands/cli-doctor.js +2 -0
- package/dist/m365/cli/commands/config/config-set.js +4 -1
- package/dist/m365/file/commands/file-add.js +32 -13
- package/dist/m365/file/commands/file-list.js +181 -0
- package/dist/m365/file/commands.js +2 -1
- package/dist/m365/flow/commands/flow-get.js +2 -2
- package/dist/m365/outlook/commands/room/room-list.js +43 -0
- package/dist/m365/outlook/commands/roomlist/roomlist-list.js +25 -0
- package/dist/m365/outlook/commands.js +2 -0
- package/dist/m365/pa/cds-project-mutator.js +1 -1
- package/dist/m365/pa/commands/app/app-list.js +28 -1
- package/dist/m365/planner/AppliedCategories.js +3 -0
- package/dist/m365/planner/commands/task/task-add.js +288 -0
- package/dist/m365/planner/commands/task/task-details-get.js +39 -0
- package/dist/m365/planner/commands/task/task-get.js +37 -0
- package/dist/m365/planner/commands/task/task-list.js +37 -7
- package/dist/m365/planner/commands/task/task-set.js +357 -0
- package/dist/m365/planner/commands.js +5 -1
- package/dist/m365/search/commands/externalconnection/externalconnection-add.js +99 -0
- package/dist/m365/search/commands.js +7 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006005_CFG_PS_metadata.js +63 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006006_CFG_PS_features.js +60 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN014008_CODE_launch_hostedWorkbench_type.js +62 -0
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.13.1.js +53 -0
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.14.0.js +59 -0
- package/dist/m365/spfx/commands/project/project-upgrade.js +3 -1
- package/dist/m365/spfx/commands/spfx-doctor.js +197 -64
- package/dist/m365/spo/commands/contenttype/contenttype-list.js +52 -0
- package/dist/m365/spo/commands/group/group-user-add.js +74 -16
- package/dist/m365/spo/commands/group/group-user-remove.js +100 -0
- package/dist/m365/spo/commands/list/list-get.js +6 -2
- package/dist/m365/spo/commands/listitem/listitem-attachment-list.js +90 -0
- package/dist/m365/spo/commands/page/Page.js +3 -1
- package/dist/m365/spo/commands/page/page-add.js +7 -10
- package/dist/m365/spo/commands/page/page-set.js +7 -10
- package/dist/m365/spo/commands/site/site-ensure.js +1 -1
- package/dist/m365/spo/commands/site/site-recyclebinitem-list.js +76 -0
- package/dist/m365/spo/commands/site/site-remove.js +98 -30
- package/dist/m365/spo/commands/web/web-installedlanguage-list.js +48 -0
- package/dist/m365/spo/commands.js +6 -1
- package/dist/m365/teams/commands/app/app-install.js +75 -21
- package/dist/m365/teams/commands/app/app-list.js +9 -6
- package/dist/m365/teams/commands/app/app-update.js +55 -12
- package/dist/m365/teams/commands/channel/channel-get.js +29 -7
- package/dist/m365/teams/commands/chat/chat-list.js +43 -0
- package/dist/m365/teams/commands/chat/chat-member-list.js +42 -0
- package/dist/m365/teams/commands/chat/chat-message-list.js +60 -0
- package/dist/m365/teams/commands/chat/chat-message-send.js +225 -0
- package/dist/m365/teams/commands/message/message-get.js +1 -1
- package/dist/m365/teams/commands/report/report-directroutingcalls.js +1 -1
- package/dist/m365/teams/commands/report/report-pstncalls.js +1 -1
- package/dist/m365/teams/commands/tab/tab-get.js +9 -6
- package/dist/m365/teams/commands.js +4 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-health-get.js +57 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-health-list.js +56 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-get.js +39 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-healthissue-list.js +38 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-get.js +51 -0
- package/dist/m365/tenant/commands/serviceannouncement/serviceannouncement-message-list.js +38 -0
- package/dist/m365/tenant/commands.js +6 -0
- package/dist/request.js +9 -4
- package/dist/settingsNames.js +6 -1
- package/docs/docs/cmd/_global.md +2 -2
- package/docs/docs/cmd/aad/app/app-add.md +11 -0
- package/docs/docs/cmd/aad/app/app-delete.md +51 -0
- package/docs/docs/cmd/aad/app/app-get.md +59 -0
- package/docs/docs/cmd/aad/app/app-set.md +21 -0
- package/docs/docs/cmd/aad/group/group-list.md +30 -0
- package/docs/docs/cmd/aad/o365group/o365group-add.md +1 -0
- package/docs/docs/cmd/aad/o365group/o365group-conversation-list.md +24 -0
- package/docs/docs/cmd/aad/oauth2grant/oauth2grant-list.md +4 -3
- package/docs/docs/cmd/aad/oauth2grant/oauth2grant-remove.md +9 -0
- package/docs/docs/cmd/aad/oauth2grant/oauth2grant-set.md +3 -2
- package/docs/docs/cmd/aad/sp/sp-add.md +53 -0
- package/docs/docs/cmd/aad/sp/sp-get.md +2 -1
- package/docs/docs/cmd/aad/user/user-get.md +13 -4
- package/docs/docs/cmd/aad/user/user-hibp.md +46 -0
- package/docs/docs/cmd/aad/user/user-list.md +9 -0
- package/docs/docs/cmd/aad/user/user-password-validate.md +29 -0
- package/docs/docs/cmd/app/permission/permission-list.md +36 -0
- package/docs/docs/cmd/file/file-add.md +11 -0
- package/docs/docs/cmd/file/file-list.md +46 -0
- package/docs/docs/cmd/outlook/room/room-list.md +30 -0
- package/docs/docs/cmd/outlook/roomlist/roomlist-list.md +21 -0
- package/docs/docs/cmd/pa/app/app-list.md +17 -1
- package/docs/docs/cmd/planner/task/task-add.md +78 -0
- package/docs/docs/cmd/planner/task/task-details-get.md +24 -0
- package/docs/docs/cmd/planner/task/task-get.md +29 -0
- package/docs/docs/cmd/planner/task/task-list.md +5 -0
- package/docs/docs/cmd/planner/task/task-set.md +99 -0
- package/docs/docs/cmd/search/externalconnection/externalconnection-add.md +43 -0
- package/docs/docs/cmd/spfx/project/project-externalize.md +1 -1
- package/docs/docs/cmd/spfx/project/project-rename.md +1 -1
- package/docs/docs/cmd/spfx/project/project-upgrade.md +8 -8
- package/docs/docs/cmd/spfx/spfx-doctor.md +1 -1
- package/docs/docs/cmd/spo/contenttype/contenttype-list.md +33 -0
- package/docs/docs/cmd/spo/group/group-user-add.md +28 -6
- package/docs/docs/cmd/spo/group/group-user-remove.md +39 -0
- package/docs/docs/cmd/spo/list/list-get.md +9 -0
- package/docs/docs/cmd/spo/listitem/listitem-attachment-list.md +39 -0
- package/docs/docs/cmd/spo/page/page-add.md +2 -2
- package/docs/docs/cmd/spo/page/page-set.md +3 -3
- package/docs/docs/cmd/spo/site/site-recyclebinitem-list.md +40 -0
- package/docs/docs/cmd/spo/site/site-remove.md +3 -1
- package/docs/docs/cmd/spo/web/web-installedlanguage-list.md +24 -0
- package/docs/docs/cmd/teams/app/app-install.md +22 -4
- package/docs/docs/cmd/teams/app/app-update.md +12 -3
- package/docs/docs/cmd/teams/channel/channel-get.md +11 -2
- package/docs/docs/cmd/teams/chat/chat-list.md +30 -0
- package/docs/docs/cmd/teams/chat/chat-member-list.md +24 -0
- package/docs/docs/cmd/teams/chat/chat-message-list.md +24 -0
- package/docs/docs/cmd/teams/chat/chat-message-send.md +55 -0
- package/docs/docs/cmd/teams/message/message-get.md +0 -3
- package/docs/docs/cmd/teams/report/report-directroutingcalls.md +0 -3
- package/docs/docs/cmd/teams/report/report-pstncalls.md +4 -3
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-get.md +33 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-health-list.md +30 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-get.md +24 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-healthissue-list.md +34 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-get.md +28 -0
- package/docs/docs/cmd/tenant/serviceannouncement/serviceannouncement-message-list.md +34 -0
- package/npm-shrinkwrap.json +1740 -2288
- package/package.json +46 -33
- package/dist/m365/base/AadCommand.js +0 -10
|
@@ -25,26 +25,65 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
25
25
|
commandAction(logger, args, cb) {
|
|
26
26
|
const removeSite = () => {
|
|
27
27
|
this.dots = '';
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
28
|
+
if (args.options.fromRecycleBin) {
|
|
29
|
+
this
|
|
30
|
+
.deleteSiteWithoutGroup(logger, args)
|
|
31
|
+
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this
|
|
35
|
+
.getSiteGroupId(args.options.url, logger)
|
|
36
|
+
.then((groupId) => {
|
|
37
|
+
if (groupId === '00000000-0000-0000-0000-000000000000') {
|
|
38
|
+
if (this.debug) {
|
|
39
|
+
logger.logToStderr('Site is not groupified. Going ahead with the conventional site deletion options');
|
|
40
|
+
}
|
|
41
|
+
return this.deleteSiteWithoutGroup(logger, args);
|
|
40
42
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
+
else {
|
|
44
|
+
if (this.debug) {
|
|
45
|
+
logger.logToStderr(`Site attached to group ${groupId}. Initiating group delete operation via Graph API`);
|
|
46
|
+
}
|
|
47
|
+
return this
|
|
48
|
+
.getSiteGroup(groupId)
|
|
49
|
+
.then((group) => {
|
|
50
|
+
if (args.options.skipRecycleBin || args.options.wait) {
|
|
51
|
+
logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameters 'skipRecycleBin' and 'wait' will not be applicable.`));
|
|
52
|
+
}
|
|
53
|
+
return this.deleteGroupifiedSite(group.id, logger);
|
|
54
|
+
})
|
|
55
|
+
.catch((err) => {
|
|
56
|
+
if (err.response.status === 404) {
|
|
57
|
+
if (this.verbose) {
|
|
58
|
+
logger.logToStderr(`Site group doesn't exist. Searching in the Microsoft 365 deleted groups.`);
|
|
59
|
+
}
|
|
60
|
+
return this
|
|
61
|
+
.isSiteGroupDeleted(groupId)
|
|
62
|
+
.then((deletedGroups) => {
|
|
63
|
+
if (deletedGroups.value.length === 0) {
|
|
64
|
+
if (this.verbose) {
|
|
65
|
+
logger.logToStderr("Site group doesn't exist anymore. Deleting the site.");
|
|
66
|
+
}
|
|
67
|
+
if (args.options.wait) {
|
|
68
|
+
logger.logToStderr(chalk.yellow(`Entered site is a groupified site. Hence, the parameter 'wait' will not be applicable.`));
|
|
69
|
+
}
|
|
70
|
+
return Promise.resolve();
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
return Promise.reject(`Site group still exists in the deleted groups. The site won't be removed.`);
|
|
74
|
+
}
|
|
75
|
+
})
|
|
76
|
+
.then(_ => this.deleteOrphanedSite(logger, args.options.url))
|
|
77
|
+
.catch((err) => Promise.reject(err));
|
|
78
|
+
}
|
|
79
|
+
else {
|
|
80
|
+
return Promise.reject(err);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
43
83
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
84
|
+
})
|
|
85
|
+
.then(_ => cb(), (err) => this.handleRejectedPromise(err, logger, cb));
|
|
86
|
+
}
|
|
48
87
|
};
|
|
49
88
|
if (args.options.confirm) {
|
|
50
89
|
removeSite();
|
|
@@ -65,32 +104,64 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
65
104
|
});
|
|
66
105
|
}
|
|
67
106
|
}
|
|
107
|
+
getSiteGroup(groupId) {
|
|
108
|
+
const requestOptions = {
|
|
109
|
+
url: `https://graph.microsoft.com/v1.0/groups/${groupId}`,
|
|
110
|
+
headers: {
|
|
111
|
+
accept: 'application/json;odata.metadata=none'
|
|
112
|
+
},
|
|
113
|
+
responseType: 'json'
|
|
114
|
+
};
|
|
115
|
+
return request_1.default.get(requestOptions);
|
|
116
|
+
}
|
|
117
|
+
isSiteGroupDeleted(groupId) {
|
|
118
|
+
const requestOptions = {
|
|
119
|
+
url: `https://graph.microsoft.com/v1.0/directory/deletedItems/Microsoft.Graph.Group?$select=id&$filter=groupTypes/any(c:c+eq+'Unified') and startswith(id, '${groupId}')`,
|
|
120
|
+
headers: {
|
|
121
|
+
accept: 'application/json;odata.metadata=none'
|
|
122
|
+
},
|
|
123
|
+
responseType: 'json'
|
|
124
|
+
};
|
|
125
|
+
return request_1.default.get(requestOptions);
|
|
126
|
+
}
|
|
127
|
+
deleteOrphanedSite(logger, url) {
|
|
128
|
+
return this
|
|
129
|
+
.getSpoAdminUrl(logger, this.debug)
|
|
130
|
+
.then((spoAdminUrl) => {
|
|
131
|
+
const requestOptions = {
|
|
132
|
+
url: `${spoAdminUrl}/_api/GroupSiteManager/Delete?siteUrl='${url}'`,
|
|
133
|
+
headers: {
|
|
134
|
+
'content-type': 'application/json;odata=nometadata',
|
|
135
|
+
accept: 'application/json;odata=nometadata'
|
|
136
|
+
},
|
|
137
|
+
responseType: 'json'
|
|
138
|
+
};
|
|
139
|
+
return request_1.default.post(requestOptions);
|
|
140
|
+
});
|
|
141
|
+
}
|
|
68
142
|
deleteSiteWithoutGroup(logger, args) {
|
|
69
143
|
return this
|
|
70
144
|
.getSpoAdminUrl(logger, this.debug)
|
|
71
|
-
.then((
|
|
72
|
-
this.spoAdminUrl =
|
|
145
|
+
.then((spoAdminUrl) => {
|
|
146
|
+
this.spoAdminUrl = spoAdminUrl;
|
|
73
147
|
return this.ensureFormDigest(this.spoAdminUrl, logger, this.context, this.debug);
|
|
74
148
|
})
|
|
75
149
|
.then((res) => {
|
|
76
150
|
this.context = res;
|
|
77
151
|
if (args.options.fromRecycleBin) {
|
|
78
152
|
if (this.verbose) {
|
|
79
|
-
logger.logToStderr(`Deleting site
|
|
153
|
+
logger.logToStderr(`Deleting site from recycle bin ${args.options.url}...`);
|
|
80
154
|
}
|
|
81
155
|
return this.deleteSiteFromTheRecycleBin(args.options.url, args.options.wait, logger);
|
|
82
156
|
}
|
|
83
157
|
else {
|
|
84
|
-
if (this.verbose) {
|
|
85
|
-
logger.logToStderr(`Deleting site collection ${args.options.url}...`);
|
|
86
|
-
}
|
|
87
158
|
return this.deleteSite(args.options.url, args.options.wait, logger);
|
|
88
159
|
}
|
|
89
160
|
})
|
|
90
161
|
.then(() => {
|
|
91
162
|
if (args.options.skipRecycleBin) {
|
|
92
163
|
if (this.verbose) {
|
|
93
|
-
logger.logToStderr(`Also deleting site
|
|
164
|
+
logger.logToStderr(`Also deleting site from tenant recycle bin ${args.options.url}...`);
|
|
94
165
|
}
|
|
95
166
|
return this.deleteSiteFromTheRecycleBin(args.options.url, args.options.wait, logger);
|
|
96
167
|
}
|
|
@@ -106,7 +177,7 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
106
177
|
.then((res) => {
|
|
107
178
|
this.context = res;
|
|
108
179
|
if (this.verbose) {
|
|
109
|
-
logger.logToStderr(`Deleting site ${url}
|
|
180
|
+
logger.logToStderr(`Deleting site ${url}...`);
|
|
110
181
|
}
|
|
111
182
|
const requestOptions = {
|
|
112
183
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
@@ -143,9 +214,6 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
143
214
|
.ensureFormDigest(this.spoAdminUrl, logger, this.context, this.debug)
|
|
144
215
|
.then((res) => {
|
|
145
216
|
this.context = res;
|
|
146
|
-
if (this.verbose) {
|
|
147
|
-
logger.logToStderr(`Deleting site ${url} from the recycle bin...`);
|
|
148
|
-
}
|
|
149
217
|
const requestOptions = {
|
|
150
218
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
151
219
|
headers: {
|
|
@@ -185,7 +253,7 @@ class SpoSiteRemoveCommand extends SpoCommand_1.default {
|
|
|
185
253
|
.then((res) => {
|
|
186
254
|
this.context = res;
|
|
187
255
|
if (this.verbose) {
|
|
188
|
-
logger.logToStderr(`Retrieving the
|
|
256
|
+
logger.logToStderr(`Retrieving the group Id of the site ${url}`);
|
|
189
257
|
}
|
|
190
258
|
const requestOptions = {
|
|
191
259
|
url: `${this.spoAdminUrl}/_vti_bin/client.svc/ProcessQuery`,
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
5
|
+
const commands_1 = require("../../commands");
|
|
6
|
+
class SpoWebInstalledLanguageListCommand extends SpoCommand_1.default {
|
|
7
|
+
get name() {
|
|
8
|
+
return commands_1.default.WEB_INSTALLEDLANGUAGE_LIST;
|
|
9
|
+
}
|
|
10
|
+
get description() {
|
|
11
|
+
return 'Lists all installed languages on site';
|
|
12
|
+
}
|
|
13
|
+
defaultProperties() {
|
|
14
|
+
return ['DisplayName', 'LanguageTag', 'Lcid'];
|
|
15
|
+
}
|
|
16
|
+
commandAction(logger, args, cb) {
|
|
17
|
+
if (this.verbose) {
|
|
18
|
+
logger.logToStderr(`Retrieving all installed languages on site ${args.options.webUrl}...`);
|
|
19
|
+
}
|
|
20
|
+
const requestOptions = {
|
|
21
|
+
url: `${args.options.webUrl}/_api/web/RegionalSettings/InstalledLanguages`,
|
|
22
|
+
headers: {
|
|
23
|
+
'accept': 'application/json;odata=nometadata'
|
|
24
|
+
},
|
|
25
|
+
responseType: 'json'
|
|
26
|
+
};
|
|
27
|
+
request_1.default
|
|
28
|
+
.get(requestOptions)
|
|
29
|
+
.then((webInstalledLanguageProperties) => {
|
|
30
|
+
logger.log(webInstalledLanguageProperties.Items);
|
|
31
|
+
cb();
|
|
32
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
33
|
+
}
|
|
34
|
+
options() {
|
|
35
|
+
const options = [
|
|
36
|
+
{
|
|
37
|
+
option: '-u, --webUrl <webUrl>'
|
|
38
|
+
}
|
|
39
|
+
];
|
|
40
|
+
const parentOptions = super.options();
|
|
41
|
+
return options.concat(parentOptions);
|
|
42
|
+
}
|
|
43
|
+
validate(args) {
|
|
44
|
+
return SpoCommand_1.default.isValidSharePointUrl(args.options.webUrl);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
module.exports = new SpoWebInstalledLanguageListCommand();
|
|
48
|
+
//# sourceMappingURL=web-installedlanguage-list.js.map
|
|
@@ -22,9 +22,10 @@ exports.default = {
|
|
|
22
22
|
CDN_POLICY_SET: `${prefix} cdn policy set`,
|
|
23
23
|
CDN_SET: `${prefix} cdn set`,
|
|
24
24
|
CONTENTTYPE_ADD: `${prefix} contenttype add`,
|
|
25
|
-
CONTENTTYPE_GET: `${prefix} contenttype get`,
|
|
26
25
|
CONTENTTYPE_FIELD_REMOVE: `${prefix} contenttype field remove`,
|
|
27
26
|
CONTENTTYPE_FIELD_SET: `${prefix} contenttype field set`,
|
|
27
|
+
CONTENTTYPE_GET: `${prefix} contenttype get`,
|
|
28
|
+
CONTENTTYPE_LIST: `${prefix} contenttype list`,
|
|
28
29
|
CONTENTTYPE_REMOVE: `${prefix} contenttype remove`,
|
|
29
30
|
CONTENTTYPEHUB_GET: `${prefix} contenttypehub get`,
|
|
30
31
|
CUSTOMACTION_ADD: `${prefix} customaction add`,
|
|
@@ -63,6 +64,7 @@ exports.default = {
|
|
|
63
64
|
GROUP_REMOVE: `${prefix} group remove`,
|
|
64
65
|
GROUP_USER_ADD: `${prefix} group user add`,
|
|
65
66
|
GROUP_USER_LIST: `${prefix} group user list`,
|
|
67
|
+
GROUP_USER_REMOVE: `${prefix} group user remove`,
|
|
66
68
|
HIDEDEFAULTTHEMES_GET: `${prefix} hidedefaultthemes get`,
|
|
67
69
|
HIDEDEFAULTTHEMES_SET: `${prefix} hidedefaultthemes set`,
|
|
68
70
|
HOMESITE_GET: `${prefix} homesite get`,
|
|
@@ -107,6 +109,7 @@ exports.default = {
|
|
|
107
109
|
LIST_WEBHOOK_REMOVE: `${prefix} list webhook remove`,
|
|
108
110
|
LIST_WEBHOOK_SET: `${prefix} list webhook set`,
|
|
109
111
|
LISTITEM_ADD: `${prefix} listitem add`,
|
|
112
|
+
LISTITEM_ATTACHMENT_LIST: `${prefix} listitem attachment list`,
|
|
110
113
|
LISTITEM_GET: `${prefix} listitem get`,
|
|
111
114
|
LISTITEM_ISRECORD: `${prefix} listitem isrecord`,
|
|
112
115
|
LISTITEM_LIST: `${prefix} listitem list`,
|
|
@@ -181,6 +184,7 @@ exports.default = {
|
|
|
181
184
|
SITE_GROUPIFY: `${prefix} site groupify`,
|
|
182
185
|
SITE_LIST: `${prefix} site list`,
|
|
183
186
|
SITE_INPLACERECORDSMANAGEMENT_SET: `${prefix} site inplacerecordsmanagement set`,
|
|
187
|
+
SITE_RECYCLEBINITEM_LIST: `${prefix} site recyclebinitem list`,
|
|
184
188
|
SITE_REMOVE: `${prefix} site remove`,
|
|
185
189
|
SITE_RENAME: `${prefix} site rename`,
|
|
186
190
|
SITE_SET: `${prefix} site set`,
|
|
@@ -244,6 +248,7 @@ exports.default = {
|
|
|
244
248
|
WEB_ADD: `${prefix} web add`,
|
|
245
249
|
WEB_CLIENTSIDEWEBPART_LIST: `${prefix} web clientsidewebpart list`,
|
|
246
250
|
WEB_GET: `${prefix} web get`,
|
|
251
|
+
WEB_INSTALLEDLANGUAGE_LIST: `${prefix} web installedlanguage list`,
|
|
247
252
|
WEB_LIST: `${prefix} web list`,
|
|
248
253
|
WEB_REINDEX: `${prefix} web reindex`,
|
|
249
254
|
WEB_REMOVE: `${prefix} web remove`,
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const cli_1 = require("../../../../cli");
|
|
3
4
|
const request_1 = require("../../../../request");
|
|
4
5
|
const Utils_1 = require("../../../../Utils");
|
|
6
|
+
const AadUserGetCommand = require("../../../aad/commands/user/user-get");
|
|
5
7
|
const GraphCommand_1 = require("../../../base/GraphCommand");
|
|
6
8
|
const commands_1 = require("../../commands");
|
|
7
9
|
class TeamsAppInstallCommand extends GraphCommand_1.default {
|
|
@@ -9,33 +11,70 @@ class TeamsAppInstallCommand extends GraphCommand_1.default {
|
|
|
9
11
|
return commands_1.default.APP_INSTALL;
|
|
10
12
|
}
|
|
11
13
|
get description() {
|
|
12
|
-
return 'Installs
|
|
14
|
+
return 'Installs a Microsoft Teams team app from the catalog in the specified team or for the specified user';
|
|
13
15
|
}
|
|
14
16
|
commandAction(logger, args, cb) {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
responseType: 'json',
|
|
23
|
-
data: {
|
|
24
|
-
'teamsApp@odata.bind': `${endpoint}/appCatalogs/teamsApps/${args.options.appId}`
|
|
17
|
+
this
|
|
18
|
+
.validateUser(args, logger)
|
|
19
|
+
.then(_ => {
|
|
20
|
+
var _a;
|
|
21
|
+
let url = `${this.resource}/v1.0`;
|
|
22
|
+
if (args.options.teamId) {
|
|
23
|
+
url += `/teams/${encodeURIComponent(args.options.teamId)}/installedApps`;
|
|
25
24
|
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
25
|
+
else {
|
|
26
|
+
url += `/users/${encodeURIComponent(((_a = args.options.userId) !== null && _a !== void 0 ? _a : args.options.userName))}/teamwork/installedApps`;
|
|
27
|
+
}
|
|
28
|
+
const requestOptions = {
|
|
29
|
+
url: url,
|
|
30
|
+
headers: {
|
|
31
|
+
'content-type': 'application/json;odata=nometadata',
|
|
32
|
+
'accept': 'application/json;odata.metadata=none'
|
|
33
|
+
},
|
|
34
|
+
responseType: 'json',
|
|
35
|
+
data: {
|
|
36
|
+
'teamsApp@odata.bind': `${this.resource}/v1.0/appCatalogs/teamsApps/${args.options.appId}`
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
return request_1.default.post(requestOptions);
|
|
40
|
+
})
|
|
29
41
|
.then(_ => cb(), (res) => this.handleRejectedODataJsonPromise(res, logger, cb));
|
|
30
42
|
}
|
|
43
|
+
// we need this method, because passing an invalid user ID to the API
|
|
44
|
+
// won't cause an error
|
|
45
|
+
validateUser(args, logger) {
|
|
46
|
+
if (!args.options.userId) {
|
|
47
|
+
return Promise.resolve(true);
|
|
48
|
+
}
|
|
49
|
+
if (this.verbose) {
|
|
50
|
+
logger.logToStderr(`Checking if user ${args.options.userId} exists...`);
|
|
51
|
+
}
|
|
52
|
+
const options = {
|
|
53
|
+
id: args.options.userId,
|
|
54
|
+
output: 'json',
|
|
55
|
+
debug: args.options.debug,
|
|
56
|
+
verbose: args.options.verbose
|
|
57
|
+
};
|
|
58
|
+
return cli_1.Cli
|
|
59
|
+
.executeCommandWithOutput(AadUserGetCommand, { options: Object.assign(Object.assign({}, options), { _: [] }) })
|
|
60
|
+
.then((res) => {
|
|
61
|
+
if (this.verbose) {
|
|
62
|
+
logger.logToStderr(res.stderr);
|
|
63
|
+
}
|
|
64
|
+
return true;
|
|
65
|
+
}, (err) => {
|
|
66
|
+
if (this.verbose) {
|
|
67
|
+
logger.logToStderr(err.stderr);
|
|
68
|
+
}
|
|
69
|
+
return Promise.reject(`User with ID ${args.options.userId} not found. Original error: ${err.error.message}`);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
31
72
|
options() {
|
|
32
73
|
const options = [
|
|
33
|
-
{
|
|
34
|
-
|
|
35
|
-
},
|
|
36
|
-
{
|
|
37
|
-
option: '--teamId <teamId>'
|
|
38
|
-
}
|
|
74
|
+
{ option: '--appId <appId>' },
|
|
75
|
+
{ option: '--teamId [teamId' },
|
|
76
|
+
{ option: '--userId [userId]' },
|
|
77
|
+
{ option: '--userName [userName]' }
|
|
39
78
|
];
|
|
40
79
|
const parentOptions = super.options();
|
|
41
80
|
return options.concat(parentOptions);
|
|
@@ -44,9 +83,24 @@ class TeamsAppInstallCommand extends GraphCommand_1.default {
|
|
|
44
83
|
if (!Utils_1.default.isValidGuid(args.options.appId)) {
|
|
45
84
|
return `${args.options.appId} is not a valid GUID`;
|
|
46
85
|
}
|
|
47
|
-
if (!
|
|
86
|
+
if (!args.options.teamId &&
|
|
87
|
+
!args.options.userId &&
|
|
88
|
+
!args.options.userName) {
|
|
89
|
+
return `Specify either teamId, userId or userName`;
|
|
90
|
+
}
|
|
91
|
+
if ((args.options.teamId && args.options.userId) ||
|
|
92
|
+
(args.options.teamId && args.options.userName) ||
|
|
93
|
+
(args.options.userId && args.options.userName)) {
|
|
94
|
+
return `Specify either teamId, userId or userName but not multiple`;
|
|
95
|
+
}
|
|
96
|
+
if (args.options.teamId &&
|
|
97
|
+
!Utils_1.default.isValidGuid(args.options.teamId)) {
|
|
48
98
|
return `${args.options.teamId} is not a valid GUID`;
|
|
49
99
|
}
|
|
100
|
+
if (args.options.userId &&
|
|
101
|
+
!Utils_1.default.isValidGuid(args.options.userId)) {
|
|
102
|
+
return `${args.options.userId} is not a valid GUID`;
|
|
103
|
+
}
|
|
50
104
|
return true;
|
|
51
105
|
}
|
|
52
106
|
}
|
|
@@ -25,24 +25,27 @@ class TeamsAppListCommand extends GraphItemsListCommand_1.GraphItemsListCommand
|
|
|
25
25
|
if (args.options.teamId) {
|
|
26
26
|
return Promise.resolve(args.options.teamId);
|
|
27
27
|
}
|
|
28
|
-
const
|
|
29
|
-
url: `${this.resource}/v1.0/
|
|
28
|
+
const requestOptions = {
|
|
29
|
+
url: `${this.resource}/v1.0/groups?$filter=displayName eq '${encodeURIComponent(args.options.teamName)}'`,
|
|
30
30
|
headers: {
|
|
31
31
|
accept: 'application/json;odata.metadata=none'
|
|
32
32
|
},
|
|
33
33
|
responseType: 'json'
|
|
34
34
|
};
|
|
35
35
|
return request_1.default
|
|
36
|
-
.get(
|
|
36
|
+
.get(requestOptions)
|
|
37
37
|
.then(response => {
|
|
38
|
-
const
|
|
39
|
-
if (!
|
|
38
|
+
const groupItem = response.value[0];
|
|
39
|
+
if (!groupItem) {
|
|
40
|
+
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
41
|
+
}
|
|
42
|
+
if (groupItem.resourceProvisioningOptions.indexOf('Team') === -1) {
|
|
40
43
|
return Promise.reject(`The specified team does not exist in the Microsoft Teams`);
|
|
41
44
|
}
|
|
42
45
|
if (response.value.length > 1) {
|
|
43
46
|
return Promise.reject(`Multiple Microsoft Teams teams with name ${args.options.teamName} found: ${response.value.map(x => x.id)}`);
|
|
44
47
|
}
|
|
45
|
-
return Promise.resolve(
|
|
48
|
+
return Promise.resolve(groupItem.id);
|
|
46
49
|
});
|
|
47
50
|
}
|
|
48
51
|
getEndpointUrl(args) {
|
|
@@ -13,27 +13,64 @@ class TeamsAppUpdateCommand extends GraphCommand_1.default {
|
|
|
13
13
|
get description() {
|
|
14
14
|
return 'Updates Teams app in the organization\'s app catalog';
|
|
15
15
|
}
|
|
16
|
+
getTelemetryProperties(args) {
|
|
17
|
+
const telemetryProps = super.getTelemetryProperties(args);
|
|
18
|
+
telemetryProps.id = typeof args.options.id !== 'undefined';
|
|
19
|
+
telemetryProps.name = typeof args.options.name !== 'undefined';
|
|
20
|
+
return telemetryProps;
|
|
21
|
+
}
|
|
16
22
|
commandAction(logger, args, cb) {
|
|
17
|
-
const {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
23
|
+
const { filePath } = args.options;
|
|
24
|
+
this
|
|
25
|
+
.getAppId(args)
|
|
26
|
+
.then((appId) => {
|
|
27
|
+
const fullPath = path.resolve(filePath);
|
|
28
|
+
if (this.verbose) {
|
|
29
|
+
logger.logToStderr(`Updating app with id '${appId}' and file '${fullPath}' in the app catalog...`);
|
|
30
|
+
}
|
|
31
|
+
const requestOptions = {
|
|
32
|
+
url: `${this.resource}/v1.0/appCatalogs/teamsApps/${appId}`,
|
|
33
|
+
headers: {
|
|
34
|
+
"content-type": "application/zip"
|
|
35
|
+
},
|
|
36
|
+
data: fs.readFileSync(fullPath)
|
|
37
|
+
};
|
|
38
|
+
return request_1.default
|
|
39
|
+
.put(requestOptions);
|
|
40
|
+
})
|
|
41
|
+
.then(_ => cb(), (res) => this.handleRejectedODataJsonPromise(res, logger, cb));
|
|
42
|
+
}
|
|
43
|
+
getAppId(args) {
|
|
44
|
+
if (args.options.id) {
|
|
45
|
+
return Promise.resolve(args.options.id);
|
|
21
46
|
}
|
|
22
47
|
const requestOptions = {
|
|
23
|
-
url: `${this.resource}/v1.0/appCatalogs/teamsApps
|
|
48
|
+
url: `${this.resource}/v1.0/appCatalogs/teamsApps?$filter=displayName eq '${encodeURIComponent(args.options.name)}'`,
|
|
24
49
|
headers: {
|
|
25
|
-
|
|
50
|
+
accept: 'application/json;odata.metadata=none'
|
|
26
51
|
},
|
|
27
|
-
|
|
52
|
+
responseType: 'json'
|
|
28
53
|
};
|
|
29
|
-
request_1.default
|
|
30
|
-
.
|
|
31
|
-
.then(
|
|
54
|
+
return request_1.default
|
|
55
|
+
.get(requestOptions)
|
|
56
|
+
.then(response => {
|
|
57
|
+
const app = response.value[0];
|
|
58
|
+
if (!app) {
|
|
59
|
+
return Promise.reject(`The specified Teams app does not exist`);
|
|
60
|
+
}
|
|
61
|
+
if (response.value.length > 1) {
|
|
62
|
+
return Promise.reject(`Multiple Teams apps with name ${args.options.name} found. Please choose one of these ids: ${response.value.map(x => x.id).join(', ')}`);
|
|
63
|
+
}
|
|
64
|
+
return Promise.resolve(app.id);
|
|
65
|
+
});
|
|
32
66
|
}
|
|
33
67
|
options() {
|
|
34
68
|
const options = [
|
|
35
69
|
{
|
|
36
|
-
option: '-i, --id
|
|
70
|
+
option: '-i, --id [id]'
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
option: '-n, --name [name]'
|
|
37
74
|
},
|
|
38
75
|
{
|
|
39
76
|
option: '-p, --filePath <filePath>'
|
|
@@ -43,7 +80,13 @@ class TeamsAppUpdateCommand extends GraphCommand_1.default {
|
|
|
43
80
|
return options.concat(parentOptions);
|
|
44
81
|
}
|
|
45
82
|
validate(args) {
|
|
46
|
-
if (!
|
|
83
|
+
if (!args.options.id && !args.options.name) {
|
|
84
|
+
return 'Specify either id or name';
|
|
85
|
+
}
|
|
86
|
+
if (args.options.id && args.options.name) {
|
|
87
|
+
return 'Specify either id or name, but not both';
|
|
88
|
+
}
|
|
89
|
+
if (args.options.id && !Utils_1.default.isValidGuid(args.options.id)) {
|
|
47
90
|
return `${args.options.id} is not a valid GUID`;
|
|
48
91
|
}
|
|
49
92
|
const fullPath = path.resolve(args.options.filePath);
|
|
@@ -21,6 +21,7 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
|
|
|
21
21
|
telemetryProps.teamName = typeof args.options.teamName !== 'undefined';
|
|
22
22
|
telemetryProps.channelId = typeof args.options.channelId !== 'undefined';
|
|
23
23
|
telemetryProps.channelName = typeof args.options.channelName !== 'undefined';
|
|
24
|
+
telemetryProps.primary = (!(!args.options.primary)).toString();
|
|
24
25
|
return telemetryProps;
|
|
25
26
|
}
|
|
26
27
|
getTeamId(args) {
|
|
@@ -54,6 +55,9 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
|
|
|
54
55
|
if (args.options.channelId) {
|
|
55
56
|
return Promise.resolve(args.options.channelId);
|
|
56
57
|
}
|
|
58
|
+
if (args.options.primary) {
|
|
59
|
+
return Promise.resolve('');
|
|
60
|
+
}
|
|
57
61
|
const channelRequestOptions = {
|
|
58
62
|
url: `${this.resource}/v1.0/teams/${encodeURIComponent(this.teamId)}/channels?$filter=displayName eq '${encodeURIComponent(args.options.channelName)}'`,
|
|
59
63
|
headers: {
|
|
@@ -79,15 +83,21 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
|
|
|
79
83
|
return this.getChannelId(args);
|
|
80
84
|
})
|
|
81
85
|
.then((channelId) => {
|
|
86
|
+
let url = '';
|
|
87
|
+
if (args.options.primary) {
|
|
88
|
+
url = `${this.resource}/v1.0/teams/${encodeURIComponent(this.teamId)}/primaryChannel`;
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
url = `${this.resource}/v1.0/teams/${encodeURIComponent(this.teamId)}/channels/${encodeURIComponent(channelId)}`;
|
|
92
|
+
}
|
|
82
93
|
const requestOptions = {
|
|
83
|
-
url:
|
|
94
|
+
url: url,
|
|
84
95
|
headers: {
|
|
85
96
|
accept: 'application/json;odata.metadata=none'
|
|
86
97
|
},
|
|
87
98
|
responseType: 'json'
|
|
88
99
|
};
|
|
89
|
-
return request_1.default
|
|
90
|
-
.get(requestOptions);
|
|
100
|
+
return request_1.default.get(requestOptions);
|
|
91
101
|
})
|
|
92
102
|
.then((res) => {
|
|
93
103
|
logger.log(res);
|
|
@@ -107,6 +117,9 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
|
|
|
107
117
|
},
|
|
108
118
|
{
|
|
109
119
|
option: '--channelName [channelName]'
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
option: '--primary'
|
|
110
123
|
}
|
|
111
124
|
];
|
|
112
125
|
const parentOptions = super.options();
|
|
@@ -122,11 +135,20 @@ class TeamsChannelGetCommand extends GraphCommand_1.default {
|
|
|
122
135
|
if (args.options.teamId && !Utils_1.default.isValidGuid(args.options.teamId)) {
|
|
123
136
|
return `${args.options.teamId} is not a valid GUID`;
|
|
124
137
|
}
|
|
125
|
-
if (args.options.channelId && args.options.channelName) {
|
|
126
|
-
return 'Specify
|
|
138
|
+
if (args.options.channelId && args.options.channelName && args.options.primary) {
|
|
139
|
+
return 'Specify channelId, channelName or primary';
|
|
140
|
+
}
|
|
141
|
+
if (!args.options.channelId && args.options.channelName && args.options.primary) {
|
|
142
|
+
return 'Specify channelId, channelName or primary.';
|
|
143
|
+
}
|
|
144
|
+
if (args.options.channelId && !args.options.channelName && args.options.primary) {
|
|
145
|
+
return 'Specify channelId, channelName or primary.';
|
|
146
|
+
}
|
|
147
|
+
if (args.options.channelId && args.options.channelName && !args.options.primary) {
|
|
148
|
+
return 'Specify channelId, channelName or primary.';
|
|
127
149
|
}
|
|
128
|
-
if (!args.options.channelId && !args.options.channelName) {
|
|
129
|
-
return 'Specify channelId or
|
|
150
|
+
if (!args.options.channelId && !args.options.channelName && !args.options.primary) {
|
|
151
|
+
return 'Specify channelId, channelName or primary, one is required';
|
|
130
152
|
}
|
|
131
153
|
if (args.options.channelId && !Utils_1.default.isValidTeamsChannelId(args.options.channelId)) {
|
|
132
154
|
return `${args.options.channelId} is not a valid Teams ChannelId`;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const GraphItemsListCommand_1 = require("../../../base/GraphItemsListCommand");
|
|
4
|
+
const commands_1 = require("../../commands");
|
|
5
|
+
class TeamsChatListCommand extends GraphItemsListCommand_1.GraphItemsListCommand {
|
|
6
|
+
get name() {
|
|
7
|
+
return commands_1.default.CHAT_LIST;
|
|
8
|
+
}
|
|
9
|
+
get description() {
|
|
10
|
+
return 'Lists all chat conversations';
|
|
11
|
+
}
|
|
12
|
+
defaultProperties() {
|
|
13
|
+
return ['id', 'topic', 'chatType'];
|
|
14
|
+
}
|
|
15
|
+
commandAction(logger, args, cb) {
|
|
16
|
+
const filter = args.options.type !== undefined ? `?$filter=chatType eq '${args.options.type}'` : '';
|
|
17
|
+
const endpoint = `${this.resource}/v1.0/chats${filter}`;
|
|
18
|
+
this
|
|
19
|
+
.getAllItems(endpoint, logger, true)
|
|
20
|
+
.then(() => {
|
|
21
|
+
logger.log(this.items);
|
|
22
|
+
cb();
|
|
23
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
24
|
+
}
|
|
25
|
+
options() {
|
|
26
|
+
const options = [
|
|
27
|
+
{
|
|
28
|
+
option: '-t, --type [chatType]'
|
|
29
|
+
}
|
|
30
|
+
];
|
|
31
|
+
const parentOptions = super.options();
|
|
32
|
+
return options.concat(parentOptions);
|
|
33
|
+
}
|
|
34
|
+
validate(args) {
|
|
35
|
+
const supportedTypes = ['oneOnOne', 'group', 'meeting'];
|
|
36
|
+
if (args.options.type !== undefined && supportedTypes.indexOf(args.options.type) === -1) {
|
|
37
|
+
return `${args.options.type} is not a valid chatType. Accepted values are ${supportedTypes.join(', ')}`;
|
|
38
|
+
}
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
module.exports = new TeamsChatListCommand();
|
|
43
|
+
//# sourceMappingURL=chat-list.js.map
|