Blame view

node_modules/loopback-phase/example/middleware.js 1.04 KB
f7563de62   Palak Handa   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
  // Copyright IBM Corp. 2014. All Rights Reserved.
  // Node module: loopback-phase
  // This file is licensed under the MIT License.
  // License text available at https://opensource.org/licenses/MIT
  
  var g = require('strong-globalize')();
  
  var PhaseList = require('../lib/phase-list');
  
  var phaseOrder = [
    'initial',
    'preprocess',
    'parse',
    'respond'
  ];
  
  var express = require('express');
  var app = express();
  var phases = new PhaseList();
  phases.add(phaseOrder);
  
  app.use(function(req, res, next) {
    // Run all handers in the phase list
    phases.run({
      req: req,
      res: res
    }, next);
  });
  
  function createLoggerForPhase(name) {
    return function logger(req, res, next) {
      g.log('Phase: %s, url: %s', name, req.url);
      next();
    };
  }
  
  phases.find('initial').use(function(ctx, cb) {
    createLoggerForPhase('intial')(ctx.req, ctx.res, cb);
  });
  
  phases.find('preprocess').use(function(ctx, cb) {
    createLoggerForPhase('preprocess')(ctx.req, ctx.res, cb);
  });
  
  app.get('/', function(req, res, next) {
    res.status(200).send('OK');
  });
  
  app.listen(3000);