Files
dbgate/plugins/dbgate-plugin-sqlite/src/frontend/drivers.js
Jan Prochazka d5c9fb8dec refactor
2025-03-14 15:04:53 +01:00

106 lines
2.9 KiB
JavaScript

// @ts-check
const { driverBase } = global.DBGATE_PACKAGES['dbgate-tools'];
const Dumper = require('./Dumper');
const { sqliteSplitterOptions, noSplitSplitterOptions } = require('dbgate-query-splitter/lib/options');
function getDatabaseFileLabel(databaseFile) {
if (!databaseFile) return databaseFile;
const m = databaseFile.match(/[\/]([^\/]+)$/);
if (m) return m[1];
return databaseFile;
}
/** @type {import('dbgate-types').SqlDialect} */
const dialect = {
limitSelect: true,
rangeSelect: true,
offsetFetchRangeSyntax: false,
explicitDropConstraint: true,
stringEscapeChar: "'",
fallbackDataType: 'nvarchar',
allowMultipleValuesInsert: true,
dropColumnDependencies: ['indexes', 'primaryKey', 'uniques'],
quoteIdentifier(s) {
return `[${s}]`;
},
anonymousPrimaryKey: true,
requireStandaloneSelectForScopeIdentity: true,
createColumn: true,
dropColumn: true,
createIndex: true,
dropIndex: true,
createForeignKey: false,
enableForeignKeyChecks: false,
dropForeignKey: false,
createPrimaryKey: false,
dropPrimaryKey: false,
dropReferencesWhenDropTable: false,
filteredIndexes: true,
anonymousForeignKey: true,
};
/** @type {import('dbgate-types').EngineDriver} */
const sqliteDriverBase = {
...driverBase,
dumperClass: Dumper,
dialect,
readOnlySessions: true,
supportsTransactions: true,
getQuerySplitterOptions: (usage) =>
usage == 'editor'
? { ...sqliteSplitterOptions, ignoreComments: true, preventSingleLineSplit: true }
: usage == 'stream'
? noSplitSplitterOptions
: sqliteSplitterOptions,
showConnectionTab: (field) => false,
predefinedDataTypes: ['integer', 'real', 'text', 'blob'],
};
/** @type {import('dbgate-types').EngineDriver} */
const driver = {
...sqliteDriverBase,
engine: 'sqlite@dbgate-plugin-sqlite',
title: 'SQLite',
showConnectionField: (field, values) => field == 'databaseFile' || field == 'isReadOnly',
beforeConnectionSave: (connection) => ({
...connection,
singleDatabase: true,
defaultDatabase: getDatabaseFileLabel(connection.databaseFile),
}),
// isFileDatabase: true,
// isElectronOnly: true,
};
/** @type {import('dbgate-types').EngineDriver} */
const libsqlDriver = {
...sqliteDriverBase,
engine: 'libsql@dbgate-plugin-sqlite',
title: 'LibSQL',
showConnectionField: (field, values) => {
if ((values?.authType ?? 'url') === 'url') {
return ['databaseUrl', 'authToken', 'isReadOnly', 'authType'].includes(field);
}
return ['databaseFile', 'isReadOnly', 'authType'].includes(field);
},
defaultAuthTypeName: 'url',
authTypeFirst: true,
beforeConnectionSave: (connection) => ({
...connection,
singleDatabase: true,
defaultDatabase: getDatabaseFileLabel(connection.databaseFile || connection.databaseUrl),
}),
// isFileDatabase: true,
// isElectronOnly: true,
};
module.exports = [driver, libsqlDriver];