mirror of
https://github.com/immich-app/immich.git
synced 2025-12-20 01:11:46 +03:00
feat: extension, triggers, functions, comments, parameters management in sql-tools (#17269)
feat: sql-tools extension, triggers, functions, comments, parameters
This commit is contained in:
@@ -0,0 +1,26 @@
|
||||
import { SqlTransformer } from 'src/sql-tools/to-sql/transformers/types';
|
||||
import { DatabaseExtension, SchemaDiff } from 'src/sql-tools/types';
|
||||
|
||||
export const transformExtensions: SqlTransformer = (item: SchemaDiff) => {
|
||||
switch (item.type) {
|
||||
case 'extension.create': {
|
||||
return asExtensionCreate(item.extension);
|
||||
}
|
||||
|
||||
case 'extension.drop': {
|
||||
return asExtensionDrop(item.extensionName);
|
||||
}
|
||||
|
||||
default: {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
const asExtensionCreate = (extension: DatabaseExtension): string => {
|
||||
return `CREATE EXTENSION IF NOT EXISTS "${extension.name}";`;
|
||||
};
|
||||
|
||||
const asExtensionDrop = (extensionName: string): string => {
|
||||
return `DROP EXTENSION "${extensionName}";`;
|
||||
};
|
||||
Reference in New Issue
Block a user