diff --git a/app.js b/app.js index e520d5b383..73b9528d9e 100644 --- a/app.js +++ b/app.js @@ -1,16 +1,17 @@ -var express = require('express'), - bodyParser = require('body-parser'), - log4js = require('log4js'), - logger = require('./lib/logger'), - routes = require('./lib/routes'), - eventApi = require('./lib/eventApi'), - featureApi = require('./lib/featureApi'), +var express = require('express'), + bodyParser = require('body-parser'), + cookieParser = require('cookie-parser'), + log4js = require('log4js'), + logger = require('./lib/logger'), + routes = require('./lib/routes'), + eventApi = require('./lib/eventApi'), + featureApi = require('./lib/featureApi'), featureArchiveApi = require('./lib/featureArchiveApi'), - strategyApi = require('./lib/strategyApi'), - validator = require('express-validator'), - app = express(), - router = express.Router(), - baseUriPath = process.env.BASE_URI_PATH || ''; + strategyApi = require('./lib/strategyApi'), + validator = require('express-validator'), + app = express(), + router = express.Router(), + baseUriPath = process.env.BASE_URI_PATH || ''; if(app.get('env') === 'development') { app.use(require('errorhandler')()); @@ -38,6 +39,8 @@ app.set('port', process.env.HTTP_PORT || process.env.PORT || 4242); app.use(baseUriPath, express.static(__dirname + '/public')); app.use(bodyParser.json({strict: false})); +app.use(cookieParser()); + eventApi(router); featureApi(router); featureArchiveApi(router); @@ -45,4 +48,4 @@ strategyApi(router); routes(router); app.use(baseUriPath, router); -module.exports = app; \ No newline at end of file +module.exports = app; diff --git a/lib/extractUser.js b/lib/extractUser.js new file mode 100644 index 0000000000..2da29b954e --- /dev/null +++ b/lib/extractUser.js @@ -0,0 +1,4 @@ +function extractUsername(req) { + return req.cookies.username || "unknown"; +} +module.exports = extractUsername; diff --git a/lib/featureApi.js b/lib/featureApi.js index 61ff4cfc1d..1593817699 100644 --- a/lib/featureApi.js +++ b/lib/featureApi.js @@ -7,6 +7,7 @@ var NameExistsError = require('./error/NameExistsError'); var NotFoundError = require('./error/NotFoundError'); var ValidationError = require('./error/ValidationError'); var validateRequest = require('./error/validateRequest'); +var extractUser = require('./extractUser'); module.exports = function (app) { @@ -33,7 +34,7 @@ module.exports = function (app) { .then(function() { return eventStore.create({ type: eventType.featureCreated, - createdBy: req.connection.remoteAddress, + createdBy: extractUser(req), data: req.body }); }) @@ -56,7 +57,7 @@ module.exports = function (app) { app.put('/features/:featureName', function (req, res) { var featureName = req.params.featureName; - var userName = req.connection.remoteAddress; + var userName = extractUser(req); var updatedFeature = req.body; updatedFeature.name = featureName; @@ -83,7 +84,7 @@ module.exports = function (app) { app.delete('/features/:featureName', function (req, res) { var featureName = req.params.featureName; - var userName = req.connection.remoteAddress; + var userName = extractUser(req); featureDb.getFeature(featureName) .then(function () { @@ -118,4 +119,3 @@ module.exports = function (app) { }); } }; - diff --git a/lib/strategyApi.js b/lib/strategyApi.js index 3b11e82ed8..a5ebb8fac0 100644 --- a/lib/strategyApi.js +++ b/lib/strategyApi.js @@ -5,7 +5,8 @@ var strategyDb = require('./strategyDb'); var logger = require('./logger'); var NameExistsError = require('./error/NameExistsError'); var ValidationError = require('./error/ValidationError'); -var validateRequest = require('./error/validateRequest'); +var validateRequest = require('./error/validateRequest'); +var extractUser = require('./extractUser'); module.exports = function (app) { @@ -24,7 +25,7 @@ module.exports = function (app) { app.delete('/strategies/:name', function (req, res) { eventStore.create({ type: eventType.strategyDeleted, - createdBy: req.connection.remoteAddress, + createdBy: extractUser(req), data: { name: req.params.name } @@ -44,7 +45,7 @@ module.exports = function (app) { .then(function() { return eventStore.create({ type: eventType.strategyCreated, - createdBy: req.connection.remoteAddress, + createdBy: extractUser(req), data: newStrategy }); }) @@ -75,4 +76,3 @@ module.exports = function (app) { } }; - diff --git a/package.json b/package.json index c24c85d044..7d4fb9c1de 100644 --- a/package.json +++ b/package.json @@ -35,6 +35,7 @@ "dependencies": { "bluebird": "2.6.2", "body-parser": "1.10.1", + "cookie-parser": "^1.3.3", "db-migrate": "0.7.1", "deep-diff": "^0.3.0", "errorhandler": "1.3.2", diff --git a/public/js/app.jsx b/public/js/app.jsx index 3c9f8253da..22a8ea2ee3 100644 --- a/public/js/app.jsx +++ b/public/js/app.jsx @@ -1,11 +1,14 @@ var React = require('react'); var TabView = require('./components/TabView'); var Menu = require('./components/Menu'); +var UserStore = require('./stores/UserStore'); var LogEntriesComponent = React.createFactory(require('./components/log/LogEntriesComponent')); var FeatureTogglesComponent = React.createFactory(require('./components/feature/FeatureTogglesComponent')); var StrategiesComponent = React.createFactory(require('./components/strategy/StrategiesComponent')); var ArchiveFeatureComponent = React.createFactory(require('./components/feature/ArchiveFeatureComponent')); +UserStore.init(); + var tabPanes = [ { name: 'Feature Toggles', @@ -40,4 +43,4 @@ React.render( , document.getElementById('content') -); \ No newline at end of file +); diff --git a/public/js/components/Menu.jsx b/public/js/components/Menu.jsx index 1015009110..b42b4dbd10 100644 --- a/public/js/components/Menu.jsx +++ b/public/js/components/Menu.jsx @@ -1,10 +1,14 @@ var React = require('react'); +var User = require('./User'); var Menu = React.createClass({ render: function() { return (