@json-api/knex-adapter
Serve resources from your SQL database using json-api@3
.
Installation
npm i --save json-api@latest @json-api/knex-adapter
How to Use
const { ResourceTypeRegistry, ResourceController } = require('json-api');
const KnexAdapter = require('@json-api/knex-adapter');
const express = require('express');
const knex = require('knex');
const models = require('./models');
const connection = knex(config);
const dbAdapter = new Adapter(models, connection);
const defaults: ResourceTypeDescription = { dbAdapter, urlTemplates };
const registry = new ResourceTypeRegistry(resourceTypes, defaults);
const controller = new APIController(registry);
const docsController = new DocumentationController(new ResourceTypeRegistry({}), { name: 'My API' });
const Front = new ExpressStrategy(controller, docsController, { host: 'http://localhost:3000' });
const handler = Front.apiRequest;
const app = express();
app.get('/:type', handler);
app.listen(3000);
module.exports = {
posts: {
table: 'post',
idKey: '_id',
attrs: [ 'title', 'date' ],
relationships: [
{
type: 'authors',
key: 'author'
},
{
type: 'tags',
key: 'tags',
via: {
table: 'post_tag',
fk: 'post',
pk: 'tag'
}
},
{
type: 'readers',
key: 'favouriteOf',
via: {
table: 'reader',
fk: 'favouritePost',
pk: '_id'
}
}
]
}
}