163c546236
- Logs to stdout, disabled while testing - Change log calls signature when needed - Use development version of camshaft - Removes unused log cofiguration - Bind request id to log req/res - Log req at the begining of the cycle and res at the end
34 lines
1.1 KiB
JavaScript
34 lines
1.1 KiB
JavaScript
'use strict';
|
|
|
|
const NamedMapsCacheEntry = require('../../cache/model/named-maps-entry');
|
|
const NamedMapMapConfigProvider = require('../../models/mapconfig/provider/named-map-provider');
|
|
|
|
module.exports = function setSurrogateKeyHeader ({ surrogateKeysCache }) {
|
|
return function setSurrogateKeyHeaderMiddleware (req, res, next) {
|
|
const { user, mapConfigProvider } = res.locals;
|
|
|
|
if (mapConfigProvider instanceof NamedMapMapConfigProvider) {
|
|
surrogateKeysCache.tag(res, new NamedMapsCacheEntry(user, mapConfigProvider.getTemplateName()));
|
|
}
|
|
|
|
if (req.method !== 'GET') {
|
|
return next();
|
|
}
|
|
|
|
mapConfigProvider.getAffectedTables((err, affectedTables) => {
|
|
if (err) {
|
|
global.logger.warn(err, 'ERROR generating Surrogate Key Header');
|
|
return next();
|
|
}
|
|
|
|
if (!affectedTables || !affectedTables.tables || affectedTables.tables.length === 0) {
|
|
return next();
|
|
}
|
|
|
|
surrogateKeysCache.tag(res, affectedTables);
|
|
|
|
next();
|
|
});
|
|
};
|
|
};
|