Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/danilosampaio/dbrest
Create a REST API from your database models.
https://github.com/danilosampaio/dbrest
api model mssql orm postgresql rest
Last synced: about 22 hours ago
JSON representation
Create a REST API from your database models.
- Host: GitHub
- URL: https://github.com/danilosampaio/dbrest
- Owner: danilosampaio
- License: mit
- Created: 2017-10-10T12:58:05.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-12-29T20:45:07.000Z (about 2 years ago)
- Last Synced: 2024-12-29T22:07:46.262Z (about 1 month ago)
- Topics: api, model, mssql, orm, postgresql, rest
- Language: JavaScript
- Homepage:
- Size: 695 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 11
-
Metadata Files:
- Readme: readme.md
- License: license
Awesome Lists containing this project
README
# [![DBRest](assets/greeting.png)](assets/greeting.png)
## Install
```
$ npm install --save dbrest
```## Connection
> Supported databases: Postgresql and MSSQL.```js
const {DBRest, Model} = require('dbrest');
const dbrest = new DBRest({
dialect: 'postgresql',
connection: {
server: 'localhost',
port: '5432',
database: 'dbrest',
user: 'postgres',
password: 'postgres'
}
});
await dbrest.connect();
```## Database table example
[![Task](assets/task.png)](assets/task.png)
## Define your Model
> For a basic example, just create a class that extends `Model`.```js
class Task extends Model {}dbrest.loadModel(Task);
const router = dbrest.publish();//attach dbrest routes to your express app
app.use('/', router);
```## Result
> It creates a REST API for CRUD operations.HTTP Verb | Operation | Route
------------ | ------------- | -------------
GET | get tasks from database. | /task
POST | insert a task | /task
PUT | update a task | /task
DELETE | delete a task | /task> Aditional methods
HTTP Verb | Operation | Route
------------ | ------------- | -------------
GET | get task schema | /task/define
GET | get task schema and data | /task/fetch## Customize Model methods (find, insert, update, delete)
> let's see how to re-define the default methods##### find
```js
class Task extends Model {//re-define find to add a calculated column `foo`.
async find (params) {//`addWhereExpress` helps to generate `where` expression based on the request params
const statement = this.addWhereExpress(
`select id, title, status, 'foo' as calculated from Task`,
params
);
return await this.database.query(statement);
}
}
```##### insert
```js
class Task extends Model {//re-define insert to validate params
async insert (params) {if (params.status != 'backlog') {
throw new ModelError("a new task must be created with status 'backlog'.")
}super.insert(param);
}
}
```##### update
```js
class Task extends Model {//re-define update to log changes in console
async update (params) {console.log('[UPDATED] - ' + params);
super.update(params);
}
}
```##### delete
```js
class Task extends Model {//re-define delete to validate references
async delete (params) {
const id = params.id;
const reference = await this.database.query(`select id from event where taskId = ${id}`);
if (reference) {
throw new ModelError('this record is referenced by ' + reference.id);
}super.delete(params);
}
}
```## MSSQL connection example
```js
const dbrest = new DBRest({
dialect: 'mssql',
connection: {
userName: 'admin',
password: 'admin',
server: 'localhost',
options: {
database: 'MyDB',
instanceName: 'SQLSERVEREXPRESS',
rowCollectionOnRequestCompletion: true
}
}
});
```## API
### connect()
Connect to database and create a connections pool.
### loadModel(model)
#### model
*Required*
Type: `Object`Javascript class that extends Model.
### loadFrom(modelsDir)
#### modelsDir
*Required*
Type: `String`Directory path containing the Models.
### publish(middleware)
#### middleware
*Optional*
Type: `function`Express middleware function.
## Warning
This project is in development, so be careful and don't use it in production yet.
## License
MIT © [Danilo Sampaio](http://github.org/danilosampaio)