blob: 25e8f3c0edd383ace35e5ecef0cb045f602a55e5 (
plain) (
blame)
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
|
package kamon.trace
import java.nio.ByteBuffer
import java.util.concurrent.ThreadLocalRandom
import kamon.util.HexCodec
import scala.util.Try
trait IdentityProvider {
def traceIdentifierGenerator(): IdentityProvider.Generator
def spanIdentifierGenerator(): IdentityProvider.Generator
}
object IdentityProvider {
case class Identifier(string: String, bytes: Array[Byte])
val NoIdentifier = Identifier("", new Array[Byte](0))
trait Generator {
def generate(): Identifier
def from(string: String): Identifier
def from(bytes: Array[Byte]): Identifier
}
class Default extends IdentityProvider {
private val generator = new Generator {
override def generate(): Identifier = {
val data = ByteBuffer.wrap(new Array[Byte](8))
val random = ThreadLocalRandom.current().nextLong()
data.putLong(random)
Identifier(HexCodec.toLowerHex(random), data.array())
}
override def from(string: String): Identifier = Try {
val identifierLong = HexCodec.lowerHexToUnsignedLong(string)
val data = ByteBuffer.allocate(8)
data.putLong(identifierLong)
Identifier(string, data.array())
} getOrElse(IdentityProvider.NoIdentifier)
override def from(bytes: Array[Byte]): Identifier = Try {
val buffer = ByteBuffer.wrap(bytes)
val identifierLong = buffer.getLong
Identifier(HexCodec.toLowerHex(identifierLong), bytes)
} getOrElse(IdentityProvider.NoIdentifier)
}
override def traceIdentifierGenerator(): Generator = generator
override def spanIdentifierGenerator(): Generator = generator
}
object Default {
def apply(): Default = new Default()
}
}
|