forked from pinpoint-apm/pinpoint-node-agent
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspan-events.js
63 lines (53 loc) · 1.9 KB
/
span-events.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
/**
* Pinpoint Node.js Agent
* Copyright 2020-present NAVER Corp.
* Apache License v2.0
*/
'use strict'
const {convertIntStringValue, convertNextEvent, addAnnotations} = require('../data/grpc-data-convertor')
const spanMessages = require('../data/grpc/Span_pb')
class SpanEvents {
constructor(spanEvents) {
this.spanEvents = this.sortedSpanEvents(spanEvents || [])
}
sortedSpanEvents(spanEvents) {
return Array.from(spanEvents).sort((a, b) => {
if (a.sequence < b.sequence) {
return -1
}
if (a.sequence > b.sequence) {
return 1
}
return 0
})
}
getpSpanEvents(keyTime) {
let events = []
return this.pSpanEvents(events, keyTime)
}
pSpanEvents(events, keyTime) {
if (this.spanEvents.length > 0) {
this.spanEvents.reduce((previousStartTime, spanEvent) => {
const startElapsedTime = spanEvent.startTime - previousStartTime
events.push(this.convertSpanEvent(spanEvent, startElapsedTime))
return spanEvent.startTime
}, keyTime)
}
return events
}
convertSpanEvent(spanEvent, startElapsedTime) {
const pSpanEvent = new spanMessages.PSpanEvent()
pSpanEvent.setSequence(spanEvent.sequence)
pSpanEvent.setDepth(spanEvent.depth)
pSpanEvent.setStartelapsed(startElapsedTime)
pSpanEvent.setEndelapsed(spanEvent.endElapsed)
pSpanEvent.setServicetype(spanEvent.serviceType)
pSpanEvent.setApiid(spanEvent.apiId)
pSpanEvent.setExceptioninfo(convertIntStringValue(spanEvent.exceptionInfo))
pSpanEvent.setNextevent(convertNextEvent(spanEvent))
pSpanEvent.setAsyncevent(spanEvent.nextAsyncId)
addAnnotations(pSpanEvent, spanEvent.annotations)
return pSpanEvent
}
}
module.exports = SpanEvents