2024-03-16 19:04:55 +08:00
|
|
|
import { type CommonQueryMethods, sql } from '@silverhand/slonik';
|
2024-02-19 10:45:57 +08:00
|
|
|
|
|
|
|
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;
|