Browse Source

Import analytic units (#840)

pull/1/head
rozetko 5 years ago committed by GitHub
parent
commit
6e7762fc59
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 5
      server/src/models/analytic_unit_cache_model.ts
  2. 6
      server/src/models/analytic_units/db.ts
  3. 3
      server/src/models/analytic_units/index.ts
  4. 5
      server/src/models/detection_model.ts
  5. 17
      server/src/models/panel_model.ts
  6. 5
      server/src/models/segment_model.ts
  7. 46
      server/src/routes/panel_router.ts
  8. 26
      server/src/services/export_service.ts

5
server/src/models/analytic_unit_cache_model.ts

@ -82,6 +82,11 @@ export async function create(id: AnalyticUnitId): Promise<AnalyticUnitId> {
return db.insertOne(cache.toObject()); return db.insertOne(cache.toObject());
} }
// TODO: SerializedCache type
export async function insertMany(caches: any[]): Promise<AnalyticUnitId[]> {
return db.insertMany(caches);
}
export async function setData(id: AnalyticUnitId, data: any) { export async function setData(id: AnalyticUnitId, data: any) {
return db.updateOne(id, { data }); return db.updateOne(id, { data });
} }

6
server/src/models/analytic_units/db.ts

@ -1,6 +1,6 @@
import { createAnalyticUnitFromObject } from './utils'; import { createAnalyticUnitFromObject } from './utils';
import { AnalyticUnit } from './analytic_unit_model'; import { AnalyticUnit } from './analytic_unit_model';
import { AnalyticUnitId, FindManyQuery } from './types'; import { AnalyticUnitId, FindManyQuery, SerializedAnalyticUnit } from './types';
import { Collection, makeDBQ, SortingOrder } from '../../services/data_service'; import { Collection, makeDBQ, SortingOrder } from '../../services/data_service';
import { Metric } from 'grafana-datasource-kit'; import { Metric } from 'grafana-datasource-kit';
@ -41,6 +41,10 @@ export async function create(unit: AnalyticUnit): Promise<AnalyticUnitId> {
return db.insertOne(obj); return db.insertOne(obj);
} }
export async function insertMany(analyticUnits: SerializedAnalyticUnit[]): Promise<AnalyticUnitId[]> {
return db.insertMany(analyticUnits);
}
export async function remove(id: AnalyticUnitId): Promise<void> { export async function remove(id: AnalyticUnitId): Promise<void> {
// TODO: remove it`s segments // TODO: remove it`s segments
// TODO: remove it`s cache // TODO: remove it`s cache

3
server/src/models/analytic_units/index.ts

@ -13,6 +13,7 @@ import {
create, create,
remove, remove,
update, update,
insertMany,
setStatus, setStatus,
setDetectionTime, setDetectionTime,
setAlert, setAlert,
@ -26,6 +27,6 @@ export {
AnalyticUnitId, AnalyticUnitStatus, Bound, DetectorType, ANALYTIC_UNIT_TYPES, AnalyticUnitId, AnalyticUnitStatus, Bound, DetectorType, ANALYTIC_UNIT_TYPES,
createAnalyticUnitFromObject, Condition, createAnalyticUnitFromObject, Condition,
findById, findMany, findById, findMany,
create, remove, update, create, remove, update, insertMany,
setStatus, setDetectionTime, setAlert, setMetric setStatus, setDetectionTime, setAlert, setMetric
}; };

5
server/src/models/detection_model.ts

@ -162,6 +162,11 @@ export async function insertSpan(span: DetectionSpan): Promise<SpanId> {
return db.insertOne(spanToInsert); return db.insertOne(spanToInsert);
} }
// TODO: SerializedDetectionSpan type
export async function insertMany(detectionSpans: any[]): Promise<SpanId[]> {
return db.insertMany(detectionSpans);
}
export function clearSpans(analyticUnitId: AnalyticUnitId) { export function clearSpans(analyticUnitId: AnalyticUnitId) {
return db.removeMany({ analyticUnitId }); return db.removeMany({ analyticUnitId });
} }

17
server/src/models/panel_model.ts

@ -0,0 +1,17 @@
import * as AnalyticUnit from './analytic_units';
import * as AnalyticUnitCache from '../models/analytic_unit_cache_model';
import * as DetectionSpan from '../models/detection_model';
import * as Segment from '../models/segment_model';
export type PanelTemplate = {
analyticUnits: AnalyticUnit.SerializedAnalyticUnit[],
caches: AnalyticUnitCache.AnalyticUnitCache[],
detectionSpans: DetectionSpan.DetectionSpan[],
segments: Segment.Segment[]
}
export type TemplateVariables = {
grafanaUrl: string,
panelId: string,
datasourceUrl: string
};

5
server/src/models/segment_model.ts

@ -232,6 +232,11 @@ export async function mergeAndInsertSegments(segments: Segment[]): Promise<{
}; };
} }
// TODO: SerializedSegment type
export async function insertMany(segments: any[]): Promise<SegmentId[]> {
return db.insertMany(segments);
}
export async function setSegmentsDeleted(ids: SegmentId[]) { export async function setSegmentsDeleted(ids: SegmentId[]) {
return db.updateMany(ids, { deleted: true, labeled: false }); return db.updateMany(ids, { deleted: true, labeled: false });
} }

46
server/src/routes/panel_router.ts

@ -1,18 +1,54 @@
import { exportPanel } from '../services/export_service'; import { PanelTemplate, TemplateVariables } from '../models/panel_model';
import { exportPanel, importPanel } from '../services/export_service';
import * as Router from 'koa-router'; import * as Router from 'koa-router';
async function getPanelTemplate(ctx: Router.IRouterContext) { async function exportPanelTemplate(ctx: Router.IRouterContext) {
let panelId = ctx.request.query.panelId; let panelId = ctx.request.query.panelId;
if(panelId === undefined) { if(panelId === undefined) {
throw new Error('Cannot export analytic units with undefined panelId'); throw new Error('Cannot export analytic units with undefined panelId');
} }
const json = await exportPanel(panelId); const panelTemplate = await exportPanel(panelId);
ctx.response.body = json; ctx.response.body = panelTemplate;
}
async function importPanelTemplate(ctx: Router.IRouterContext) {
const { panelTemplate, templateVariables } = ctx.request.body as {
panelTemplate: PanelTemplate,
templateVariables: TemplateVariables
};
// TODO: move to model
if(panelTemplate.analyticUnits === undefined) {
throw new Error('Cannot import analytic units with undefined analyticUnits');
}
if(panelTemplate.caches === undefined) {
throw new Error('Cannot import analytic units with undefined caches');
}
if(panelTemplate.detectionSpans === undefined) {
throw new Error('Cannot import analytic units with undefined detectionSpans');
}
if(panelTemplate.segments === undefined) {
throw new Error('Cannot import analytic units with undefined segments');
}
if(templateVariables.grafanaUrl === undefined) {
throw new Error('Cannot make analytic unit from template with undefined grafanaUrl');
}
if(templateVariables.panelId === undefined) {
throw new Error('Cannot make analytic unit from template with undefined panelId');
}
if(templateVariables.datasourceUrl === undefined) {
throw new Error('Cannot make analytic unit from template with undefined datasourceUrl');
}
await importPanel(panelTemplate, templateVariables);
ctx.response.status = 200;
} }
export var router = new Router(); export var router = new Router();
router.get('/template', getPanelTemplate); router.get('/template', exportPanelTemplate);
router.post('/template', importPanelTemplate);

26
server/src/services/export_service.ts

@ -1,15 +1,12 @@
import { PanelTemplate, TemplateVariables } from '../models/panel_model';
import * as AnalyticUnit from '../models/analytic_units'; import * as AnalyticUnit from '../models/analytic_units';
import * as AnalyticUnitCache from '../models/analytic_unit_cache_model'; import * as AnalyticUnitCache from '../models/analytic_unit_cache_model';
import * as DetectionSpan from '../models/detection_model'; import * as DetectionSpan from '../models/detection_model';
import * as Segment from '../models/segment_model'; import * as Segment from '../models/segment_model';
export async function exportPanel(panelId: string): Promise<{ export async function exportPanel(panelId: string): Promise<PanelTemplate> {
analyticUnitTemplates: any[],
caches: AnalyticUnitCache.AnalyticUnitCache[],
detectionSpans: DetectionSpan.DetectionSpan[],
segments: Segment.Segment[]
}> {
const analyticUnits = await AnalyticUnit.findMany({ panelId }); const analyticUnits = await AnalyticUnit.findMany({ panelId });
const analyticUnitIds = analyticUnits.map(analyticUnit => analyticUnit.id); const analyticUnitIds = analyticUnits.map(analyticUnit => analyticUnit.id);
const analyticUnitTemplates = analyticUnits.map(analyticUnit => analyticUnit.toTemplate()); const analyticUnitTemplates = analyticUnits.map(analyticUnit => analyticUnit.toTemplate());
@ -21,9 +18,24 @@ export async function exportPanel(panelId: string): Promise<{
]); ]);
return { return {
analyticUnitTemplates, analyticUnits: analyticUnitTemplates,
caches, caches,
detectionSpans, detectionSpans,
segments segments
}; };
} }
export async function importPanel(
panelTemplate: PanelTemplate,
variables: TemplateVariables
): Promise<void> {
panelTemplate.analyticUnits.forEach(analyticUnit => {
analyticUnit.grafanaUrl = variables.grafanaUrl;
analyticUnit.panelId = variables.panelId;
analyticUnit.metric.datasource.url = variables.datasourceUrl;
});
await AnalyticUnit.insertMany(panelTemplate.analyticUnits);
await AnalyticUnitCache.insertMany(panelTemplate.caches);
await Segment.insertMany(panelTemplate.segments);
await DetectionSpan.insertMany(panelTemplate.detectionSpans);
}

Loading…
Cancel
Save