forked from strapi/migration-scripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathadminHelpers.js
104 lines (94 loc) · 2.99 KB
/
adminHelpers.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
const {
dbV3,
dbV4,
isPGSQL,
isSQLITE,
isMYSQL,
} = require("../../config/database");
const { BATCH_SIZE, SUPER_ADMIN } = require("./constants");
const { resetTableSequence } = require("./migrate");
const { migrateItems } = require("./migrateFields");
const { migrateUids } = require("./migrateValues");
const pluralize = require("pluralize");
const { camelCase } = require("lodash");
const extraV4Permissions = [
{ action: "admin::api-tokens.create", properties: {}, conditions: [] },
{ action: "admin::api-tokens.delete", properties: {}, conditions: [] },
{ action: "admin::api-tokens.read", properties: {}, conditions: [] },
{ action: "admin::api-tokens.update", properties: {}, conditions: [] },
];
function migrateSubject(subject) {
if (subject) {
return subject
.split(".")
.map((s) => migrateUids(pluralize(s, 1)))
.join(".");
}
return subject;
}
function migrateProperties(properties) {
if (properties && properties.fields) {
properties.fields = properties.fields.map((p) => camelCase(p));
return properties;
}
return properties;
}
async function migrateAdminPermissions() {
const source = "strapi_permission";
const destination = "admin_permissions";
const destinationLinks = "admin_permissions_role_links";
const count =
(await dbV3(source).count().first()).count ||
(await dbV3(source).count().first())["count(*)"];
console.log(`Migrating ${count} items from ${source} to ${destination}`);
await dbV4(destinationLinks).del();
await dbV4(destination).del();
for (var page = 0; page * BATCH_SIZE < count; page++) {
console.log(`${source} batch #${page + 1}`);
const items = await dbV3(source)
.limit(BATCH_SIZE)
.offset(page * BATCH_SIZE);
const migratedItems = migrateItems(items, ({ role, ...item }) => ({
...item,
action: migrateUids(item.action),
subject: migrateSubject(item.subject),
properties: migrateProperties(item.properties),
conditions: item.conditions,
}));
const roleLinks = items.map((item) => ({
permission_id: item.id,
role_id: item.role,
}));
await dbV4(destination).insert(migratedItems);
await dbV4(destinationLinks).insert(roleLinks);
}
await resetTableSequence(destination);
let ids = [];
if (isPGSQL) {
ids = await dbV4(destination).insert(extraV4Permissions).returning("id");
}
if (isSQLITE) {
ids = await dbV4(destination).insert(
extraV4Permissions.map((item) => ({
...item,
properties: JSON.stringify(item.properties),
conditions: JSON.stringify(item.conditions),
}))
);
}
if (isMYSQL) {
ids = await dbV4(destination).insert(
extraV4Permissions.map((item) => ({
...item,
properties: JSON.stringify(item.properties),
conditions: JSON.stringify(item.conditions),
}))
);
}
await dbV4(destinationLinks).insert(
ids.map((id) => ({ permission_id: id.id, role_id: SUPER_ADMIN }))
);
}
module.exports = {
migrateAdminPermissions,
};