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 | var qewd = require('qewd').master;
|
32 |
|
33 | function start(config) {
|
34 |
|
35 | var cookiePath = '/';
|
36 |
|
37 | var routes = [
|
38 | {
|
39 | path: '/api',
|
40 | module: 'qewd-ripple'
|
41 | }
|
42 | ];
|
43 |
|
44 | if (!config.webServerRootPath) config.webServerRootPath = process.cwd() + '/www';
|
45 | if (!config.database) config.database = {type: 'gtm'};
|
46 | if (!config.serverName) config.serverName = 'RippleOSI QEWD Server';
|
47 | if (!config.managementPassword) config.managementPassword = 'keepThisSecret!';
|
48 |
|
49 | var q = qewd.start(config, routes);
|
50 |
|
51 | if (config.auth0) {
|
52 | var passport = require('passport');
|
53 | var Auth0Strategy = require('passport-auth0');
|
54 |
|
55 | var strategy = new Auth0Strategy({
|
56 | domain: config.auth0.domain,
|
57 | clientID: config.auth0.clientID,
|
58 | clientSecret: config.auth0.clientSecret,
|
59 | callbackURL: config.auth0.callbackURL,
|
60 | },
|
61 | function(accessToken, refreshToken, extraParams, profile, done) {
|
62 | return done(null, profile);
|
63 | }
|
64 | );
|
65 |
|
66 | passport.use(strategy);
|
67 | passport.serializeUser(function(user, done) {
|
68 | done(null, user);
|
69 | });
|
70 | passport.deserializeUser(function(user, done) {
|
71 | done(null, user);
|
72 | });
|
73 |
|
74 | var failURL = config.auth0.failURL || '/fail.html';
|
75 | var callbackPath = config.auth0.callbackPath || '/auth0/token';
|
76 |
|
77 | var app = qewd.intercept().app;
|
78 | app.use(passport.initialize());
|
79 | app.use(passport.session());
|
80 | app.get(callbackPath,
|
81 | passport.authenticate('auth0', { failureRedirect: failURL }),
|
82 | function(req, res) {
|
83 | var message = {
|
84 | type: 'ewd-qoper8-express',
|
85 | expressType: 'auth0-register',
|
86 | application: 'qewd-ripple',
|
87 | params: req.user
|
88 | };
|
89 | q.handleMessage(message, function(response) {
|
90 | console.log('*** auth0-register response: ' + JSON.stringify(response));
|
91 | res.cookie('JSESSIONID', response.message.token, {path: cookiePath});
|
92 | res.redirect(config.auth0.indexURL);
|
93 | });
|
94 | }
|
95 | );
|
96 | q.userDefined['auth0'] = config.auth0;
|
97 | }
|
98 |
|
99 | var pasConfig = {
|
100 | openEHR: {
|
101 | pasModule: 'mysqlPAS',
|
102 | summaryHeadings: ['allergies', 'problems', 'medications', 'contacts', {name: 'transfers', value: true}]
|
103 | }
|
104 | };
|
105 | if (config.ripple && config.ripple.pas) pasConfig = config.ripple.pas;
|
106 |
|
107 | var pas = process.argv[2] || 'openEHR'
|
108 | q.userDefined['rippleUser'] = pasConfig[pas];
|
109 | var mode = 'demo';
|
110 | if (config.ripple && config.ripple.mode) mode = config.ripple.mode;
|
111 | q.userDefined['rippleMode'] = mode;
|
112 |
|
113 | q.userDefined['sessionTimeout'] = config.sessionTimeout || 900;
|
114 | q.userDefined.clinicalStatementsDocumentName = 'rippleClinStatements';
|
115 | q.userDefined.tocDocumentName = 'rippleTOC';
|
116 |
|
117 | }
|
118 |
|
119 | module.exports = {
|
120 | start: start
|
121 | };
|
122 |
|
123 |
|
124 |
|