mirror of
https://github.com/logto-io/logto.git
synced 2025-01-06 20:40:08 -05:00
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
|
import { type CommonQueryMethods, sql } from 'slonik';
|
||
|
|
||
|
import type { AlterationScript } from '../lib/types/alteration.js';
|
||
|
|
||
|
const getDatabaseName = async (pool: CommonQueryMethods) => {
|
||
|
const { currentDatabase } = await pool.one<{ currentDatabase: string }>(sql`
|
||
|
select current_database();
|
||
|
`);
|
||
|
|
||
|
return currentDatabase.replaceAll('-', '_');
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Grant read permission to the is_suspended column in the tenants table to the logto_tenant_<databaseName> role.
|
||
|
*/
|
||
|
const alteration: AlterationScript = {
|
||
|
up: async (pool) => {
|
||
|
const databaseName = await getDatabaseName(pool);
|
||
|
const baseRoleId = sql.identifier([`logto_tenant_${databaseName}`]);
|
||
|
|
||
|
await pool.query(sql`
|
||
|
grant select (is_suspended)
|
||
|
on table tenants
|
||
|
to ${baseRoleId}
|
||
|
`);
|
||
|
},
|
||
|
down: async (pool) => {
|
||
|
const databaseName = await getDatabaseName(pool);
|
||
|
const baseRoleId = sql.identifier([`logto_tenant_${databaseName}`]);
|
||
|
|
||
|
await pool.query(sql`
|
||
|
revoke select(is_suspended)
|
||
|
on table tenants
|
||
|
from ${baseRoleId}
|
||
|
`);
|
||
|
},
|
||
|
};
|
||
|
|
||
|
export default alteration;
|