@pnp/cli-microsoft365 5.1.0-beta.c8f5fd7 → 5.1.0-beta.efdacec
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 +1 -0
- package/dist/cli/index.js +5 -1
- package/dist/m365/aad/commands/app/app-add.js +68 -10
- package/dist/m365/aad/commands/app/app-role-delete.js +1 -1
- package/dist/m365/base/PowerPlatformCommand.js +10 -0
- package/dist/m365/pp/commands/managementapp/managementapp-add.js +98 -0
- package/dist/m365/pp/commands.js +7 -0
- package/dist/m365/spfx/commands/project/model/index.js +5 -1
- package/dist/m365/spfx/commands/project/project-externalize/index.js +5 -1
- package/dist/m365/spfx/commands/project/project-externalize/rules/index.js +5 -1
- package/dist/m365/spfx/commands/project/project-upgrade/index.js +5 -1
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN001033_DEP_tslib.js +14 -0
- package/dist/m365/spfx/commands/project/project-upgrade/rules/FN023002_GITIGNORE_heft.js +40 -0
- package/dist/m365/spfx/commands/project/project-upgrade/upgrade-1.15.0-beta.1.js +63 -0
- package/dist/m365/spfx/commands/project/project-upgrade.js +24 -19
- package/dist/m365/spo/commands/site/site-recyclebinitem-restore.js +66 -0
- package/dist/m365/spo/commands.js +1 -0
- package/dist/m365/teams/commands/chat/chat-message-send.js +50 -58
- package/dist/utils/formatting.js +3 -0
- package/dist/utils/index.js +5 -1
- package/docs/docs/cmd/pp/managementapp/managementapp-add.md +50 -0
- package/docs/docs/cmd/spfx/project/project-upgrade.md +1 -1
- package/docs/docs/cmd/spo/site/site-recyclebinitem-restore.md +27 -0
- package/docs/docs/cmd/teams/chat/chat-message-send.md +4 -4
- package/npm-shrinkwrap.json +173 -188
- package/package.json +10 -10
package/.eslintrc.js
CHANGED
package/dist/cli/index.js
CHANGED
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -58,6 +58,9 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
58
58
|
if (_appInfo.secret) {
|
|
59
59
|
appInfo.secret = _appInfo.secret;
|
|
60
60
|
}
|
|
61
|
+
if (_appInfo.secrets) {
|
|
62
|
+
appInfo.secrets = _appInfo.secrets;
|
|
63
|
+
}
|
|
61
64
|
logger.log(appInfo);
|
|
62
65
|
cb();
|
|
63
66
|
}, (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
|
|
@@ -111,6 +114,10 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
111
114
|
delete v2Manifest.id;
|
|
112
115
|
delete v2Manifest.appId;
|
|
113
116
|
delete v2Manifest.publisherDomain;
|
|
117
|
+
// extract secrets from the manifest. Store them in a separate variable
|
|
118
|
+
// and remove them from the manifest because we need to create them
|
|
119
|
+
// separately
|
|
120
|
+
const secrets = this.getSecretsFromManifest(v2Manifest);
|
|
114
121
|
// Azure Portal returns v2 manifest whereas the Graph API expects a v1.6
|
|
115
122
|
const graphManifest = this.transformManifest(v2Manifest);
|
|
116
123
|
const updateAppRequestOptions = {
|
|
@@ -124,7 +131,26 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
124
131
|
return request_1.default
|
|
125
132
|
.patch(updateAppRequestOptions)
|
|
126
133
|
.then(_ => this.updatePreAuthorizedAppsFromManifest(v2Manifest, appInfo))
|
|
127
|
-
.then(_ =>
|
|
134
|
+
.then(_ => this.createSecrets(secrets, appInfo));
|
|
135
|
+
}
|
|
136
|
+
getSecretsFromManifest(manifest) {
|
|
137
|
+
if (!manifest.passwordCredentials || manifest.passwordCredentials.length === 0) {
|
|
138
|
+
return [];
|
|
139
|
+
}
|
|
140
|
+
const secrets = manifest.passwordCredentials.map((c) => {
|
|
141
|
+
const startDate = new Date(c.startDate);
|
|
142
|
+
const endDate = new Date(c.endDate);
|
|
143
|
+
const expirationDate = new Date();
|
|
144
|
+
expirationDate.setMilliseconds(endDate.valueOf() - startDate.valueOf());
|
|
145
|
+
return {
|
|
146
|
+
name: c.displayName,
|
|
147
|
+
expirationDate
|
|
148
|
+
};
|
|
149
|
+
});
|
|
150
|
+
// delete the secrets from the manifest so that we won't try to set them
|
|
151
|
+
// from the manifest
|
|
152
|
+
delete manifest.passwordCredentials;
|
|
153
|
+
return secrets;
|
|
128
154
|
}
|
|
129
155
|
updatePreAuthorizedAppsFromManifest(manifest, appInfo) {
|
|
130
156
|
if (!manifest ||
|
|
@@ -153,6 +179,21 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
153
179
|
.patch(updateAppRequestOptions)
|
|
154
180
|
.then(_ => Promise.resolve(appInfo));
|
|
155
181
|
}
|
|
182
|
+
createSecrets(secrets, appInfo) {
|
|
183
|
+
if (secrets.length === 0) {
|
|
184
|
+
return Promise.resolve(appInfo);
|
|
185
|
+
}
|
|
186
|
+
return Promise
|
|
187
|
+
.all(secrets.map(secret => this.createSecret({
|
|
188
|
+
appObjectId: appInfo.id,
|
|
189
|
+
displayName: secret.name,
|
|
190
|
+
expirationDate: secret.expirationDate
|
|
191
|
+
})))
|
|
192
|
+
.then(secrets => {
|
|
193
|
+
appInfo.secrets = secrets;
|
|
194
|
+
return appInfo;
|
|
195
|
+
});
|
|
196
|
+
}
|
|
156
197
|
transformManifest(v2Manifest) {
|
|
157
198
|
var _a, _b, _c, _d;
|
|
158
199
|
const graphManifest = JSON.parse(JSON.stringify(v2Manifest));
|
|
@@ -187,7 +228,7 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
187
228
|
unsupportedProperties.forEach(p => delete graphManifest[p]);
|
|
188
229
|
graphManifest.api.acceptMappedClaims = v2Manifest.acceptMappedClaims;
|
|
189
230
|
delete graphManifest.acceptMappedClaims;
|
|
190
|
-
graphManifest.
|
|
231
|
+
graphManifest.isFallbackPublicClient = v2Manifest.allowPublicClient;
|
|
191
232
|
delete graphManifest.allowPublicClient;
|
|
192
233
|
graphManifest.info.termsOfServiceUrl = (_a = v2Manifest.informationalUrls) === null || _a === void 0 ? void 0 : _a.termsOfService;
|
|
193
234
|
graphManifest.info.supportUrl = (_b = v2Manifest.informationalUrls) === null || _b === void 0 ? void 0 : _b.support;
|
|
@@ -234,6 +275,11 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
234
275
|
}
|
|
235
276
|
graphManifest.web.homePageUrl = v2Manifest.signInUrl;
|
|
236
277
|
delete graphManifest.signInUrl;
|
|
278
|
+
if (graphManifest.appRoles) {
|
|
279
|
+
graphManifest.appRoles.forEach((role) => {
|
|
280
|
+
delete role.lang;
|
|
281
|
+
});
|
|
282
|
+
}
|
|
237
283
|
return graphManifest;
|
|
238
284
|
}
|
|
239
285
|
configureUri(args, appInfo, logger) {
|
|
@@ -357,27 +403,39 @@ class AadAppAddCommand extends GraphCommand_1.default {
|
|
|
357
403
|
if (this.verbose) {
|
|
358
404
|
logger.logToStderr(`Configure Azure AD app secret...`);
|
|
359
405
|
}
|
|
360
|
-
|
|
361
|
-
|
|
406
|
+
return this
|
|
407
|
+
.createSecret({ appObjectId: appInfo.id })
|
|
408
|
+
.then(secret => {
|
|
409
|
+
appInfo.secret = secret.value;
|
|
410
|
+
return Promise.resolve(appInfo);
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
createSecret({ appObjectId, displayName = undefined, expirationDate = undefined }) {
|
|
414
|
+
let secretExpirationDate = expirationDate;
|
|
415
|
+
if (!secretExpirationDate) {
|
|
416
|
+
secretExpirationDate = new Date();
|
|
417
|
+
secretExpirationDate.setFullYear(secretExpirationDate.getFullYear() + 1);
|
|
418
|
+
}
|
|
419
|
+
const secretName = displayName !== null && displayName !== void 0 ? displayName : 'Default';
|
|
362
420
|
const requestOptions = {
|
|
363
|
-
url: `${this.resource}/v1.0/myorganization/applications/${
|
|
421
|
+
url: `${this.resource}/v1.0/myorganization/applications/${appObjectId}/addPassword`,
|
|
364
422
|
headers: {
|
|
365
423
|
'content-type': 'application/json'
|
|
366
424
|
},
|
|
367
425
|
responseType: 'json',
|
|
368
426
|
data: {
|
|
369
427
|
passwordCredential: {
|
|
370
|
-
displayName:
|
|
428
|
+
displayName: secretName,
|
|
371
429
|
endDateTime: secretExpirationDate.toISOString()
|
|
372
430
|
}
|
|
373
431
|
}
|
|
374
432
|
};
|
|
375
433
|
return request_1.default
|
|
376
434
|
.post(requestOptions)
|
|
377
|
-
.then((password) => {
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
});
|
|
435
|
+
.then((password) => Promise.resolve({
|
|
436
|
+
displayName: secretName,
|
|
437
|
+
value: password.secretText
|
|
438
|
+
}));
|
|
381
439
|
}
|
|
382
440
|
saveAppInfo(args, appInfo, logger) {
|
|
383
441
|
if (!args.options.save) {
|
|
@@ -56,7 +56,7 @@ class AadAppRoleDeleteCommand extends GraphCommand_1.default {
|
|
|
56
56
|
if (this.verbose) {
|
|
57
57
|
logger.logToStderr(`Deleting role with ${appRoleDeleteIdentifierNameValue} from Azure AD app ${aadApp.id}...`);
|
|
58
58
|
}
|
|
59
|
-
// Find the role search criteria provided by the user.
|
|
59
|
+
// Find the role search criteria provided by the user.
|
|
60
60
|
const appRoleDeleteIdentifierProperty = args.options.name ? `displayName` : (args.options.claim ? `value` : `id`);
|
|
61
61
|
const appRoleDeleteIdentifierValue = args.options.name ? args.options.name : (args.options.claim ? args.options.claim : args.options.id);
|
|
62
62
|
const appRoleToDelete = aadApp.appRoles.filter((role) => role[appRoleDeleteIdentifierProperty] === appRoleDeleteIdentifierValue);
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const Command_1 = require("../../Command");
|
|
4
|
+
class PowerPlatformCommand extends Command_1.default {
|
|
5
|
+
get resource() {
|
|
6
|
+
return 'https://api.bap.microsoft.com';
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.default = PowerPlatformCommand;
|
|
10
|
+
//# sourceMappingURL=PowerPlatformCommand.js.map
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const utils_1 = require("../../../../utils");
|
|
5
|
+
const PowerPlatformCommand_1 = require("../../../base/PowerPlatformCommand");
|
|
6
|
+
const commands_1 = require("../../commands");
|
|
7
|
+
class PpManagementAppAddCommand extends PowerPlatformCommand_1.default {
|
|
8
|
+
get name() {
|
|
9
|
+
return commands_1.default.MANAGEMENTAPP_ADD;
|
|
10
|
+
}
|
|
11
|
+
get description() {
|
|
12
|
+
return 'Register management application for Power Platform';
|
|
13
|
+
}
|
|
14
|
+
getTelemetryProperties(args) {
|
|
15
|
+
const telemetryProps = super.getTelemetryProperties(args);
|
|
16
|
+
telemetryProps.appId = typeof args.options.appId !== 'undefined';
|
|
17
|
+
telemetryProps.objectId = typeof args.options.objectId !== 'undefined';
|
|
18
|
+
telemetryProps.name = typeof args.options.name !== 'undefined';
|
|
19
|
+
return telemetryProps;
|
|
20
|
+
}
|
|
21
|
+
commandAction(logger, args, cb) {
|
|
22
|
+
this
|
|
23
|
+
.getAppId(args)
|
|
24
|
+
.then((appId) => {
|
|
25
|
+
const requestOptions = {
|
|
26
|
+
// This should be refactored once we implement a PowerPlatform base class as api.bap will differ between envs.
|
|
27
|
+
url: `${this.resource}/providers/Microsoft.BusinessAppPlatform/adminApplications/${appId}?api-version=2020-06-01`,
|
|
28
|
+
headers: {
|
|
29
|
+
accept: 'application/json;odata.metadata=none'
|
|
30
|
+
},
|
|
31
|
+
responseType: 'json'
|
|
32
|
+
};
|
|
33
|
+
return request_1.default.put(requestOptions);
|
|
34
|
+
})
|
|
35
|
+
.then((res) => {
|
|
36
|
+
logger.log(res);
|
|
37
|
+
cb();
|
|
38
|
+
}, (err) => this.handleRejectedODataJsonPromise(err, logger, cb));
|
|
39
|
+
}
|
|
40
|
+
getAppId(args) {
|
|
41
|
+
if (args.options.appId) {
|
|
42
|
+
return Promise.resolve(args.options.appId);
|
|
43
|
+
}
|
|
44
|
+
const { objectId, name } = args.options;
|
|
45
|
+
const filter = objectId ?
|
|
46
|
+
`id eq '${encodeURIComponent(objectId)}'` :
|
|
47
|
+
`displayName eq '${encodeURIComponent(name)}'`;
|
|
48
|
+
const requestOptions = {
|
|
49
|
+
url: `https://graph.microsoft.com/v1.0/myorganization/applications?$filter=${filter}&$select=appId`,
|
|
50
|
+
headers: {
|
|
51
|
+
accept: 'application/json;odata.metadata=none'
|
|
52
|
+
},
|
|
53
|
+
responseType: 'json'
|
|
54
|
+
};
|
|
55
|
+
return request_1.default
|
|
56
|
+
.get((requestOptions))
|
|
57
|
+
.then((aadApps) => {
|
|
58
|
+
if (aadApps.value.length === 0) {
|
|
59
|
+
const applicationIdentifier = objectId ? `ID ${objectId}` : `name ${name}`;
|
|
60
|
+
return Promise.reject(`No Azure AD application registration with ${applicationIdentifier} found`);
|
|
61
|
+
}
|
|
62
|
+
if (aadApps.value.length === 1 && aadApps.value[0].appId) {
|
|
63
|
+
return Promise.resolve(aadApps.value[0].appId);
|
|
64
|
+
}
|
|
65
|
+
return Promise.reject(`Multiple Azure AD application registration with name ${name} found. Please disambiguate (app IDs): ${aadApps.value.map(a => a.appId).join(', ')}`);
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
options() {
|
|
69
|
+
const options = [
|
|
70
|
+
{ option: '--appId [appId]' },
|
|
71
|
+
{ option: '--objectId [objectId]' },
|
|
72
|
+
{ option: '--name [name]' }
|
|
73
|
+
];
|
|
74
|
+
const parentOptions = super.options();
|
|
75
|
+
return options.concat(parentOptions);
|
|
76
|
+
}
|
|
77
|
+
validate(args) {
|
|
78
|
+
if (!args.options.appId &&
|
|
79
|
+
!args.options.objectId &&
|
|
80
|
+
!args.options.name) {
|
|
81
|
+
return 'Specify either appId, objectId, or name';
|
|
82
|
+
}
|
|
83
|
+
if ((args.options.appId && args.options.objectId) ||
|
|
84
|
+
(args.options.appId && args.options.name) ||
|
|
85
|
+
(args.options.objectId && args.options.name)) {
|
|
86
|
+
return 'Specify either appId, objectId, or name but not both';
|
|
87
|
+
}
|
|
88
|
+
if (args.options.appId && !utils_1.validation.isValidGuid(args.options.appId)) {
|
|
89
|
+
return `${args.options.appId} is not a valid GUID`;
|
|
90
|
+
}
|
|
91
|
+
if (args.options.objectId && !utils_1.validation.isValidGuid(args.options.objectId)) {
|
|
92
|
+
return `${args.options.objectId} is not a valid GUID`;
|
|
93
|
+
}
|
|
94
|
+
return true;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
module.exports = new PpManagementAppAddCommand();
|
|
98
|
+
//# sourceMappingURL=managementapp-add.js.map
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FN001033_DEP_tslib = void 0;
|
|
4
|
+
const DependencyRule_1 = require("./DependencyRule");
|
|
5
|
+
class FN001033_DEP_tslib extends DependencyRule_1.DependencyRule {
|
|
6
|
+
constructor(packageVersion) {
|
|
7
|
+
super('tslib', packageVersion, false, false);
|
|
8
|
+
}
|
|
9
|
+
get id() {
|
|
10
|
+
return 'FN001033';
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.FN001033_DEP_tslib = FN001033_DEP_tslib;
|
|
14
|
+
//# sourceMappingURL=FN001033_DEP_tslib.js.map
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.FN023002_GITIGNORE_heft = void 0;
|
|
4
|
+
const Rule_1 = require("./Rule");
|
|
5
|
+
class FN023002_GITIGNORE_heft extends Rule_1.Rule {
|
|
6
|
+
constructor() {
|
|
7
|
+
super();
|
|
8
|
+
}
|
|
9
|
+
get id() {
|
|
10
|
+
return 'FN023002';
|
|
11
|
+
}
|
|
12
|
+
get title() {
|
|
13
|
+
return `.gitignore '.heft' folder`;
|
|
14
|
+
}
|
|
15
|
+
get description() {
|
|
16
|
+
return `To .gitignore add the '.heft' folder`;
|
|
17
|
+
}
|
|
18
|
+
get resolution() {
|
|
19
|
+
return `.heft`;
|
|
20
|
+
}
|
|
21
|
+
get resolutionType() {
|
|
22
|
+
return 'text';
|
|
23
|
+
}
|
|
24
|
+
get severity() {
|
|
25
|
+
return 'Required';
|
|
26
|
+
}
|
|
27
|
+
get file() {
|
|
28
|
+
return './.gitignore';
|
|
29
|
+
}
|
|
30
|
+
visit(project, findings) {
|
|
31
|
+
if (!project.gitignore) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (!/^\.heft$/m.test(project.gitignore.source)) {
|
|
35
|
+
this.addFinding(findings);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.FN023002_GITIGNORE_heft = FN023002_GITIGNORE_heft;
|
|
40
|
+
//# sourceMappingURL=FN023002_GITIGNORE_heft.js.map
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const FN001001_DEP_microsoft_sp_core_library_1 = require("./rules/FN001001_DEP_microsoft_sp_core_library");
|
|
4
|
+
const FN001002_DEP_microsoft_sp_lodash_subset_1 = require("./rules/FN001002_DEP_microsoft_sp_lodash_subset");
|
|
5
|
+
const FN001003_DEP_microsoft_sp_office_ui_fabric_core_1 = require("./rules/FN001003_DEP_microsoft_sp_office_ui_fabric_core");
|
|
6
|
+
const FN001004_DEP_microsoft_sp_webpart_base_1 = require("./rules/FN001004_DEP_microsoft_sp_webpart_base");
|
|
7
|
+
const FN001011_DEP_microsoft_sp_dialog_1 = require("./rules/FN001011_DEP_microsoft_sp_dialog");
|
|
8
|
+
const FN001012_DEP_microsoft_sp_application_base_1 = require("./rules/FN001012_DEP_microsoft_sp_application_base");
|
|
9
|
+
const FN001013_DEP_microsoft_decorators_1 = require("./rules/FN001013_DEP_microsoft_decorators");
|
|
10
|
+
const FN001014_DEP_microsoft_sp_listview_extensibility_1 = require("./rules/FN001014_DEP_microsoft_sp_listview_extensibility");
|
|
11
|
+
const FN001021_DEP_microsoft_sp_property_pane_1 = require("./rules/FN001021_DEP_microsoft_sp_property_pane");
|
|
12
|
+
const FN001022_DEP_office_ui_fabric_react_1 = require("./rules/FN001022_DEP_office_ui_fabric_react");
|
|
13
|
+
const FN001023_DEP_microsoft_sp_component_base_1 = require("./rules/FN001023_DEP_microsoft_sp_component_base");
|
|
14
|
+
const FN001024_DEP_microsoft_sp_diagnostics_1 = require("./rules/FN001024_DEP_microsoft_sp_diagnostics");
|
|
15
|
+
const FN001025_DEP_microsoft_sp_dynamic_data_1 = require("./rules/FN001025_DEP_microsoft_sp_dynamic_data");
|
|
16
|
+
const FN001026_DEP_microsoft_sp_extension_base_1 = require("./rules/FN001026_DEP_microsoft_sp_extension_base");
|
|
17
|
+
const FN001027_DEP_microsoft_sp_http_1 = require("./rules/FN001027_DEP_microsoft_sp_http");
|
|
18
|
+
const FN001028_DEP_microsoft_sp_list_subscription_1 = require("./rules/FN001028_DEP_microsoft_sp_list_subscription");
|
|
19
|
+
const FN001029_DEP_microsoft_sp_loader_1 = require("./rules/FN001029_DEP_microsoft_sp_loader");
|
|
20
|
+
const FN001030_DEP_microsoft_sp_module_interfaces_1 = require("./rules/FN001030_DEP_microsoft_sp_module_interfaces");
|
|
21
|
+
const FN001031_DEP_microsoft_sp_odata_types_1 = require("./rules/FN001031_DEP_microsoft_sp_odata_types");
|
|
22
|
+
const FN001032_DEP_microsoft_sp_page_context_1 = require("./rules/FN001032_DEP_microsoft_sp_page_context");
|
|
23
|
+
const FN001033_DEP_tslib_1 = require("./rules/FN001033_DEP_tslib");
|
|
24
|
+
const FN002001_DEVDEP_microsoft_sp_build_web_1 = require("./rules/FN002001_DEVDEP_microsoft_sp_build_web");
|
|
25
|
+
const FN002002_DEVDEP_microsoft_sp_module_interfaces_1 = require("./rules/FN002002_DEVDEP_microsoft_sp_module_interfaces");
|
|
26
|
+
const FN002007_DEVDEP_ajv_1 = require("./rules/FN002007_DEVDEP_ajv");
|
|
27
|
+
const FN002009_DEVDEP_microsoft_sp_tslint_rules_1 = require("./rules/FN002009_DEVDEP_microsoft_sp_tslint_rules");
|
|
28
|
+
const FN002013_DEVDEP_types_webpack_env_1 = require("./rules/FN002013_DEVDEP_types_webpack_env");
|
|
29
|
+
const FN006004_CFG_PS_developer_1 = require("./rules/FN006004_CFG_PS_developer");
|
|
30
|
+
const FN010001_YORC_version_1 = require("./rules/FN010001_YORC_version");
|
|
31
|
+
const FN023002_GITIGNORE_heft_1 = require("./rules/FN023002_GITIGNORE_heft");
|
|
32
|
+
module.exports = [
|
|
33
|
+
new FN001001_DEP_microsoft_sp_core_library_1.FN001001_DEP_microsoft_sp_core_library('1.15.0-beta.1'),
|
|
34
|
+
new FN001002_DEP_microsoft_sp_lodash_subset_1.FN001002_DEP_microsoft_sp_lodash_subset('1.15.0-beta.1'),
|
|
35
|
+
new FN001003_DEP_microsoft_sp_office_ui_fabric_core_1.FN001003_DEP_microsoft_sp_office_ui_fabric_core('1.15.0-beta.1'),
|
|
36
|
+
new FN001004_DEP_microsoft_sp_webpart_base_1.FN001004_DEP_microsoft_sp_webpart_base('1.15.0-beta.1'),
|
|
37
|
+
new FN001011_DEP_microsoft_sp_dialog_1.FN001011_DEP_microsoft_sp_dialog('1.15.0-beta.1'),
|
|
38
|
+
new FN001012_DEP_microsoft_sp_application_base_1.FN001012_DEP_microsoft_sp_application_base('1.15.0-beta.1'),
|
|
39
|
+
new FN001013_DEP_microsoft_decorators_1.FN001013_DEP_microsoft_decorators('1.15.0-beta.1'),
|
|
40
|
+
new FN001014_DEP_microsoft_sp_listview_extensibility_1.FN001014_DEP_microsoft_sp_listview_extensibility('1.15.0-beta.1'),
|
|
41
|
+
new FN001021_DEP_microsoft_sp_property_pane_1.FN001021_DEP_microsoft_sp_property_pane('1.15.0-beta.1'),
|
|
42
|
+
new FN001022_DEP_office_ui_fabric_react_1.FN001022_DEP_office_ui_fabric_react('7.181.1'),
|
|
43
|
+
new FN001023_DEP_microsoft_sp_component_base_1.FN001023_DEP_microsoft_sp_component_base('1.15.0-beta.1'),
|
|
44
|
+
new FN001024_DEP_microsoft_sp_diagnostics_1.FN001024_DEP_microsoft_sp_diagnostics('1.15.0-beta.1'),
|
|
45
|
+
new FN001025_DEP_microsoft_sp_dynamic_data_1.FN001025_DEP_microsoft_sp_dynamic_data('1.15.0-beta.1'),
|
|
46
|
+
new FN001026_DEP_microsoft_sp_extension_base_1.FN001026_DEP_microsoft_sp_extension_base('1.15.0-beta.1'),
|
|
47
|
+
new FN001027_DEP_microsoft_sp_http_1.FN001027_DEP_microsoft_sp_http('1.15.0-beta.1'),
|
|
48
|
+
new FN001028_DEP_microsoft_sp_list_subscription_1.FN001028_DEP_microsoft_sp_list_subscription('1.15.0-beta.1'),
|
|
49
|
+
new FN001029_DEP_microsoft_sp_loader_1.FN001029_DEP_microsoft_sp_loader('1.15.0-beta.1'),
|
|
50
|
+
new FN001030_DEP_microsoft_sp_module_interfaces_1.FN001030_DEP_microsoft_sp_module_interfaces('1.15.0-beta.1'),
|
|
51
|
+
new FN001031_DEP_microsoft_sp_odata_types_1.FN001031_DEP_microsoft_sp_odata_types('1.15.0-beta.1'),
|
|
52
|
+
new FN001032_DEP_microsoft_sp_page_context_1.FN001032_DEP_microsoft_sp_page_context('1.15.0-beta.1'),
|
|
53
|
+
new FN001033_DEP_tslib_1.FN001033_DEP_tslib('1.13.0'),
|
|
54
|
+
new FN002001_DEVDEP_microsoft_sp_build_web_1.FN002001_DEVDEP_microsoft_sp_build_web('1.15.0-beta.1'),
|
|
55
|
+
new FN002002_DEVDEP_microsoft_sp_module_interfaces_1.FN002002_DEVDEP_microsoft_sp_module_interfaces('1.15.0-beta.1'),
|
|
56
|
+
new FN002007_DEVDEP_ajv_1.FN002007_DEVDEP_ajv('6.12.5'),
|
|
57
|
+
new FN002009_DEVDEP_microsoft_sp_tslint_rules_1.FN002009_DEVDEP_microsoft_sp_tslint_rules('1.15.0-beta.1'),
|
|
58
|
+
new FN002013_DEVDEP_types_webpack_env_1.FN002013_DEVDEP_types_webpack_env('1.15.2'),
|
|
59
|
+
new FN006004_CFG_PS_developer_1.FN006004_CFG_PS_developer('1.15.0-beta.1'),
|
|
60
|
+
new FN010001_YORC_version_1.FN010001_YORC_version('1.15.0-beta.1'),
|
|
61
|
+
new FN023002_GITIGNORE_heft_1.FN023002_GITIGNORE_heft()
|
|
62
|
+
];
|
|
63
|
+
//# sourceMappingURL=upgrade-1.15.0-beta.1.js.map
|
|
@@ -3,6 +3,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
const fs = require("fs");
|
|
4
4
|
const os = require("os");
|
|
5
5
|
const path = require("path");
|
|
6
|
+
// uncomment to support upgrading to preview releases
|
|
7
|
+
const semver_1 = require("semver");
|
|
6
8
|
const Command_1 = require("../../../../Command");
|
|
7
9
|
const commands_1 = require("../../commands");
|
|
8
10
|
const base_project_command_1 = require("./base-project-command");
|
|
@@ -43,7 +45,8 @@ class SpfxProjectUpgradeCommand extends base_project_command_1.BaseProjectComman
|
|
|
43
45
|
'1.12.1',
|
|
44
46
|
'1.13.0',
|
|
45
47
|
'1.13.1',
|
|
46
|
-
'1.14.0'
|
|
48
|
+
'1.14.0',
|
|
49
|
+
'1.15.0-beta.1'
|
|
47
50
|
];
|
|
48
51
|
}
|
|
49
52
|
get name() {
|
|
@@ -56,9 +59,9 @@ class SpfxProjectUpgradeCommand extends base_project_command_1.BaseProjectComman
|
|
|
56
59
|
const telemetryProps = super.getTelemetryProperties(args);
|
|
57
60
|
telemetryProps.toVersion = args.options.toVersion || this.supportedVersions[this.supportedVersions.length - 1];
|
|
58
61
|
// uncomment to support upgrading to preview releases
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
+
if ((0, semver_1.prerelease)(telemetryProps.toVersion) && !args.options.preview) {
|
|
63
|
+
telemetryProps.toVersion = this.supportedVersions[this.supportedVersions.length - 2];
|
|
64
|
+
}
|
|
62
65
|
telemetryProps.packageManager = args.options.packageManager || 'npm';
|
|
63
66
|
telemetryProps.shell = args.options.shell || 'bash';
|
|
64
67
|
telemetryProps.preview = args.options.preview;
|
|
@@ -72,15 +75,15 @@ class SpfxProjectUpgradeCommand extends base_project_command_1.BaseProjectComman
|
|
|
72
75
|
}
|
|
73
76
|
this.toVersion = args.options.toVersion ? args.options.toVersion : this.supportedVersions[this.supportedVersions.length - 1];
|
|
74
77
|
// uncomment to support upgrading to preview releases
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
78
|
+
if (!args.options.toVersion &&
|
|
79
|
+
!args.options.preview &&
|
|
80
|
+
(0, semver_1.prerelease)(this.toVersion)) {
|
|
81
|
+
// no version and no preview specified while the current version to
|
|
82
|
+
// upgrade to is a prerelease so let's grab the first non-preview version
|
|
83
|
+
// since we're supporting only one preview version, it's sufficient for
|
|
84
|
+
// us to take second to last version
|
|
85
|
+
this.toVersion = this.supportedVersions[this.supportedVersions.length - 2];
|
|
86
|
+
}
|
|
84
87
|
this.packageManager = args.options.packageManager || 'npm';
|
|
85
88
|
this.shell = args.options.shell || 'bash';
|
|
86
89
|
if (this.supportedVersions.indexOf(this.toVersion) < 0) {
|
|
@@ -501,11 +504,11 @@ ${f.resolution}
|
|
|
501
504
|
},
|
|
502
505
|
{
|
|
503
506
|
option: '--packageManager [packageManager]',
|
|
504
|
-
autocomplete:
|
|
507
|
+
autocomplete: SpfxProjectUpgradeCommand.packageManagers
|
|
505
508
|
},
|
|
506
509
|
{
|
|
507
510
|
option: '--shell [shell]',
|
|
508
|
-
autocomplete:
|
|
511
|
+
autocomplete: SpfxProjectUpgradeCommand.shells
|
|
509
512
|
},
|
|
510
513
|
{
|
|
511
514
|
option: '--preview'
|
|
@@ -521,18 +524,20 @@ ${f.resolution}
|
|
|
521
524
|
}
|
|
522
525
|
validate(args) {
|
|
523
526
|
if (args.options.packageManager) {
|
|
524
|
-
if (
|
|
525
|
-
return `${args.options.packageManager} is not a supported package manager. Supported package managers are
|
|
527
|
+
if (SpfxProjectUpgradeCommand.packageManagers.indexOf(args.options.packageManager) < 0) {
|
|
528
|
+
return `${args.options.packageManager} is not a supported package manager. Supported package managers are ${SpfxProjectUpgradeCommand.packageManagers.join(', ')}`;
|
|
526
529
|
}
|
|
527
530
|
}
|
|
528
531
|
if (args.options.shell) {
|
|
529
|
-
if (
|
|
530
|
-
return `${args.options.shell} is not a supported shell. Supported shells are
|
|
532
|
+
if (SpfxProjectUpgradeCommand.shells.indexOf(args.options.shell) < 0) {
|
|
533
|
+
return `${args.options.shell} is not a supported shell. Supported shells are ${SpfxProjectUpgradeCommand.shells.join(', ')}`;
|
|
531
534
|
}
|
|
532
535
|
}
|
|
533
536
|
return true;
|
|
534
537
|
}
|
|
535
538
|
}
|
|
539
|
+
SpfxProjectUpgradeCommand.packageManagers = ['npm', 'pnpm', 'yarn'];
|
|
540
|
+
SpfxProjectUpgradeCommand.shells = ['bash', 'powershell', 'cmd'];
|
|
536
541
|
SpfxProjectUpgradeCommand.packageCommands = {
|
|
537
542
|
npm: {
|
|
538
543
|
install: 'npm i -SE',
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const request_1 = require("../../../../request");
|
|
4
|
+
const utils_1 = require("../../../../utils");
|
|
5
|
+
const SpoCommand_1 = require("../../../base/SpoCommand");
|
|
6
|
+
const commands_1 = require("../../commands");
|
|
7
|
+
class SpoSiteRecycleBinItemRestoreCommand extends SpoCommand_1.default {
|
|
8
|
+
get name() {
|
|
9
|
+
return commands_1.default.SITE_RECYCLEBINITEM_RESTORE;
|
|
10
|
+
}
|
|
11
|
+
get description() {
|
|
12
|
+
return 'Restores given items from the site recycle bin';
|
|
13
|
+
}
|
|
14
|
+
commandAction(logger, args, cb) {
|
|
15
|
+
if (this.verbose) {
|
|
16
|
+
logger.logToStderr(`Restoring items from recycle bin at ${args.options.siteUrl}...`);
|
|
17
|
+
}
|
|
18
|
+
const requestUrl = `${args.options.siteUrl}/_api/site/RecycleBin/RestoreByIds`;
|
|
19
|
+
const ids = utils_1.formatting.splitAndTrim(args.options.ids);
|
|
20
|
+
const idsChunks = [];
|
|
21
|
+
while (ids.length) {
|
|
22
|
+
idsChunks.push(ids.splice(0, 20));
|
|
23
|
+
}
|
|
24
|
+
Promise.all(idsChunks.map((idsChunk) => {
|
|
25
|
+
const requestOptions = {
|
|
26
|
+
url: requestUrl,
|
|
27
|
+
headers: {
|
|
28
|
+
'accept': 'application/json;odata=nometadata',
|
|
29
|
+
'content-type': 'application/json'
|
|
30
|
+
},
|
|
31
|
+
responseType: 'json',
|
|
32
|
+
data: {
|
|
33
|
+
ids: idsChunk
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
return request_1.default.post(requestOptions);
|
|
37
|
+
})).then(_ => cb(), (rawRes) => this.handleRejectedODataJsonPromise(rawRes, logger, cb));
|
|
38
|
+
}
|
|
39
|
+
options() {
|
|
40
|
+
const options = [
|
|
41
|
+
{
|
|
42
|
+
option: '-u, --siteUrl <siteUrl>'
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
option: '-i, --ids <ids>'
|
|
46
|
+
}
|
|
47
|
+
];
|
|
48
|
+
const parentOptions = super.options();
|
|
49
|
+
return options.concat(parentOptions);
|
|
50
|
+
}
|
|
51
|
+
validate(args) {
|
|
52
|
+
const isValidSharePointUrl = utils_1.validation.isValidSharePointUrl(args.options.siteUrl);
|
|
53
|
+
if (isValidSharePointUrl !== true) {
|
|
54
|
+
return isValidSharePointUrl;
|
|
55
|
+
}
|
|
56
|
+
const invalidIds = utils_1.formatting
|
|
57
|
+
.splitAndTrim(args.options.ids)
|
|
58
|
+
.filter(id => !utils_1.validation.isValidGuid(id));
|
|
59
|
+
if (invalidIds.length > 0) {
|
|
60
|
+
return `The following IDs are invalid: ${invalidIds.join(', ')}`;
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
module.exports = new SpoSiteRecycleBinItemRestoreCommand();
|
|
66
|
+
//# sourceMappingURL=site-recyclebinitem-restore.js.map
|
|
@@ -185,6 +185,7 @@ exports.default = {
|
|
|
185
185
|
SITE_LIST: `${prefix} site list`,
|
|
186
186
|
SITE_INPLACERECORDSMANAGEMENT_SET: `${prefix} site inplacerecordsmanagement set`,
|
|
187
187
|
SITE_RECYCLEBINITEM_LIST: `${prefix} site recyclebinitem list`,
|
|
188
|
+
SITE_RECYCLEBINITEM_RESTORE: `${prefix} site recyclebinitem restore`,
|
|
188
189
|
SITE_REMOVE: `${prefix} site remove`,
|
|
189
190
|
SITE_RENAME: `${prefix} site rename`,
|
|
190
191
|
SITE_SET: `${prefix} site set`,
|