Browse Source
* Add webhook settings to config * Update notification service * Remove alerts controller * Remove alerts router * Add alert field to analytic unit * Add endpoints: - GET analyticUnits/units - PATCH analyticUnits/alert * Rename sendNotification -> sendWebhook * Change webhook payload * Send webhook on detectionpull/1/head
8 changed files with 136 additions and 151 deletions
@ -1,4 +1,7 @@
|
||||
{ |
||||
"HASTIC_PORT": 8000, |
||||
"HASTIC_API_KEY": "eyJrIjoiVjZqMHY0dHk4UEE3eEN4MzgzRnd2aURlMWlIdXdHNW4iLCJuIjoiaGFzdGljIiwiaWQiOjF9" |
||||
"HASTIC_API_KEY": "eyJrIjoiVjZqMHY0dHk4UEE3eEN4MzgzRnd2aURlMWlIdXdHNW4iLCJuIjoiaGFzdGljIiwiaWQiOjF9", |
||||
"HASTIC_WEBHOOK_URL": "http://localhost:8080", |
||||
"HASTIC_WEBHOOK_TYPE": "application/x-www-form-urlencoded", |
||||
"HASTIC_WEBHOOK_SECRET": "mysecret" |
||||
} |
||||
|
@ -1,72 +0,0 @@
|
||||
/** |
||||
* Alarting is not supported yet |
||||
*/ |
||||
|
||||
throw new Error('not supported'); |
||||
|
||||
|
||||
// import { runDetect } from './analytics_controller';
|
||||
// import { getLabeledSegments } from './segments_controller';
|
||||
// import { AnalyticUnitId } from '../models/analytic_unit';
|
||||
// import { sendNotification } from '../services/notification_service';
|
||||
// import { getJsonDataSync, writeJsonDataSync } from '../services/json_service';
|
||||
// import { ANALYTIC_UNITS_PATH } from '../config';
|
||||
|
||||
// import * as path from 'path';
|
||||
// import * as fs from 'fs';
|
||||
|
||||
|
||||
// const ALERT_TIMEOUT = 60000; // ms
|
||||
// const ALERTS_DB_PATH = path.join(ANALYTIC_UNITS_PATH, `alerts_anomalies.json`);
|
||||
|
||||
|
||||
// export function getAlertsAnomalies(): AnalyticUnitId[] {
|
||||
// if(!fs.existsSync(ALERTS_DB_PATH)) {
|
||||
// saveAlertsAnomalies([]);
|
||||
// }
|
||||
// return getJsonDataSync(ALERTS_DB_PATH);
|
||||
// }
|
||||
|
||||
// export function saveAlertsAnomalies(units: AnalyticUnitId[]) {
|
||||
// return writeJsonDataSync(ALERTS_DB_PATH, units);
|
||||
// }
|
||||
|
||||
// function processAlerts(id: AnalyticUnitId) {
|
||||
// let segments = getLabeledSegments(id);
|
||||
|
||||
// const currentTime = new Date().getTime();
|
||||
// const activeAlert = activeAlerts.has(id);
|
||||
// let newActiveAlert = false;
|
||||
|
||||
// if(segments.length > 0) {
|
||||
// let lastSegment = segments[segments.length - 1];
|
||||
// if(lastSegment.finish >= currentTime - ALERT_TIMEOUT) {
|
||||
// newActiveAlert = true;
|
||||
// }
|
||||
// }
|
||||
|
||||
// if(!activeAlert && newActiveAlert) {
|
||||
// activeAlerts.add(id);
|
||||
// sendNotification(id, true);
|
||||
// } else if(activeAlert && !newActiveAlert) {
|
||||
// activeAlerts.delete(id);
|
||||
// sendNotification(id, false);
|
||||
// }
|
||||
// }
|
||||
|
||||
// async function alertsTick() {
|
||||
// let alertsAnomalies = getAlertsAnomalies();
|
||||
// for (let detectorId of alertsAnomalies) {
|
||||
// try {
|
||||
// await runDetect(detectorId);
|
||||
// processAlerts(detectorId);
|
||||
// } catch (e) {
|
||||
// console.error(e);
|
||||
// }
|
||||
// }
|
||||
// setTimeout(alertsTick, 5000);
|
||||
// }
|
||||
|
||||
|
||||
// const activeAlerts = new Set<string>();
|
||||
// setTimeout(alertsTick, 5000);
|
@ -1,43 +0,0 @@
|
||||
// /**
|
||||
// * Alarting is not supported yet
|
||||
// */
|
||||
|
||||
// throw new console.error("Not supported");
|
||||
|
||||
|
||||
// import * as AnalyticUnit from '../models/analytic_unit';
|
||||
// import { getAlertsAnomalies, saveAlertsAnomalies } from '../controllers/alerts_controller';
|
||||
|
||||
// import * as Router from 'koa-router';
|
||||
|
||||
|
||||
// function getAlert(ctx: Router.IRouterContext) {
|
||||
// let id: AnalyticUnit.AnalyticUnitId = ctx.request.query.id;
|
||||
|
||||
// let alertsAnomalies = getAlertsAnomalies();
|
||||
// let pos = alertsAnomalies.indexOf(id);
|
||||
|
||||
// let enabled: boolean = (pos !== -1);
|
||||
// ctx.response.body = { enabled };
|
||||
// }
|
||||
|
||||
// function setAlertEnabled(ctx: Router.IRouterContext) {
|
||||
// let id: AnalyticUnit.AnalyticUnitId = ctx.request.body.id;
|
||||
// let enabled: boolean = ctx.request.body.enabled;
|
||||
|
||||
// let alertsAnomalies = getAlertsAnomalies();
|
||||
// let pos: number = alertsAnomalies.indexOf(id);
|
||||
// if(enabled && pos == -1) {
|
||||
// alertsAnomalies.push(id);
|
||||
// saveAlertsAnomalies(alertsAnomalies);
|
||||
// } else if(!enabled && pos > -1) {
|
||||
// alertsAnomalies.splice(pos, 1);
|
||||
// saveAlertsAnomalies(alertsAnomalies);
|
||||
// }
|
||||
// ctx.response.body = { status: 'OK' };
|
||||
// }
|
||||
|
||||
// export const router = new Router();
|
||||
|
||||
// router.get('/', getAlert);
|
||||
// router.post('/', setAlertEnabled);
|
Loading…
Reference in new issue