-
Notifications
You must be signed in to change notification settings - Fork 8
/
app.js
98 lines (80 loc) · 2.73 KB
/
app.js
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
'use strict';
/*
*
* Copyright 2016-2017 Red Hat, Inc, and individual contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
const logger = require('./logger.js');
const path = require('path');
const fs = require('fs');
const { promisify } = require('util');
const express = require('express');
const bodyParser = require('body-parser');
const readFile = promisify(fs.readFile);
const app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(express.static(path.join(__dirname, 'public')));
let configMap;
let message;
app.use('/api/greeting', (request, response) => {
const name = (request.query && request.query.name) ? request.query.name : 'World';
if (!message) {
response.status(500);
return response.send({ content: 'no config map' });
}
logger.debug('Replying to request, parameter={}', name);
return response.send({ content: message.replace(/%s/g, name) });
});
// Add basic health check endpoints
app.use('/ready', (request, response) => {
return response.sendStatus(200);
});
app.use('/live', (request, response) => {
return response.sendStatus(200);
});
// Periodic check for config map update
// If new configMap is found, then set new log level
setInterval(() => {
retrieveConfigfMap().then(config => {
if (!config) {
message = null;
return;
}
if (JSON.stringify(config) !== JSON.stringify(configMap)) {
configMap = config;
message = config.message;
// Set New log level
if (logger.level !== config.level.toLowerCase()) {
logger.info('New configuration retrieved: {}', config.message);
logger.info('New log level: {}', config.level.toLowerCase());
logger.level = config.level.toLowerCase();
}
}
}).catch(error => {
logger.error('Error getting config', error);
});
}, 2000);
// Get ConfigMap Stuff
const jsyaml = require('js-yaml');
// Find the Config Map
function retrieveConfigfMap () {
return readFile(process.env.NODE_CONFIGMAP_PATH, { encoding: 'utf8' }).then(configMap => {
// Parse the configMap, which is yaml
const configMapParsed = jsyaml.load(configMap);
return configMapParsed;
}).catch(error => logger.error(error));
}
module.exports = app;