-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathBundleGraphSpec.groovy
69 lines (54 loc) · 2.53 KB
/
BundleGraphSpec.groovy
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
64
65
66
67
68
69
package stix.bundle
import io.digitalstate.stix.bundle.Bundle
import io.digitalstate.stix.common.StixInstant
import io.digitalstate.stix.coo.objects.DomainName
import io.digitalstate.stix.coo.objects.Ipv4Address
import io.digitalstate.stix.graph.StixGraphGenerator
import io.digitalstate.stix.sdo.objects.AttackPattern
import io.digitalstate.stix.sdo.objects.ObservedData
import io.digitalstate.stix.sro.objects.Relationship
import io.digitalstate.stix.sro.objects.Sighting
import spock.lang.Specification
class BundleGraphSpec extends Specification {
def "Generate a Simple Graph of STIX data"() {
when: "Create Objects"
AttackPattern attackPattern1 = AttackPattern.builder().name("attk1").build()
AttackPattern attackPattern2 = AttackPattern.builder().name("attk2").build()
Relationship relationship1 = Relationship.builder()
.sourceRef(attackPattern1)
.targetRef(attackPattern2)
.relationshipType("related-to")
.build()
DomainName domainName1 = DomainName.builder()
.value("http://google.com")
.build()
Ipv4Address ip1 = Ipv4Address.builder().value("10.10.10.10").build()
Ipv4Address ip2 = Ipv4Address.builder().value("10.10.10.11").build()
Ipv4Address ip3 = Ipv4Address.builder().value("10.10.10.12").build()
Ipv4Address ip4 = Ipv4Address.builder().value("10.10.10.13").build()
Ipv4Address ip5 = Ipv4Address.builder().value("10.10.10.14").build()
Ipv4Address ip6 = Ipv4Address.builder().value("10.10.10.15").build()
ObservedData observedData1 = ObservedData.builder()
.addObjects(domainName1, ip1, ip2, ip3, ip4, ip5, ip6)
.firstObserved(new StixInstant())
.lastObserved(new StixInstant())
.numberObserved(2)
.build()
Sighting sighting1 = Sighting.builder()
.firstSeen(new StixInstant())
.lastSeen(new StixInstant())
.count(1)
.sightingOfRef(attackPattern1)
.addObservedDataRef(observedData1)
.build()
then: "build bundle"
Bundle bundle = Bundle.builder()
.addObjects(attackPattern1, attackPattern2, relationship1, observedData1, sighting1)
.build()
println bundle.toString()
then: "generate graph json"
StixGraphGenerator graph = new StixGraphGenerator(bundle)
println graph.process().toString()
println graph.toJson()
}
}