2
0
mirror of https://github.com/frappe/books.git synced 2025-01-27 09:08:24 +00:00
books/backends/sqlite.js

109 lines
2.6 KiB
JavaScript
Raw Normal View History

2018-01-16 11:39:17 +05:30
const frappe = require('frappejs');
const Database = require('./database');
2018-01-12 17:55:07 +05:30
2019-11-20 15:08:32 +05:30
class SqliteDatabase extends Database {
constructor({ dbPath }) {
super();
this.dbPath = dbPath;
2019-12-10 01:27:26 +05:30
this.connectionParams = {
client: 'sqlite3',
connection: {
filename: this.dbPath
},
pool: {
afterCreate(conn, done) {
conn.run('PRAGMA foreign_keys=ON');
done();
2019-01-12 17:40:52 +05:30
}
2019-12-10 01:27:26 +05:30
},
useNullAsDefault: true,
asyncStackTraces: process.env.NODE_ENV === 'development'
2019-12-10 01:27:26 +05:30
};
}
2018-01-31 18:34:46 +05:30
async addForeignKeys(doctype, newForeignKeys) {
2019-12-10 01:27:26 +05:30
await this.sql('PRAGMA foreign_keys=OFF');
await this.sql('BEGIN TRANSACTION');
2018-02-20 15:23:38 +05:30
2019-12-10 01:27:26 +05:30
const tempName = 'TEMP' + doctype;
2018-03-05 22:15:21 +05:30
// create temp table
await this.createTable(doctype, tempName);
2018-03-05 22:15:21 +05:30
// copy from old to new table
2019-12-10 01:27:26 +05:30
await this.knex(tempName).insert(this.knex.select().from(doctype));
2018-02-20 15:23:38 +05:30
// drop old table
2019-12-10 01:27:26 +05:30
await this.knex.schema.dropTable(doctype);
2018-02-20 15:23:38 +05:30
// rename new table
2019-12-10 01:27:26 +05:30
await this.knex.schema.renameTable(tempName, doctype);
2018-02-20 15:23:38 +05:30
2019-12-10 01:27:26 +05:30
await this.sql('COMMIT');
await this.sql('PRAGMA foreign_keys=ON');
}
2018-02-20 15:23:38 +05:30
removeColumns() {
// pass
}
2018-03-05 22:15:21 +05:30
async getTableColumns(doctype) {
return (await this.sql(`PRAGMA table_info(${doctype})`)).map(d => d.name);
}
async getForeignKeys(doctype) {
2019-12-10 01:27:26 +05:30
return (await this.sql(`PRAGMA foreign_key_list(${doctype})`)).map(
d => d.from
);
}
initTypeMap() {
2019-12-10 01:27:26 +05:30
// prettier-ignore
this.typeMap = {
2019-12-10 01:27:26 +05:30
'AutoComplete': 'text',
'Currency': 'float',
'Int': 'integer',
'Float': 'float',
'Percent': 'float',
'Check': 'integer',
'Small Text': 'text',
'Long Text': 'text',
'Code': 'text',
'Text Editor': 'text',
'Date': 'text',
'Datetime': 'text',
'Time': 'text',
'Text': 'text',
'Data': 'text',
'Link': 'text',
'DynamicLink': 'text',
'Password': 'text',
'Select': 'text',
'Read Only': 'text',
'File': 'text',
'Attach': 'text',
'AttachImage': 'text',
'Signature': 'text',
'Color': 'text',
'Barcode': 'text',
'Geolocation': 'text'
};
}
2019-11-15 13:14:45 +05:30
2019-11-20 15:08:32 +05:30
getError(err) {
let errorType = frappe.errors.DatabaseError;
2019-11-20 15:08:32 +05:30
if (err.message.includes('FOREIGN KEY')) {
errorType = frappe.errors.LinkValidationError;
2019-11-20 15:08:32 +05:30
}
if (err.message.includes('SQLITE_ERROR: cannot commit')) {
errorType = frappe.errors.CannotCommitError;
2019-11-20 15:08:32 +05:30
}
if (err.message.includes('SQLITE_CONSTRAINT: UNIQUE constraint failed:')) {
errorType = frappe.errors.DuplicateEntryError;
}
return errorType;
2019-11-15 13:14:45 +05:30
}
2018-01-12 17:55:07 +05:30
}
2019-11-20 15:08:32 +05:30
module.exports = SqliteDatabase;