UNPKG

nightscout

Version:

Nightscout acts as a web-based CGM (Continuous Glucose Monitor) to allow multiple caregivers to remotely view a patients glucose data in realtime.

89 lines (74 loc) 2.7 kB
'use strict'; var consts = require('../../constants'); function configure (app, wares, ctx) { var express = require('express'), api = express.Router( ); // invoke common middleware api.use(wares.sendJSONStatus); // text body types get handled as raw buffer stream api.use(wares.rawParser); // json body types get handled as parsed json api.use(wares.jsonParser); // also support url-encoded content-type api.use(wares.urlencodedParser); // text body types get handled as raw buffer stream // shortcut to use extension to specify output content-type api.use(ctx.authorization.isPermitted('api:food:read')); // List foods available api.get('/food/', function(req, res) { ctx.food.list(function (err, attribute) { return res.json(attribute); }); }); api.get('/food/quickpicks', function(req, res) { ctx.food.listquickpicks(function (err, attribute) { return res.json(attribute); }); }); api.get('/food/regular', function(req, res) { ctx.food.listregular(function (err, attribute) { return res.json(attribute); }); }); function config_authed (app, api, wares, ctx) { // create new record api.post('/food/', ctx.authorization.isPermitted('api:food:create'), function(req, res) { var data = req.body; ctx.food.create(data, function (err, created) { if (err) { res.sendJSONStatus(res, consts.HTTP_INTERNAL_ERROR, 'Mongo Error', err); console.log('Error creating food'); console.log(err); } else { res.json(created); console.log('food created',created); } }); }); // update record api.put('/food/', ctx.authorization.isPermitted('api:food:update'), function(req, res) { var data = req.body; ctx.food.save(data, function (err, created) { if (err) { res.sendJSONStatus(res, consts.HTTP_INTERNAL_ERROR, 'Mongo Error', err); console.log('Error saving food'); console.log(err); } else { res.json(created); console.log('food saved'); } }); }); // delete record api.delete('/food/:_id', ctx.authorization.isPermitted('api:food:delete'), function(req, res) { ctx.food.remove(req.params._id, function ( ) { res.json({ }); }); }); } if (app.enabled('api')) { config_authed(app, api, wares, ctx); } return api; } module.exports = configure;