@strapi/strapi 4.6.0-beta.1 → 4.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +14 -10
- package/bin/strapi.js +101 -5
- package/ee/ee-store.js +18 -0
- package/ee/index.js +173 -0
- package/ee/license.js +102 -0
- package/{lib/utils → ee}/resources/key.pub +0 -0
- package/lib/Strapi.js +15 -5
- package/lib/commands/builders/admin.js +1 -1
- package/lib/commands/transfer/export.js +37 -36
- package/lib/commands/transfer/import.js +42 -50
- package/lib/commands/transfer/transfer.js +129 -0
- package/lib/commands/transfer/utils.js +93 -6
- package/lib/commands/utils/commander.js +76 -13
- package/lib/commands/utils/helpers.js +108 -0
- package/lib/core/loaders/plugins/index.js +9 -1
- package/lib/core-api/service/index.d.ts +1 -1
- package/lib/core-api/service/single-type.js +14 -1
- package/lib/services/entity-service/components.js +39 -36
- package/lib/services/entity-service/index.js +13 -2
- package/lib/services/errors.js +5 -1
- package/lib/services/event-hub.js +70 -8
- package/lib/services/metrics/index.js +3 -54
- package/lib/services/metrics/sender.js +1 -3
- package/lib/types/core/strapi/index.d.ts +5 -0
- package/lib/types/factories.d.ts +1 -1
- package/lib/utils/cron.js +56 -0
- package/lib/utils/ee.js +1 -121
- package/lib/utils/startup-logger.js +2 -4
- package/package.json +18 -17
- package/lib/commands/utils/index.js +0 -20
package/lib/utils/ee.js
CHANGED
|
@@ -1,123 +1,3 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
const fs = require('fs');
|
|
5
|
-
const crypto = require('crypto');
|
|
6
|
-
const _ = require('lodash');
|
|
7
|
-
|
|
8
|
-
const publicKey = fs.readFileSync(path.join(__dirname, '../utils/resources/key.pub'));
|
|
9
|
-
|
|
10
|
-
const noop = () => {};
|
|
11
|
-
|
|
12
|
-
const noLog = {
|
|
13
|
-
warn: noop,
|
|
14
|
-
info: noop,
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
-
const internals = {};
|
|
18
|
-
const features = {
|
|
19
|
-
bronze: [],
|
|
20
|
-
silver: [],
|
|
21
|
-
gold: ['sso'],
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
module.exports = ({ dir, logger = noLog }) => {
|
|
25
|
-
if (_.has(internals, 'isEE')) return internals.isEE;
|
|
26
|
-
|
|
27
|
-
const warnAndReturn = (msg = 'Invalid license. Starting in CE.') => {
|
|
28
|
-
logger.warn(msg);
|
|
29
|
-
internals.isEE = false;
|
|
30
|
-
return false;
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
if (process.env.STRAPI_DISABLE_EE === 'true') {
|
|
34
|
-
internals.isEE = false;
|
|
35
|
-
return false;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const licensePath = path.join(dir, 'license.txt');
|
|
39
|
-
|
|
40
|
-
let license;
|
|
41
|
-
if (_.has(process.env, 'STRAPI_LICENSE')) {
|
|
42
|
-
license = process.env.STRAPI_LICENSE;
|
|
43
|
-
} else if (fs.existsSync(licensePath)) {
|
|
44
|
-
license = fs.readFileSync(licensePath).toString();
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (_.isNil(license)) {
|
|
48
|
-
internals.isEE = false;
|
|
49
|
-
return false;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
try {
|
|
53
|
-
const plainLicense = Buffer.from(license, 'base64').toString();
|
|
54
|
-
const [signatureb64, contentb64] = plainLicense.split('\n');
|
|
55
|
-
|
|
56
|
-
const signature = Buffer.from(signatureb64, 'base64');
|
|
57
|
-
const content = Buffer.from(contentb64, 'base64').toString();
|
|
58
|
-
|
|
59
|
-
const verifier = crypto.createVerify('RSA-SHA256');
|
|
60
|
-
verifier.update(content);
|
|
61
|
-
verifier.end();
|
|
62
|
-
|
|
63
|
-
const isValid = verifier.verify(publicKey, signature);
|
|
64
|
-
if (!isValid) return warnAndReturn();
|
|
65
|
-
|
|
66
|
-
internals.licenseInfo = JSON.parse(content);
|
|
67
|
-
|
|
68
|
-
const expirationTime = new Date(internals.licenseInfo.expireAt).getTime();
|
|
69
|
-
if (expirationTime < new Date().getTime()) {
|
|
70
|
-
return warnAndReturn('License expired. Starting in CE');
|
|
71
|
-
}
|
|
72
|
-
} catch (err) {
|
|
73
|
-
return warnAndReturn();
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
internals.isEE = true;
|
|
77
|
-
return true;
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
Object.defineProperty(module.exports, 'licenseInfo', {
|
|
81
|
-
get() {
|
|
82
|
-
mustHaveKey('licenseInfo');
|
|
83
|
-
return internals.licenseInfo;
|
|
84
|
-
},
|
|
85
|
-
configurable: false,
|
|
86
|
-
enumerable: false,
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
Object.defineProperty(module.exports, 'isEE', {
|
|
90
|
-
get() {
|
|
91
|
-
mustHaveKey('isEE');
|
|
92
|
-
return internals.isEE;
|
|
93
|
-
},
|
|
94
|
-
configurable: false,
|
|
95
|
-
enumerable: false,
|
|
96
|
-
});
|
|
97
|
-
|
|
98
|
-
Object.defineProperty(module.exports, 'features', {
|
|
99
|
-
get() {
|
|
100
|
-
mustHaveKey('licenseInfo');
|
|
101
|
-
|
|
102
|
-
const { type: licenseType } = module.exports.licenseInfo;
|
|
103
|
-
|
|
104
|
-
return {
|
|
105
|
-
isEnabled(feature) {
|
|
106
|
-
return features[licenseType].includes(feature);
|
|
107
|
-
},
|
|
108
|
-
getEnabled() {
|
|
109
|
-
return features[licenseType];
|
|
110
|
-
},
|
|
111
|
-
};
|
|
112
|
-
},
|
|
113
|
-
configurable: false,
|
|
114
|
-
enumerable: false,
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
const mustHaveKey = (key) => {
|
|
118
|
-
if (!_.has(internals, key)) {
|
|
119
|
-
const err = new Error('Tampering with license');
|
|
120
|
-
// err.stack = null;
|
|
121
|
-
throw err;
|
|
122
|
-
}
|
|
123
|
-
};
|
|
3
|
+
module.exports = require('../../ee');
|
|
@@ -4,7 +4,6 @@ const chalk = require('chalk');
|
|
|
4
4
|
const CLITable = require('cli-table3');
|
|
5
5
|
const _ = require('lodash/fp');
|
|
6
6
|
const { getAbsoluteAdminUrl, getAbsoluteServerUrl } = require('@strapi/utils');
|
|
7
|
-
const ee = require('./ee');
|
|
8
7
|
|
|
9
8
|
module.exports = (app) => {
|
|
10
9
|
return {
|
|
@@ -19,15 +18,14 @@ module.exports = (app) => {
|
|
|
19
18
|
chars: { mid: '', 'left-mid': '', 'mid-mid': '', 'right-mid': '' },
|
|
20
19
|
});
|
|
21
20
|
|
|
22
|
-
const isEE = app.EE === true && ee.isEE === true;
|
|
23
|
-
|
|
24
21
|
infoTable.push(
|
|
25
22
|
[chalk.blue('Time'), `${new Date()}`],
|
|
26
23
|
[chalk.blue('Launched in'), `${Date.now() - app.config.launchedAt} ms`],
|
|
27
24
|
[chalk.blue('Environment'), app.config.environment],
|
|
28
25
|
[chalk.blue('Process PID'), process.pid],
|
|
29
26
|
[chalk.blue('Version'), `${app.config.info.strapi} (node ${process.version})`],
|
|
30
|
-
[chalk.blue('Edition'),
|
|
27
|
+
[chalk.blue('Edition'), app.EE ? 'Enterprise' : 'Community'],
|
|
28
|
+
[chalk.blue('Database'), app.db.dialect.client]
|
|
31
29
|
);
|
|
32
30
|
|
|
33
31
|
console.log(infoTable.toString());
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@strapi/strapi",
|
|
3
|
-
"version": "4.6.0
|
|
3
|
+
"version": "4.6.0",
|
|
4
4
|
"description": "An open source headless CMS solution to create and manage your own API. It provides a powerful dashboard and features to make your life easier. Databases supported: MySQL, MariaDB, PostgreSQL, SQLite",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"strapi",
|
|
@@ -71,7 +71,8 @@
|
|
|
71
71
|
},
|
|
72
72
|
"directories": {
|
|
73
73
|
"lib": "./lib",
|
|
74
|
-
"bin": "./bin"
|
|
74
|
+
"bin": "./bin",
|
|
75
|
+
"ee": "./ee"
|
|
75
76
|
},
|
|
76
77
|
"scripts": {
|
|
77
78
|
"postinstall": "node lib/utils/success.js",
|
|
@@ -80,26 +81,26 @@
|
|
|
80
81
|
"dependencies": {
|
|
81
82
|
"@koa/cors": "3.4.3",
|
|
82
83
|
"@koa/router": "10.1.1",
|
|
83
|
-
"@strapi/admin": "4.6.0
|
|
84
|
-
"@strapi/data-transfer": "4.6.0
|
|
85
|
-
"@strapi/database": "4.6.0
|
|
86
|
-
"@strapi/generate-new": "4.6.0
|
|
87
|
-
"@strapi/generators": "4.6.0
|
|
88
|
-
"@strapi/logger": "4.6.0
|
|
89
|
-
"@strapi/permissions": "4.6.0
|
|
90
|
-
"@strapi/plugin-content-manager": "4.6.0
|
|
91
|
-
"@strapi/plugin-content-type-builder": "4.6.0
|
|
92
|
-
"@strapi/plugin-email": "4.6.0
|
|
93
|
-
"@strapi/plugin-upload": "4.6.0
|
|
94
|
-
"@strapi/typescript-utils": "4.6.0
|
|
95
|
-
"@strapi/utils": "4.6.0
|
|
84
|
+
"@strapi/admin": "4.6.0",
|
|
85
|
+
"@strapi/data-transfer": "4.6.0",
|
|
86
|
+
"@strapi/database": "4.6.0",
|
|
87
|
+
"@strapi/generate-new": "4.6.0",
|
|
88
|
+
"@strapi/generators": "4.6.0",
|
|
89
|
+
"@strapi/logger": "4.6.0",
|
|
90
|
+
"@strapi/permissions": "4.6.0",
|
|
91
|
+
"@strapi/plugin-content-manager": "4.6.0",
|
|
92
|
+
"@strapi/plugin-content-type-builder": "4.6.0",
|
|
93
|
+
"@strapi/plugin-email": "4.6.0",
|
|
94
|
+
"@strapi/plugin-upload": "4.6.0",
|
|
95
|
+
"@strapi/typescript-utils": "4.6.0",
|
|
96
|
+
"@strapi/utils": "4.6.0",
|
|
96
97
|
"bcryptjs": "2.4.3",
|
|
97
98
|
"boxen": "5.1.2",
|
|
98
99
|
"chalk": "4.1.2",
|
|
99
100
|
"chokidar": "3.5.2",
|
|
100
101
|
"ci-info": "3.5.0",
|
|
101
102
|
"cli-table3": "0.6.2",
|
|
102
|
-
"commander": "8.
|
|
103
|
+
"commander": "8.3.0",
|
|
103
104
|
"configstore": "5.0.1",
|
|
104
105
|
"debug": "4.3.4",
|
|
105
106
|
"delegates": "1.0.0",
|
|
@@ -141,5 +142,5 @@
|
|
|
141
142
|
"node": ">=14.19.1 <=18.x.x",
|
|
142
143
|
"npm": ">=6.0.0"
|
|
143
144
|
},
|
|
144
|
-
"gitHead": "
|
|
145
|
+
"gitHead": "a9e55435c489f3379d88565bf3f729deb29bfb45"
|
|
145
146
|
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
const bytesPerKb = 1024;
|
|
4
|
-
const sizes = ['B ', 'KB', 'MB', 'GB', 'TB', 'PB'];
|
|
5
|
-
|
|
6
|
-
const readableBytes = (bytes, decimals = 1, padStart = 0) => {
|
|
7
|
-
if (!bytes) {
|
|
8
|
-
return '0';
|
|
9
|
-
}
|
|
10
|
-
const i = Math.floor(Math.log(bytes) / Math.log(bytesPerKb));
|
|
11
|
-
const result = `${parseFloat((bytes / bytesPerKb ** i).toFixed(decimals))} ${sizes[i].padStart(
|
|
12
|
-
2
|
|
13
|
-
)}`;
|
|
14
|
-
|
|
15
|
-
return result.padStart(padStart);
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
module.exports = {
|
|
19
|
-
readableBytes,
|
|
20
|
-
};
|