/usr/share/grafana/public/app/plugins/datasource/jaeger
import { DataFrame, FieldType, MutableDataFrame, TraceLog, TraceSpanRow } from '@grafana/data'; import { JaegerResponse, Span, TraceProcess, TraceResponse } from './types'; export function createTraceFrame(data: TraceResponse): DataFrame { const spans = data.spans.map((s) => toSpanRow(s, data.processes)); const frame = new MutableDataFrame({ fields: [ { name: 'traceID', type: FieldType.string }, { name: 'spanID', type: FieldType.string }, { name: 'parentSpanID', type: FieldType.string }, { name: 'operationName', type: FieldType.string }, { name: 'serviceName', type: FieldType.string }, { name: 'serviceTags', type: FieldType.other }, { name: 'startTime', type: FieldType.number }, { name: 'duration', type: FieldType.number }, { name: 'logs', type: FieldType.other }, { name: 'references', type: FieldType.other, values: [] }, { name: 'tags', type: FieldType.other }, { name: 'warnings', type: FieldType.other }, { name: 'stackTraces', type: FieldType.other }, ], meta: { preferredVisualisationType: 'trace', custom: { traceFormat: 'jaeger', }, }, }); for (const span of spans) { frame.add(span); } return frame; } function toSpanRow(span: Span, processes: Record<string, TraceProcess>): TraceSpanRow { const parentSpanID = span.references?.find((r) => r.refType === 'CHILD_OF')?.spanID; return { spanID: span.spanID, traceID: span.traceID, parentSpanID: parentSpanID, operationName: span.operationName, // from micro to millis startTime: span.startTime / 1000, duration: span.duration / 1000, logs: span.logs.map((l) => ({ ...l, timestamp: l.timestamp / 1000, })), tags: span.tags, warnings: span.warnings ?? undefined, stackTraces: span.stackTraces, references: span.references?.filter((r) => r.spanID !== parentSpanID) ?? [], // parentSpanID is pushed to references in the transformTraceDataFrame method serviceName: processes[span.processID].serviceName, serviceTags: processes[span.processID].tags, }; } export function transformToJaeger(data: MutableDataFrame): JaegerResponse { let traceResponse: TraceResponse = { traceID: '', spans: [], processes: {}, warnings: null, }; let processes: string[] = []; for (let i = 0; i < data.length; i++) { const span = data.get(i); // Set traceID if (!traceResponse.traceID) { traceResponse.traceID = span.traceID; } // Create process if doesn't exist if (!processes.find((p) => p === span.serviceName)) { processes.push(span.serviceName); traceResponse.processes[`p${processes.length}`] = { serviceName: span.serviceName, tags: span.serviceTags, }; } // Create span traceResponse.spans.push({ traceID: span.traceID, spanID: span.spanID, duration: span.duration * 1000, references: span.parentSpanID ? [ { refType: 'CHILD_OF', spanID: span.parentSpanID, traceID: span.traceID, }, ] : [], flags: 0, logs: span.logs.map((l: TraceLog) => ({ ...l, timestamp: l.timestamp * 1000, })), operationName: span.operationName, processID: Object.keys(traceResponse.processes).find( (key) => traceResponse.processes[key].serviceName === span.serviceName ) || '', startTime: span.startTime * 1000, tags: span.tags, warnings: span.warnings ? span.warnings : null, }); } return { data: [traceResponse], total: 0, limit: 0, offset: 0, errors: null }; }
.
Edit
..
Edit
CHANGELOG.md
Edit
CheatSheet.tsx
Edit
README.md
Edit
components
Edit
configuration
Edit
datasource.test.ts
Edit
datasource.ts
Edit
dist
Edit
graphTransform.test.ts
Edit
graphTransform.ts
Edit
helpers
Edit
img
Edit
jest-setup.js
Edit
jest.config.js
Edit
mockJsonResponse.json
Edit
mockSearchResponse.json
Edit
mockTraceResponse.json
Edit
module.ts
Edit
package.json
Edit
plugin.json
Edit
project.json
Edit
responseTransform.test.ts
Edit
responseTransform.ts
Edit
testResponse.ts
Edit
tsconfig.json
Edit
types.ts
Edit
webpack.config.ts
Edit