2021-03-29 19:58:11 +02:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const async = require('async');
|
|
|
|
|
|
|
|
const settingsId = 'unleash.enterprise.api.keys';
|
|
|
|
|
2021-08-12 15:04:37 +02:00
|
|
|
const toApiToken = (legacyToken) => ({
|
2021-04-16 15:29:23 +02:00
|
|
|
secret: legacyToken.key,
|
|
|
|
username: legacyToken.username,
|
|
|
|
createdAt: legacyToken.created || new Date(),
|
2021-08-12 15:04:37 +02:00
|
|
|
type: legacyToken.priviliges.some((n) => n === 'ADMIN')
|
|
|
|
? 'admin'
|
|
|
|
: 'client',
|
2021-04-16 15:29:23 +02:00
|
|
|
});
|
2021-03-29 19:58:11 +02:00
|
|
|
|
2021-08-12 15:04:37 +02:00
|
|
|
exports.up = function (db, cb) {
|
2021-03-29 19:58:11 +02:00
|
|
|
db.runSql(
|
|
|
|
`SELECT * from settings where name = '${settingsId}';`,
|
|
|
|
(err, results) => {
|
|
|
|
if (results.rowCount === 1) {
|
|
|
|
const legacyTokens = results.rows[0].content.keys;
|
2021-08-12 15:04:37 +02:00
|
|
|
const inserts = legacyTokens.map(toApiToken).map((t) =>
|
2021-03-29 19:58:11 +02:00
|
|
|
db.runSql.bind(
|
|
|
|
db,
|
|
|
|
`INSERT INTO api_tokens (secret, username, type, created_at)
|
|
|
|
VALUES (?, ?, ?, ?)
|
|
|
|
ON CONFLICT DO NOTHING;`,
|
|
|
|
[t.secret, t.username, t.type, t.createdAt],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
async.series(inserts, cb);
|
|
|
|
} else {
|
|
|
|
cb();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2021-08-12 15:04:37 +02:00
|
|
|
exports.down = function (db, cb) {
|
2021-03-29 19:58:11 +02:00
|
|
|
cb();
|
|
|
|
};
|