@pnp/cli-microsoft365 6.0.0-beta.c5ce305 → 6.0.0-beta.cd80a69
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/.eslintrc.js +13 -0
- package/README.md +5 -0
- package/dist/appInsights.js +2 -0
- package/dist/m365/outlook/commands/mail/mail-send.js +1 -1
- package/dist/m365/pp/commands/Environment.js +3 -0
- package/dist/m365/pp/commands/card/card-list.js +68 -0
- package/dist/m365/pp/commands/dataverse/dataverse-table-list.js +69 -0
- package/dist/m365/pp/commands/environment/environment-get.js +75 -0
- package/dist/m365/pp/commands/solution/Solution.js +3 -0
- package/dist/m365/pp/commands/solution/solution-list.js +87 -0
- package/dist/m365/pp/commands/tenant/tenant-settings-list.js +45 -0
- package/dist/m365/pp/commands.js +6 -1
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.14.0.js +0 -2
- package/dist/m365/spfx/commands/spfx-doctor.js +37 -7
- package/dist/m365/spo/commands/eventreceiver/EventReceiver.js +3 -0
- package/dist/m365/spo/commands/eventreceiver/eventreceiver-remove.js +182 -0
- package/dist/m365/spo/commands/file/file-copy.js +25 -39
- package/dist/m365/spo/commands/file/file-move.js +24 -37
- package/dist/m365/spo/commands/file/file-rename.js +19 -16
- package/dist/m365/spo/commands/file/file-roleassignment-add.js +231 -0
- package/dist/m365/spo/commands/file/file-roleassignment-remove.js +180 -0
- package/dist/m365/spo/commands/file/file-roleinheritance-break.js +129 -0
- package/dist/m365/spo/commands/file/file-roleinheritance-reset.js +1 -1
- package/dist/m365/spo/commands/folder/folder-roleassignment-remove.js +168 -0
- package/dist/m365/spo/commands/folder/folder-roleinheritance-break.js +94 -0
- package/dist/m365/spo/commands/folder/folder-roleinheritance-reset.js +1 -1
- package/dist/m365/spo/commands/group/AssociatedGroupPropertiesCollection.js +3 -0
- package/dist/m365/spo/commands/group/group-list.js +49 -10
- package/dist/m365/spo/commands/list/list-contenttype-add.js +21 -18
- package/dist/m365/spo/commands/list/list-contenttype-default-set.js +59 -47
- package/dist/m365/spo/commands/list/list-contenttype-list.js +16 -8
- package/dist/m365/spo/commands/list/list-contenttype-remove.js +16 -8
- package/dist/m365/spo/commands/list/list-roleassignment-add.js +10 -10
- package/dist/m365/spo/commands/list/list-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands/list/list-webhook-add.js +19 -11
- package/dist/m365/spo/commands/list/list-webhook-get.js +17 -9
- package/dist/m365/spo/commands/list/list-webhook-list.js +23 -24
- package/dist/m365/spo/commands/list/list-webhook-remove.js +19 -11
- package/dist/m365/spo/commands/list/list-webhook-set.js +18 -10
- package/dist/m365/spo/commands/listitem/listitem-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands/web/web-roleassignment-add.js +10 -10
- package/dist/m365/spo/commands/web/web-roleassignment-remove.js +8 -8
- package/dist/m365/spo/commands.js +6 -0
- package/dist/m365/teams/commands/channel/channel-add.js +9 -9
- package/dist/m365/todo/commands/task/task-set.js +53 -1
- package/dist/utils/cache.js +81 -0
- package/dist/utils/pid.js +57 -0
- package/dist/utils/powerPlatform.js +42 -0
- package/docs/docs/cmd/pp/card/card-list.md +33 -0
- package/docs/docs/cmd/pp/dataverse/dataverse-table-list.md +33 -0
- package/docs/docs/cmd/pp/environment/environment-get.md +38 -0
- package/docs/docs/cmd/pp/environment/environment-list.md +1 -1
- package/docs/docs/cmd/pp/solution/solution-list.md +33 -0
- package/docs/docs/cmd/pp/tenant/tenant-settings-list.md +26 -0
- package/docs/docs/cmd/spfx/spfx-doctor.md +10 -1
- package/docs/docs/cmd/spo/eventreceiver/eventreceiver-get.md +2 -2
- package/docs/docs/cmd/spo/eventreceiver/eventreceiver-remove.md +69 -0
- package/docs/docs/cmd/spo/file/file-roleassignment-add.md +57 -0
- package/docs/docs/cmd/spo/file/file-roleassignment-remove.md +54 -0
- package/docs/docs/cmd/spo/file/file-roleinheritance-break.md +54 -0
- package/docs/docs/cmd/spo/folder/folder-roleassignment-remove.md +57 -0
- package/docs/docs/cmd/spo/folder/folder-roleinheritance-break.md +39 -0
- package/docs/docs/cmd/spo/folder/folder-roleinheritance-reset.md +2 -2
- package/docs/docs/cmd/spo/group/group-list.md +10 -1
- package/docs/docs/cmd/spo/hubsite/hubsite-disconnect.md +1 -1
- package/docs/docs/cmd/spo/hubsite/hubsite-get.md +3 -3
- package/docs/docs/cmd/spo/list/list-contenttype-add.md +15 -6
- package/docs/docs/cmd/spo/list/list-contenttype-default-set.md +16 -7
- package/docs/docs/cmd/spo/list/list-contenttype-list.md +15 -6
- package/docs/docs/cmd/spo/list/list-contenttype-remove.md +16 -7
- package/docs/docs/cmd/spo/list/list-webhook-add.md +15 -16
- package/docs/docs/cmd/spo/list/list-webhook-get.md +15 -6
- package/docs/docs/cmd/spo/list/list-webhook-list.md +16 -7
- package/docs/docs/cmd/spo/list/list-webhook-remove.md +12 -10
- package/docs/docs/cmd/spo/list/list-webhook-set.md +13 -11
- package/docs/docs/cmd/teams/channel/channel-add.md +4 -4
- package/docs/docs/cmd/todo/task/task-set.md +29 -2
- package/package.json +4 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN006006_CFG_PS_features.js +0 -60
package/.eslintrc.js
CHANGED
|
@@ -17,6 +17,7 @@ const dictionary = [
|
|
|
17
17
|
'content',
|
|
18
18
|
'conversation',
|
|
19
19
|
'custom',
|
|
20
|
+
'dataverse',
|
|
20
21
|
'default',
|
|
21
22
|
'external',
|
|
22
23
|
'externalize',
|
|
@@ -61,6 +62,7 @@ const dictionary = [
|
|
|
61
62
|
'site',
|
|
62
63
|
'status',
|
|
63
64
|
'storage',
|
|
65
|
+
'table',
|
|
64
66
|
'teams',
|
|
65
67
|
'token',
|
|
66
68
|
'type',
|
|
@@ -172,6 +174,17 @@ module.exports = {
|
|
|
172
174
|
"eqeqeq": [
|
|
173
175
|
"error",
|
|
174
176
|
"always"
|
|
177
|
+
],
|
|
178
|
+
"@typescript-eslint/naming-convention": [
|
|
179
|
+
"error",
|
|
180
|
+
{
|
|
181
|
+
"selector": [
|
|
182
|
+
"method"
|
|
183
|
+
],
|
|
184
|
+
"format": [
|
|
185
|
+
"camelCase"
|
|
186
|
+
]
|
|
187
|
+
}
|
|
175
188
|
]
|
|
176
189
|
},
|
|
177
190
|
"overrides": [
|
package/README.md
CHANGED
|
@@ -15,6 +15,11 @@
|
|
|
15
15
|
alt="GitHub" />
|
|
16
16
|
</a>
|
|
17
17
|
|
|
18
|
+
<a href="https://discord.com/invite/7rfW4kg6B5">
|
|
19
|
+
<img src="https://img.shields.io/badge/Discord-Join-7289da?style=flat-square"
|
|
20
|
+
alt="Discord" />
|
|
21
|
+
</a>
|
|
22
|
+
|
|
18
23
|
<a href="https://twitter.com/climicrosoft365">
|
|
19
24
|
<img src="https://img.shields.io/badge/Twitter-%40climicrosoft365-blue?style=flat-square"
|
|
20
25
|
alt="Twitter" />
|
package/dist/appInsights.js
CHANGED
|
@@ -10,6 +10,7 @@ const appInsights = require("applicationinsights");
|
|
|
10
10
|
const crypto = require("crypto");
|
|
11
11
|
const fs = require("fs");
|
|
12
12
|
const path = require("path");
|
|
13
|
+
const pid_1 = require("./utils/pid");
|
|
13
14
|
const config = appInsights.setup('6b908c80-d09f-4cf6-8274-e54349a0149a');
|
|
14
15
|
config.setInternalLogging(false, false);
|
|
15
16
|
// append -dev to the version number when ran locally
|
|
@@ -20,6 +21,7 @@ const env = process.env.CLIMICROSOFT365_ENV !== undefined ? process.env.CLIMICRO
|
|
|
20
21
|
appInsights.defaultClient.commonProperties = {
|
|
21
22
|
version: version,
|
|
22
23
|
node: process.version,
|
|
24
|
+
shell: pid_1.pid.getProcessName(process.ppid) || '',
|
|
23
25
|
env: env,
|
|
24
26
|
ci: Boolean(process.env.CI).toString()
|
|
25
27
|
};
|
|
@@ -129,7 +129,7 @@ _OutlookMailSendCommand_instances = new WeakSet(), _OutlookMailSendCommand_initT
|
|
|
129
129
|
if (args.options.bodyContentType &&
|
|
130
130
|
args.options.bodyContentType !== 'Text' &&
|
|
131
131
|
args.options.bodyContentType !== 'HTML') {
|
|
132
|
-
return `${args.options.
|
|
132
|
+
return `${args.options.bodyContentType} is not a valid value for the bodyContentType option. Allowed values are Text|HTML`;
|
|
133
133
|
}
|
|
134
134
|
if (args.options.saveToSentItems &&
|
|
135
135
|
args.options.saveToSentItems !== 'true' &&
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PpCardListCommand_instances, _PpCardListCommand_initTelemetry, _PpCardListCommand_initOptions;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const odata_1 = require("../../../../utils/odata");
|
|
19
|
+
const powerPlatform_1 = require("../../../../utils/powerPlatform");
|
|
20
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
21
|
+
const commands_1 = require("../../commands");
|
|
22
|
+
class PpCardListCommand extends PowerPlatformCommand_1.default {
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
_PpCardListCommand_instances.add(this);
|
|
26
|
+
__classPrivateFieldGet(this, _PpCardListCommand_instances, "m", _PpCardListCommand_initTelemetry).call(this);
|
|
27
|
+
__classPrivateFieldGet(this, _PpCardListCommand_instances, "m", _PpCardListCommand_initOptions).call(this);
|
|
28
|
+
}
|
|
29
|
+
get name() {
|
|
30
|
+
return commands_1.default.CARD_LIST;
|
|
31
|
+
}
|
|
32
|
+
get description() {
|
|
33
|
+
return 'Lists Microsoft Power Platform cards in the specified Power Platform environment.';
|
|
34
|
+
}
|
|
35
|
+
defaultProperties() {
|
|
36
|
+
return ['name', 'cardid', 'publishdate', 'createdon', 'modifiedon'];
|
|
37
|
+
}
|
|
38
|
+
commandAction(logger, args) {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
if (this.verbose) {
|
|
41
|
+
logger.logToStderr(`Retrieving list of cards`);
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
const dynamicsApiUrl = yield powerPlatform_1.powerPlatform.getDynamicsInstanceApiUrl(args.options.environment, args.options.asAdmin);
|
|
45
|
+
const items = yield odata_1.odata.getAllItems(`${dynamicsApiUrl}/api/data/v9.1/cards?$expand=owninguser($select=azureactivedirectoryobjectid,fullname)`);
|
|
46
|
+
logger.log(items);
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
this.handleRejectedODataJsonPromise(err);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
_PpCardListCommand_instances = new WeakSet(), _PpCardListCommand_initTelemetry = function _PpCardListCommand_initTelemetry() {
|
|
55
|
+
this.telemetry.push((args) => {
|
|
56
|
+
Object.assign(this.telemetryProperties, {
|
|
57
|
+
asAdmin: !!args.options.asAdmin
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
}, _PpCardListCommand_initOptions = function _PpCardListCommand_initOptions() {
|
|
61
|
+
this.options.unshift({
|
|
62
|
+
option: '-e, --environment <environment>'
|
|
63
|
+
}, {
|
|
64
|
+
option: '-a, --asAdmin'
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
module.exports = new PpCardListCommand();
|
|
68
|
+
//# sourceMappingURL=card-list.js.map
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PpDataverseTableListCommand_instances, _PpDataverseTableListCommand_initTelemetry, _PpDataverseTableListCommand_initOptions;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const odata_1 = require("../../../../utils/odata");
|
|
19
|
+
const powerPlatform_1 = require("../../../../utils/powerPlatform");
|
|
20
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
21
|
+
const commands_1 = require("../../commands");
|
|
22
|
+
class PpDataverseTableListCommand extends PowerPlatformCommand_1.default {
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
_PpDataverseTableListCommand_instances.add(this);
|
|
26
|
+
__classPrivateFieldGet(this, _PpDataverseTableListCommand_instances, "m", _PpDataverseTableListCommand_initTelemetry).call(this);
|
|
27
|
+
__classPrivateFieldGet(this, _PpDataverseTableListCommand_instances, "m", _PpDataverseTableListCommand_initOptions).call(this);
|
|
28
|
+
}
|
|
29
|
+
get name() {
|
|
30
|
+
return commands_1.default.DATAVERSE_TABLE_LIST;
|
|
31
|
+
}
|
|
32
|
+
get description() {
|
|
33
|
+
return 'Lists dataverse tables in a given environment';
|
|
34
|
+
}
|
|
35
|
+
defaultProperties() {
|
|
36
|
+
return ['SchemaName', 'EntitySetName', 'LogicalName', 'IsManaged'];
|
|
37
|
+
}
|
|
38
|
+
commandAction(logger, args) {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
if (this.verbose) {
|
|
41
|
+
logger.logToStderr(`Retrieving list of tables for which the user is an admin...`);
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
const dynamicsApiUrl = yield powerPlatform_1.powerPlatform.getDynamicsInstanceApiUrl(args.options.environment, args.options.asAdmin);
|
|
45
|
+
const endpoint = `${dynamicsApiUrl}/api/data/v9.0/EntityDefinitions?$select=MetadataId,IsCustomEntity,IsManaged,SchemaName,IconVectorName,LogicalName,EntitySetName,IsActivity,DataProviderId,IsRenameable,IsCustomizable,CanCreateForms,CanCreateViews,CanCreateCharts,CanCreateAttributes,CanChangeTrackingBeEnabled,CanModifyAdditionalSettings,CanChangeHierarchicalRelationship,CanEnableSyncToExternalSearchIndex&$filter=(IsIntersect eq false and IsLogicalEntity eq false and%0APrimaryNameAttribute ne null and PrimaryNameAttribute ne %27%27 and ObjectTypeCode gt 0 and%0AObjectTypeCode ne 4712 and ObjectTypeCode ne 4724 and ObjectTypeCode ne 9933 and ObjectTypeCode ne 9934 and%0AObjectTypeCode ne 9935 and ObjectTypeCode ne 9947 and ObjectTypeCode ne 9945 and ObjectTypeCode ne 9944 and%0AObjectTypeCode ne 9942 and ObjectTypeCode ne 9951 and ObjectTypeCode ne 2016 and ObjectTypeCode ne 9949 and%0AObjectTypeCode ne 9866 and ObjectTypeCode ne 9867 and ObjectTypeCode ne 9868) and (IsCustomizable/Value eq true or IsCustomEntity eq true or IsManaged eq false or IsMappable/Value eq true or IsRenameable/Value eq true)&api-version=9.1`;
|
|
46
|
+
const res = yield odata_1.odata.getAllItems(endpoint);
|
|
47
|
+
logger.log(res);
|
|
48
|
+
}
|
|
49
|
+
catch (err) {
|
|
50
|
+
this.handleRejectedODataJsonPromise(err);
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
_PpDataverseTableListCommand_instances = new WeakSet(), _PpDataverseTableListCommand_initTelemetry = function _PpDataverseTableListCommand_initTelemetry() {
|
|
56
|
+
this.telemetry.push((args) => {
|
|
57
|
+
Object.assign(this.telemetryProperties, {
|
|
58
|
+
asAdmin: !!args.options.asAdmin
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
}, _PpDataverseTableListCommand_initOptions = function _PpDataverseTableListCommand_initOptions() {
|
|
62
|
+
this.options.unshift({
|
|
63
|
+
option: '-e, --environment <environment>'
|
|
64
|
+
}, {
|
|
65
|
+
option: '-a, --asAdmin'
|
|
66
|
+
});
|
|
67
|
+
};
|
|
68
|
+
module.exports = new PpDataverseTableListCommand();
|
|
69
|
+
//# sourceMappingURL=dataverse-table-list.js.map
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PpEnvironmentGetCommand_instances, _PpEnvironmentGetCommand_initTelemetry, _PpEnvironmentGetCommand_initOptions;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
20
|
+
const commands_1 = require("../../commands");
|
|
21
|
+
class PpEnvironmentGetCommand extends PowerPlatformCommand_1.default {
|
|
22
|
+
constructor() {
|
|
23
|
+
super();
|
|
24
|
+
_PpEnvironmentGetCommand_instances.add(this);
|
|
25
|
+
__classPrivateFieldGet(this, _PpEnvironmentGetCommand_instances, "m", _PpEnvironmentGetCommand_initTelemetry).call(this);
|
|
26
|
+
__classPrivateFieldGet(this, _PpEnvironmentGetCommand_instances, "m", _PpEnvironmentGetCommand_initOptions).call(this);
|
|
27
|
+
}
|
|
28
|
+
get name() {
|
|
29
|
+
return commands_1.default.ENVIRONMENT_GET;
|
|
30
|
+
}
|
|
31
|
+
get description() {
|
|
32
|
+
return 'Gets information about the specified Power Platform environment';
|
|
33
|
+
}
|
|
34
|
+
defaultProperties() {
|
|
35
|
+
return ['name', 'id'];
|
|
36
|
+
}
|
|
37
|
+
commandAction(logger, args) {
|
|
38
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
39
|
+
let url = `${this.resource}/providers/Microsoft.BusinessAppPlatform/environments`;
|
|
40
|
+
if (args.options.asAdmin) {
|
|
41
|
+
url = `${this.resource}/providers/Microsoft.BusinessAppPlatform/scopes/admin/environments`;
|
|
42
|
+
}
|
|
43
|
+
const requestOptions = {
|
|
44
|
+
url: `${url}?api-version=2020-10-01`,
|
|
45
|
+
headers: {
|
|
46
|
+
accept: 'application/json'
|
|
47
|
+
},
|
|
48
|
+
responseType: 'json'
|
|
49
|
+
};
|
|
50
|
+
const res = yield request_1.default.get(requestOptions);
|
|
51
|
+
const environmentItem = res.value.filter((env) => {
|
|
52
|
+
return env.name === args.options.name;
|
|
53
|
+
})[0];
|
|
54
|
+
if (!environmentItem) {
|
|
55
|
+
throw `The specified Power Platform environment does not exist`;
|
|
56
|
+
}
|
|
57
|
+
logger.log(environmentItem);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
_PpEnvironmentGetCommand_instances = new WeakSet(), _PpEnvironmentGetCommand_initTelemetry = function _PpEnvironmentGetCommand_initTelemetry() {
|
|
62
|
+
this.telemetry.push((args) => {
|
|
63
|
+
Object.assign(this.telemetryProperties, {
|
|
64
|
+
asAdmin: !!args.options.asAdmin
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
}, _PpEnvironmentGetCommand_initOptions = function _PpEnvironmentGetCommand_initOptions() {
|
|
68
|
+
this.options.unshift({
|
|
69
|
+
option: '-n, --name <name>'
|
|
70
|
+
}, {
|
|
71
|
+
option: '-a, --asAdmin'
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
module.exports = new PpEnvironmentGetCommand();
|
|
75
|
+
//# sourceMappingURL=environment-get.js.map
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
12
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
13
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
|
+
};
|
|
16
|
+
var _PpSolutionListCommand_instances, _PpSolutionListCommand_initTelemetry, _PpSolutionListCommand_initOptions;
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const request_1 = require("../../../../request");
|
|
19
|
+
const powerPlatform_1 = require("../../../../utils/powerPlatform");
|
|
20
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
21
|
+
const commands_1 = require("../../commands");
|
|
22
|
+
class PpSolutionListCommand extends PowerPlatformCommand_1.default {
|
|
23
|
+
constructor() {
|
|
24
|
+
super();
|
|
25
|
+
_PpSolutionListCommand_instances.add(this);
|
|
26
|
+
__classPrivateFieldGet(this, _PpSolutionListCommand_instances, "m", _PpSolutionListCommand_initTelemetry).call(this);
|
|
27
|
+
__classPrivateFieldGet(this, _PpSolutionListCommand_instances, "m", _PpSolutionListCommand_initOptions).call(this);
|
|
28
|
+
}
|
|
29
|
+
get name() {
|
|
30
|
+
return commands_1.default.SOLUTION_LIST;
|
|
31
|
+
}
|
|
32
|
+
get description() {
|
|
33
|
+
return 'Lists solutions in a given environment.';
|
|
34
|
+
}
|
|
35
|
+
defaultProperties() {
|
|
36
|
+
return ['uniquename', 'version', 'publisher'];
|
|
37
|
+
}
|
|
38
|
+
commandAction(logger, args) {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
if (this.verbose) {
|
|
41
|
+
logger.logToStderr(`Retrieving list of solutions for which the user is an admin...`);
|
|
42
|
+
}
|
|
43
|
+
try {
|
|
44
|
+
const dynamicsApiUrl = yield powerPlatform_1.powerPlatform.getDynamicsInstanceApiUrl(args.options.environment, args.options.asAdmin);
|
|
45
|
+
const requestOptions = {
|
|
46
|
+
url: `${dynamicsApiUrl}/api/data/v9.0/solutions?$filter=isvisible eq true&$expand=publisherid($select=friendlyname)&$select=solutionid,uniquename,version,publisherid,installedon,solutionpackageversion,friendlyname,versionnumber&api-version=9.1`,
|
|
47
|
+
headers: {
|
|
48
|
+
accept: 'application/json;odata.metadata=none'
|
|
49
|
+
},
|
|
50
|
+
responseType: 'json'
|
|
51
|
+
};
|
|
52
|
+
const res = yield request_1.default.get(requestOptions);
|
|
53
|
+
if (!args.options.output || args.options.output === 'json') {
|
|
54
|
+
logger.log(res.value);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
//converted to text friendly output
|
|
58
|
+
logger.log(res.value.map(i => {
|
|
59
|
+
return {
|
|
60
|
+
uniquename: i.uniquename,
|
|
61
|
+
version: i.version,
|
|
62
|
+
publisher: i.publisherid.friendlyname
|
|
63
|
+
};
|
|
64
|
+
}));
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
this.handleRejectedODataJsonPromise(err);
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
_PpSolutionListCommand_instances = new WeakSet(), _PpSolutionListCommand_initTelemetry = function _PpSolutionListCommand_initTelemetry() {
|
|
74
|
+
this.telemetry.push((args) => {
|
|
75
|
+
Object.assign(this.telemetryProperties, {
|
|
76
|
+
asAdmin: !!args.options.asAdmin
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
}, _PpSolutionListCommand_initOptions = function _PpSolutionListCommand_initOptions() {
|
|
80
|
+
this.options.unshift({
|
|
81
|
+
option: '-e, --environment <environment>'
|
|
82
|
+
}, {
|
|
83
|
+
option: '-a, --asAdmin'
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
module.exports = new PpSolutionListCommand();
|
|
87
|
+
//# sourceMappingURL=solution-list.js.map
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
const request_1 = require("../../../../request");
|
|
13
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
14
|
+
const commands_1 = require("../../commands");
|
|
15
|
+
class PpTenantSettingsListCommand extends PowerPlatformCommand_1.default {
|
|
16
|
+
get name() {
|
|
17
|
+
return commands_1.default.TENANT_SETTINGS_LIST;
|
|
18
|
+
}
|
|
19
|
+
get description() {
|
|
20
|
+
return 'Lists the global Power Platform tenant settings';
|
|
21
|
+
}
|
|
22
|
+
defaultProperties() {
|
|
23
|
+
return ['disableCapacityAllocationByEnvironmentAdmins', 'disableEnvironmentCreationByNonAdminUsers', 'disableNPSCommentsReachout', 'disablePortalsCreationByNonAdminUsers', 'disableSupportTicketsVisibleByAllUsers', 'disableSurveyFeedback', 'disableTrialEnvironmentCreationByNonAdminUsers', 'walkMeOptOut'];
|
|
24
|
+
}
|
|
25
|
+
commandAction(logger) {
|
|
26
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
27
|
+
const requestOptions = {
|
|
28
|
+
url: `${this.resource}/providers/Microsoft.BusinessAppPlatform/listtenantsettings?api-version=2020-10-01`,
|
|
29
|
+
headers: {
|
|
30
|
+
accept: 'application/json'
|
|
31
|
+
},
|
|
32
|
+
responseType: 'json'
|
|
33
|
+
};
|
|
34
|
+
try {
|
|
35
|
+
const res = yield request_1.default.post(requestOptions);
|
|
36
|
+
logger.log(res);
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
this.handleRejectedODataJsonPromise(err);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
module.exports = new PpTenantSettingsListCommand();
|
|
45
|
+
//# sourceMappingURL=tenant-settings-list.js.map
|
package/dist/m365/pp/commands.js
CHANGED
|
@@ -2,9 +2,14 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const prefix = 'pp';
|
|
4
4
|
exports.default = {
|
|
5
|
+
CARD_LIST: `${prefix} card list`,
|
|
6
|
+
DATAVERSE_TABLE_LIST: `${prefix} dataverse table list`,
|
|
7
|
+
ENVIRONMENT_GET: `${prefix} environment get`,
|
|
5
8
|
ENVIRONMENT_LIST: `${prefix} environment list`,
|
|
6
9
|
GATEWAY_LIST: `${prefix} gateway list`,
|
|
7
10
|
MANAGEMENTAPP_ADD: `${prefix} managementapp add`,
|
|
8
|
-
MANAGEMENTAPP_LIST: `${prefix} managementapp list
|
|
11
|
+
MANAGEMENTAPP_LIST: `${prefix} managementapp list`,
|
|
12
|
+
SOLUTION_LIST: `${prefix} solution list`,
|
|
13
|
+
TENANT_SETTINGS_LIST: `${prefix} tenant settings list`
|
|
9
14
|
};
|
|
10
15
|
//# sourceMappingURL=commands.js.map
|
|
@@ -25,7 +25,6 @@ const FN002009_DEVDEP_microsoft_sp_tslint_rules_1 = require("./rules/FN002009_DE
|
|
|
25
25
|
const FN002019_DEVDEP_spfx_fast_serve_helpers_1 = require("./rules/FN002019_DEVDEP_spfx_fast_serve_helpers");
|
|
26
26
|
const FN006004_CFG_PS_developer_1 = require("./rules/FN006004_CFG_PS_developer");
|
|
27
27
|
const FN006005_CFG_PS_metadata_1 = require("./rules/FN006005_CFG_PS_metadata");
|
|
28
|
-
const FN006006_CFG_PS_features_1 = require("./rules/FN006006_CFG_PS_features");
|
|
29
28
|
const FN010001_YORC_version_1 = require("./rules/FN010001_YORC_version");
|
|
30
29
|
const FN014008_CODE_launch_hostedWorkbench_type_1 = require("./rules/FN014008_CODE_launch_hostedWorkbench_type");
|
|
31
30
|
module.exports = [
|
|
@@ -54,7 +53,6 @@ module.exports = [
|
|
|
54
53
|
new FN002019_DEVDEP_spfx_fast_serve_helpers_1.FN002019_DEVDEP_spfx_fast_serve_helpers('1.14.0'),
|
|
55
54
|
new FN006004_CFG_PS_developer_1.FN006004_CFG_PS_developer('1.14.0'),
|
|
56
55
|
new FN006005_CFG_PS_metadata_1.FN006005_CFG_PS_metadata(),
|
|
57
|
-
new FN006006_CFG_PS_features_1.FN006006_CFG_PS_features(),
|
|
58
56
|
new FN010001_YORC_version_1.FN010001_YORC_version('1.14.0'),
|
|
59
57
|
new FN014008_CODE_launch_hostedWorkbench_type_1.FN014008_CODE_launch_hostedWorkbench_type('pwa-chrome')
|
|
60
58
|
];
|
|
@@ -13,7 +13,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
|
|
|
13
13
|
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
14
14
|
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
15
15
|
};
|
|
16
|
-
var _SpfxDoctorCommand_instances, _SpfxDoctorCommand_initTelemetry, _SpfxDoctorCommand_initOptions, _SpfxDoctorCommand_initValidators
|
|
16
|
+
var _SpfxDoctorCommand_instances, _SpfxDoctorCommand_initTelemetry, _SpfxDoctorCommand_initOptions, _SpfxDoctorCommand_initValidators;
|
|
17
17
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
18
|
const chalk = require("chalk");
|
|
19
19
|
const child_process = require("child_process");
|
|
@@ -448,7 +448,6 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
448
448
|
__classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initTelemetry).call(this);
|
|
449
449
|
__classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initOptions).call(this);
|
|
450
450
|
__classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initValidators).call(this);
|
|
451
|
-
__classPrivateFieldGet(this, _SpfxDoctorCommand_instances, "m", _SpfxDoctorCommand_initTypes).call(this);
|
|
452
451
|
}
|
|
453
452
|
get name() {
|
|
454
453
|
return commands_1.default.DOCTOR;
|
|
@@ -457,6 +456,7 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
457
456
|
return 'Verifies environment configuration for using the specific version of the SharePoint Framework';
|
|
458
457
|
}
|
|
459
458
|
commandAction(logger, args) {
|
|
459
|
+
var _a;
|
|
460
460
|
return __awaiter(this, void 0, void 0, function* () {
|
|
461
461
|
if (!args.options.output) {
|
|
462
462
|
args.options.output = 'text';
|
|
@@ -469,7 +469,7 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
469
469
|
let prerequisites;
|
|
470
470
|
const fixes = [];
|
|
471
471
|
try {
|
|
472
|
-
spfxVersion = yield this.getSharePointFrameworkVersion(logger);
|
|
472
|
+
spfxVersion = (_a = args.options.spfxVersion) !== null && _a !== void 0 ? _a : yield this.getSharePointFrameworkVersion(logger);
|
|
473
473
|
if (!spfxVersion) {
|
|
474
474
|
logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework`));
|
|
475
475
|
throw `SharePoint Framework not found`;
|
|
@@ -479,7 +479,13 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
479
479
|
logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework v${spfxVersion}`));
|
|
480
480
|
throw `spfx doctor doesn't support SPFx v${spfxVersion} at this moment`;
|
|
481
481
|
}
|
|
482
|
-
|
|
482
|
+
if (args.options.spfxVersion) {
|
|
483
|
+
yield this.checkSharePointFrameworkVersion(args.options.spfxVersion, fixes, logger);
|
|
484
|
+
}
|
|
485
|
+
else {
|
|
486
|
+
// spfx was detected and if we are here, it means that we support it
|
|
487
|
+
logger.log(this.getStatus(CheckStatus.Success, `SharePoint Framework v${spfxVersion}`));
|
|
488
|
+
}
|
|
483
489
|
yield this.checkSharePointCompatibility(spfxVersion, prerequisites, args, fixes, logger);
|
|
484
490
|
yield this.checkNodeVersion(prerequisites, fixes, logger);
|
|
485
491
|
yield this.checkYo(prerequisites, fixes, logger);
|
|
@@ -532,6 +538,23 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
532
538
|
this.checkStatus('Node', nodeVersion, prerequisites.node, OptionalOrRequired.Required, fixes, logger);
|
|
533
539
|
});
|
|
534
540
|
}
|
|
541
|
+
checkSharePointFrameworkVersion(spfxVersionRequested, fixes, logger) {
|
|
542
|
+
return this
|
|
543
|
+
.getPackageVersion('@microsoft/generator-sharepoint', PackageSearchMode.GlobalOnly, HandlePromise.Continue, logger)
|
|
544
|
+
.then((spfxVersionDetected) => {
|
|
545
|
+
const versionCheck = {
|
|
546
|
+
range: spfxVersionRequested,
|
|
547
|
+
fix: `npm i -g @microsoft/generator-sharepoint@${spfxVersionRequested}`
|
|
548
|
+
};
|
|
549
|
+
if (spfxVersionDetected) {
|
|
550
|
+
this.checkStatus(`SharePoint Framework`, spfxVersionDetected, versionCheck, OptionalOrRequired.Required, fixes, logger);
|
|
551
|
+
}
|
|
552
|
+
else {
|
|
553
|
+
logger.log(this.getStatus(CheckStatus.Failure, `SharePoint Framework v${spfxVersionRequested} not found`));
|
|
554
|
+
fixes.push(versionCheck.fix);
|
|
555
|
+
}
|
|
556
|
+
});
|
|
557
|
+
}
|
|
535
558
|
checkYo(prerequisites, fixes, logger) {
|
|
536
559
|
return this
|
|
537
560
|
.getPackageVersion('yo', PackageSearchMode.GlobalOnly, HandlePromise.Continue, logger)
|
|
@@ -710,13 +733,17 @@ class SpfxDoctorCommand extends AnonymousCommand_1.default {
|
|
|
710
733
|
_SpfxDoctorCommand_instances = new WeakSet(), _SpfxDoctorCommand_initTelemetry = function _SpfxDoctorCommand_initTelemetry() {
|
|
711
734
|
this.telemetry.push((args) => {
|
|
712
735
|
Object.assign(this.telemetryProperties, {
|
|
713
|
-
env: args.options.env
|
|
736
|
+
env: args.options.env,
|
|
737
|
+
spfxVersion: args.options.spfxVersion
|
|
714
738
|
});
|
|
715
739
|
});
|
|
716
740
|
}, _SpfxDoctorCommand_initOptions = function _SpfxDoctorCommand_initOptions() {
|
|
717
741
|
this.options.unshift({
|
|
718
742
|
option: '-e, --env [env]',
|
|
719
743
|
autocomplete: ['sp2016', 'sp2019', 'spo']
|
|
744
|
+
}, {
|
|
745
|
+
option: '-v, --spfxVersion [spfxVersion]',
|
|
746
|
+
autocomplete: Object.keys(this.versions)
|
|
720
747
|
});
|
|
721
748
|
}, _SpfxDoctorCommand_initValidators = function _SpfxDoctorCommand_initValidators() {
|
|
722
749
|
this.validators.push((args) => __awaiter(this, void 0, void 0, function* () {
|
|
@@ -726,13 +753,16 @@ _SpfxDoctorCommand_instances = new WeakSet(), _SpfxDoctorCommand_initTelemetry =
|
|
|
726
753
|
return `${args.options.env} is not a valid SharePoint version. Valid versions are sp2016, sp2019 or spo`;
|
|
727
754
|
}
|
|
728
755
|
}
|
|
756
|
+
if (args.options.spfxVersion) {
|
|
757
|
+
if (!this.versions[args.options.spfxVersion]) {
|
|
758
|
+
return `${args.options.spfxVersion} is not a supported SharePoint Framework version. Supported versions are ${Object.keys(this.versions).join(', ')}`;
|
|
759
|
+
}
|
|
760
|
+
}
|
|
729
761
|
if (args.options.output && args.options.output !== 'text') {
|
|
730
762
|
return `The output option only accepts the type 'text'`;
|
|
731
763
|
}
|
|
732
764
|
return true;
|
|
733
765
|
}));
|
|
734
|
-
}, _SpfxDoctorCommand_initTypes = function _SpfxDoctorCommand_initTypes() {
|
|
735
|
-
this.types.string.push('e', 'env');
|
|
736
766
|
};
|
|
737
767
|
module.exports = new SpfxDoctorCommand();
|
|
738
768
|
//# sourceMappingURL=spfx-doctor.js.map
|