add basic authentication

This commit is contained in:
Jonathan Rainville 2018-09-06 11:30:06 -04:00 committed by Pascal Precht
parent 46e647bba4
commit 422a98e172
No known key found for this signature in database
GPG Key ID: 0EE28D8D6FD85D7D
6 changed files with 52 additions and 1 deletions

View File

@ -13,6 +13,13 @@ function action(type, payload = {}) {
return {type, ...payload}; return {type, ...payload};
} }
export const AUTHENTICATE = createRequestTypes('AUTHENTICATE');
export const authenticate = {
request: (token) => action(AUTHENTICATE[REQUEST], {token}),
success: () => action(AUTHENTICATE[SUCCESS]),
failure: (error) => action(AUTHENTICATE[FAILURE], {error})
};
export const ACCOUNTS = createRequestTypes('ACCOUNTS'); export const ACCOUNTS = createRequestTypes('ACCOUNTS');
export const accounts = { export const accounts = {
request: () => action(ACCOUNTS[REQUEST]), request: () => action(ACCOUNTS[REQUEST]),

View File

@ -9,6 +9,7 @@ import routes from '../routes';
import { import {
initBlockHeader, initBlockHeader,
authenticate,
processes as processesAction, processes as processesAction,
versions as versionsAction, versions as versionsAction,
plugins as pluginsAction plugins as pluginsAction
@ -16,6 +17,7 @@ import {
class AppContainer extends Component { class AppContainer extends Component {
componentDidMount() { componentDidMount() {
this.props.authenticate('Test');
this.props.initBlockHeader(); this.props.initBlockHeader();
this.props.fetchProcesses(); this.props.fetchProcesses();
this.props.fetchVersions(); this.props.fetchVersions();
@ -34,6 +36,7 @@ class AppContainer extends Component {
} }
AppContainer.propTypes = { AppContainer.propTypes = {
authenticate: PropTypes.func,
initBlockHeader: PropTypes.func, initBlockHeader: PropTypes.func,
fetchProcesses: PropTypes.func, fetchProcesses: PropTypes.func,
fetchPlugins: PropTypes.func, fetchPlugins: PropTypes.func,
@ -44,8 +47,8 @@ export default connect(
null, null,
{ {
initBlockHeader, initBlockHeader,
authenticate: authenticate.request,
fetchProcesses: processesAction.request, fetchProcesses: processesAction.request,
fetchVersions: versionsAction.request, fetchVersions: versionsAction.request,
fetchPlugins: pluginsAction.request fetchPlugins: pluginsAction.request
}, },

View File

@ -39,6 +39,7 @@ export const fetchFile = doRequest.bind(null, actions.file, api.fetchFile);
export const postFile = doRequest.bind(null, actions.saveFile, api.postFile); export const postFile = doRequest.bind(null, actions.saveFile, api.postFile);
export const deleteFile = doRequest.bind(null, actions.removeFile, api.deleteFile); export const deleteFile = doRequest.bind(null, actions.removeFile, api.deleteFile);
export const fetchEthGas = doRequest.bind(null, actions.gasOracle, api.getEthGasAPI); export const fetchEthGas = doRequest.bind(null, actions.gasOracle, api.getEthGasAPI);
export const authenticate = doRequest.bind(null, actions.authenticate, api.authenticate);
export const fetchCurrentFile = doRequest.bind(null, actions.currentFile, storage.fetchCurrentFile); export const fetchCurrentFile = doRequest.bind(null, actions.currentFile, storage.fetchCurrentFile);
export const postCurrentFile = doRequest.bind(null, actions.saveCurrentFile, storage.postCurrentFile); export const postCurrentFile = doRequest.bind(null, actions.saveCurrentFile, storage.postCurrentFile);
@ -170,6 +171,10 @@ export function *watchFetchEthGas() {
yield takeEvery(actions.GAS_ORACLE[actions.REQUEST], fetchEthGas); yield takeEvery(actions.GAS_ORACLE[actions.REQUEST], fetchEthGas);
} }
export function *watchAuthenticate() {
yield takeEvery(actions.AUTHENTICATE[actions.REQUEST], authenticate);
}
function createChannel(socket) { function createChannel(socket) {
return eventChannel(emit => { return eventChannel(emit => {
socket.onmessage = ((message) => { socket.onmessage = ((message) => {
@ -279,6 +284,7 @@ export default function *root() {
fork(watchFetchCurrentFile), fork(watchFetchCurrentFile),
fork(watchPostCurrentFile), fork(watchPostCurrentFile),
fork(watchFetchEthGas), fork(watchFetchEthGas),
fork(watchAuthenticate),
fork(watchListenGasOracle) fork(watchListenGasOracle)
]); ]);
} }

View File

@ -138,6 +138,10 @@ export function deleteFile(payload) {
return destroy('/file', {params: payload}); return destroy('/file', {params: payload});
} }
export function authenticate(payload) {
return post('/authenticate', payload);
}
export function listenToChannel(channel) { export function listenToChannel(channel) {
return new WebSocket(`${constants.wsEndpoint}/communication/listenTo/${channel}`); return new WebSocket(`${constants.wsEndpoint}/communication/listenTo/${channel}`);
} }

View File

@ -230,6 +230,7 @@ class Engine {
webServerService() { webServerService() {
this.registerModule('webserver', {plugins: this.plugins}); this.registerModule('webserver', {plugins: this.plugins});
this.registerModule('authenticator');
} }
storageService(_options) { storageService(_options) {

View File

@ -0,0 +1,30 @@
const uuid = require('uuid/v1');
class Authenticator {
constructor(embark, _options) {
this.authToken = uuid();
embark.events.on('outputDone', () => {
embark.logger.info(__('Access the web backend with the following url: %s',
('http://localhost:8000/embark/' + this.authToken).underline));
});
embark.registerAPICall(
'post',
'/embark-api/authenticate',
(req, res) => {
if (req.body.token !== this.authToken) {
embark.logger.warn(__('Someone tried and failed to authenticate to the backend'));
embark.logger.warn(__('- User-Agent: %s', req.headers['user-agent']));
embark.logger.warn(__('- Referer: %s', req.headers.referer));
return res.status(403).send({error: __('Wrong authentication token')});
}
res.send();
}
);
}
}
module.exports = Authenticator;