2
0
mirror of https://github.com/frappe/books.git synced 2024-09-20 11:29:00 +00:00
books/frappe/index.js
2018-01-03 22:08:17 +05:30

116 lines
2.5 KiB
JavaScript

const path = require('path');
const bodyParser = require('body-parser');
const express = require('express');
module.exports = {
async init() {
if (this._initialized) return;
this.init_config();
this.init_errors();
this.init_globals();
this.init_libs();
this._initialized = true;
// login as guest
this.login();
},
init_config() {
this.config = {
backend: 'sqlite'
};
},
init_errors() {
this.ValueError = class extends Error { };
},
init_globals() {
this.meta_cache = {};
},
init_libs() {
this.utils = require('./utils');
Object.assign(this, this.utils);
let models = require('./model/models');
this.models = new models.Models();
this.model = require('./model');
this.document = require('./model/document');
this.meta = require('./model/meta');
this.session_lib = require('./session');
this.rest_server = require('./rest_server');
},
init_app(app) {
this.app = app;
this.init_middleware();
this.rest_server.setup(this.app);
},
init_middleware() {
this.app.use(bodyParser.json());
this.app.use(bodyParser.urlencoded({ extended: true }));
this.app.use(express.static('frappe/client'));
},
async start(port=8000) {
await this.db.migrate();
this.server = this.app.listen(port);
},
async init_db(db_type, options) {
var Database;
switch (db_type) {
case 'sqlite':
Database = require('./backends/sqlite').Database;
break;
case 'rest':
Database = require('./backends/rest_client').Database;
break;
default:
throw new Error(`${db_type} is not a supported database type`);
}
this.db = new Database(options);
await this.db.connect();
},
get_meta(doctype) {
if (!this.meta_cache[doctype]) {
this.meta_cache[doctype] = new this.meta.Meta(this.models.get('DocType', doctype));
}
return this.meta_cache[doctype];
},
async get_doc(data, name) {
if (typeof data==='string' && typeof name==='string') {
let controller_class = this.models.get_controller(data);
var doc = new controller_class({doctype:data, name: name});
await doc.load();
} else {
let controller_class = this.models.get_controller(data.doctype);
var doc = new controller_class(data);
}
return doc;
},
async insert(data) {
const doc = await this.get_doc(data);
return await doc.insert();
},
login(user='guest', user_key) {
this.session = new this.session_lib.Session(user);
if (user && user_key) {
this.login(user_key);
}
},
close() {
this.db.close();
if (this.server) {
this.server.close();
}
}
};