1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

Added view for client-instances

This commit is contained in:
ivaosthu 2016-11-04 23:02:55 +01:00 committed by Ivar Conradi Østhus
parent 891b2ba3f0
commit c836d45f80
12 changed files with 129 additions and 36 deletions

View File

@ -8,7 +8,6 @@ module.exports = class UnleashClientMetrics {
this.globalCount = 0;
this.apps = {};
this.clients = {};
this.strategies = {};
this.buckets = {};
this.hourProjectionValue = new Projection();
@ -29,7 +28,6 @@ module.exports = class UnleashClientMetrics {
globalCount: this.globalCount,
apps: this.apps,
clients: this.clients,
strategies: this.strategies,
};
}
@ -37,11 +35,6 @@ module.exports = class UnleashClientMetrics {
return this.hourProjectionValue.getProjection();
}
registerClient (data) {
this.addClient(data.appName, data.instanceId, data.started);
this.addStrategies(data.appName, data.strategies);
}
addPayload (data) {
this.addClient(data.appName, data.instanceId);
this.addBucket(data.appName, data.instanceId, data.bucket);
@ -63,15 +56,6 @@ module.exports = class UnleashClientMetrics {
this.addClientCount(appName, instanceId, count);
}
addStrategies (appName, strategyNames) {
strategyNames.forEach((name) => {
if (!this.strategies[name]) {
this.strategies[name] = {};
}
this.strategies[name][appName] = true;
});
}
addClientCount (appName, instanceId, count) {
if (typeof count === 'number' && count > 0) {
this.globalCount += count;

View File

@ -43,6 +43,7 @@ module.exports = function (db) {
return db
.select(COLUMNS)
.from(TABLE)
.orderBy('last_seen', 'desc')
.map(mapRow);
}

View File

@ -4,7 +4,7 @@ const COLUMNS = ['app_name', 'strategies'];
const TABLE = 'client_strategies';
module.exports = function (db) {
function update (appName, strategies) {
function updateRow (appName, strategies) {
return db(TABLE)
.where('app_name', appName) // eslint-disable-line
.update({
@ -13,23 +13,23 @@ module.exports = function (db) {
});
}
function insert (appName, strategies) {
function insertNewRow (appName, strategies) {
return db(TABLE).insert({
app_name: appName, // eslint-disable-line
strategies: JSON.stringify(strategies),
});
}
function insertOrUpdate (appName, strategies) {
function insert (appName, strategies) {
return db(TABLE)
.count('*')
.where('app_name', appName)
.map(row => ({ count: row.count }))
.then(rows => {
if (rows[0].count > 0) {
return update(appName, strategies);
return updateRow(appName, strategies);
} else {
return insert(appName, strategies);
return insertNewRow(appName, strategies);
}
});
}
@ -48,5 +48,5 @@ module.exports = function (db) {
};
}
return { insertOrUpdate, getAll };
return { insert, getAll };
};

View File

@ -5,14 +5,14 @@ const ClientMetrics = require('../client-metrics');
const ClientMetricsService = require('../client-metrics/service');
module.exports = function (app, config) {
const { clientMetricsDb, clientStrategiesDb } = config;
const {
clientMetricsDb,
clientStrategiesDb,
clientInstancesDb,
} = config;
const metrics = new ClientMetrics();
const service = new ClientMetricsService(clientMetricsDb);
// Just som dummo demo data
clientStrategiesDb.insertOrUpdate('demo-app', ['default', 'test']).then(() => console.log('inserted client_strategies'));
service.on('metrics', (entries) => {
entries.forEach((m) => {
metrics.addPayload(m.metrics);
@ -41,12 +41,15 @@ module.exports = function (app, config) {
});
app.post('/client/register', (req, res) => {
try {
const data = typeof req.body === 'string' ? JSON.parse(req.body) : req.body;
metrics.registerClient(data);
} catch (e) {
logger.error('Error registering client', e);
}
const data = req.body;
clientStrategiesDb.insert(data.appName, data.strategies)
.then(() => clientInstancesDb.insert({
appName: data.appName,
instanceId: data.instanceId,
clientIp: req.ip,
}))
.then(() => console.log('new client registerd'))
.catch((error) => logger.error('Error registering client', error));
res.end();
});
@ -54,4 +57,10 @@ module.exports = function (app, config) {
app.get('/client/strategies', (req, res) => {
clientStrategiesDb.getAll().then(data => res.json(data));
});
app.get('/client/instances', (req, res) => {
clientInstancesDb.getAll()
.then(data => res.json(data))
.catch(err => console.error(err));
});
};

View File

@ -0,0 +1,38 @@
import React, { Component, PropTypes } from 'react';
import Table from 'react-toolbox/lib/table';
const Model = {
appName: { type: String, title: 'Application Name' },
instanceId: { type: String },
clientIp: { type: String },
createdAt: { type: String },
lastSeen: { type: String },
};
class ClientStrategies extends Component {
static propTypes () {
return {
fetchClientInstances: PropTypes.func.isRequired,
clientInstances: PropTypes.array.isRequired,
};
}
componentDidMount () {
this.props.fetchClientInstances();
}
render () {
const source = this.props.clientInstances;
return (
<Table
model={Model}
source={source}
selectable={false}
/>
);
}
}
export default ClientStrategies;

View File

@ -0,0 +1,9 @@
import { connect } from 'react-redux';
import ClientInstances from './client-instance-component';
import { fetchClientInstances } from '../../store/client-instance-actions';
const mapStateToProps = (state) => ({ clientInstances: state.clientInstances.toJS() });
const StrategiesContainer = connect(mapStateToProps, { fetchClientInstances })(ClientInstances);
export default StrategiesContainer;

View File

@ -0,0 +1,13 @@
import { throwIfNotSuccess, headers } from './helper';
const URI = '/client/instances';
function fetchAll () {
return fetch(URI, { headers })
.then(throwIfNotSuccess)
.then(response => response.json());
}
module.exports = {
fetchAll,
};

View File

@ -1,6 +1,6 @@
import React from 'react';
import ClientStrategy from '../../component/client-strategy/strategy-container';
import ClientInstance from '../../component/client-instance/client-instance-container';
const render = () => <ClientStrategy />;
const render = () => <ClientInstance />;
export default render;

View File

@ -0,0 +1,20 @@
import api from '../data/client-instance-api';
export const RECEIVE_CLIENT_INSTANCES = 'RECEIVE_CLIENT_INSTANCES';
export const ERROR_RECEIVE_CLIENT_INSTANCES = 'ERROR_RECEIVE_CLIENT_INSTANCES';
const receiveClientInstances = (json) => ({
type: RECEIVE_CLIENT_INSTANCES,
value: json,
});
const errorReceiveClientInstances = (statusCode) => ({
type: RECEIVE_CLIENT_INSTANCES,
statusCode,
});
export function fetchClientInstances () {
return dispatch => api.fetchAll()
.then(json => dispatch(receiveClientInstances(json)))
.catch(error => dispatch(errorReceiveClientInstances(error)));
}

View File

@ -0,0 +1,17 @@
import { fromJS } from 'immutable';
import { RECEIVE_CLIENT_INSTANCES } from './client-instance-actions';
function getInitState () {
return fromJS([]);
}
const store = (state = getInitState(), action) => {
switch (action.type) {
case RECEIVE_CLIENT_INSTANCES:
return fromJS(action.value);
default:
return state;
}
};
export default store;

View File

@ -7,6 +7,7 @@ import archive from './archive-store';
import error from './error-store';
import metrics from './metrics-store';
import clientStrategies from './client-strategy-store';
import clientInstances from './client-instance-store';
const unleashStore = combineReducers({
features,
@ -17,6 +18,7 @@ const unleashStore = combineReducers({
error,
metrics,
clientStrategies,
clientInstances,
});
export default unleashStore;

View File

@ -77,7 +77,7 @@ module.exports = {
target: 'http://localhost:4242',
secure: false,
},
'/client/strategies': {
'/client': {
target: 'http://localhost:4242',
secure: false,
},