-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathartifact.go
127 lines (113 loc) · 4.42 KB
/
artifact.go
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
// Copyright 2020 Joakim Kennedy. All rights reserved. Use of
// this source code is governed by the included BSD license.
package stix2
import (
"encoding/json"
"strings"
)
// Artifact object permits capturing an array of bytes (8-bits), as a
// base64-encoded string, or linking to a file-like payload. One of payload_bin
// or url MUST be provided. It is incumbent on object creators to ensure that
// the URL is accessible for downstream consumers.
type Artifact struct {
STIXCyberObservableObject
// MimeType should, whenever feasible, be one of the values defined in the
// Template column in the IANA media type registry. Maintaining a
// comprehensive universal catalog of all extant file types is obviously
// not possible. When specifying a MIME Type not included in the IANA
// registry, implementers should use their best judgement so as to
// facilitate interoperability.
MimeType string `json:"mime_type,omitempty"`
// Payload specifies the binary data contained in the artifact. This
// property MUST NOT be present if url is provided.
Payload Binary `json:"payload_bin,omitempty"`
// URL a valid URL that resolves to the unencoded content. This property
// MUST NOT be present if Payload is provided.
URL string `json:"url,omitempty"`
// Hashes are hashes for the contents of the URL or the Payload.
// This property MUST be present when the url property is present.
Hashes Hashes `json:"hashes,omitempty"`
// Encryption is used if the artifact is encrypted, specifies the type of
// encryption algorithm the binary data is encoded in.
Encryption EncryptionAlgorithm `json:"encryption_algorithm,omitempty"`
// Key specifies the decryption key for the encrypted binary data. For
// example, this may be useful in cases of sharing malware samples, which
// are often encoded in an encrypted archive.
Key string `json:"decryption_key,omitempty"`
}
func (o *Artifact) MarshalJSON() ([]byte, error) {
return marshalToJSONHelper(o)
}
// NewArtifact creates a new Artifact object.
func NewArtifact(opts ...STIXOption) (*Artifact, error) {
base := newSTIXCyberObservableObject(TypeArtifact)
obj := &Artifact{
STIXCyberObservableObject: base,
}
err := applyOptions(obj, opts)
if err != nil {
return nil, err
}
if obj.Payload == nil && obj.URL == "" {
return nil, ErrPropertyMissing
}
if obj.Payload != nil && obj.URL != "" {
return nil, ErrInvalidParameter
}
if obj.URL != "" && obj.Hashes == nil {
return nil, ErrPropertyMissing
}
contriStr := []string{}
if len(obj.Hashes) != 0 {
contriStr = append(contriStr, obj.Hashes.getIDContribution())
}
if len(obj.Payload) != 0 {
contriStr = append(contriStr, `"`+obj.Payload.String()+`"`)
}
obj.ID = NewObservableIdentifier("["+strings.Join(contriStr, ",")+"]", TypeArtifact)
return obj, nil
}
// EncryptionAlgorithm is the encryption algorithms used for sharing defanged
// and/or confidential artifacts.
type EncryptionAlgorithm uint8
// String returns the string representation of the type.
func (typ EncryptionAlgorithm) String() string {
return encAlgMap[typ]
}
// MarshalJSON converts the enum type to the JSON string.
func (typ EncryptionAlgorithm) MarshalJSON() ([]byte, error) {
return json.Marshal(typ.String())
}
// UnmarshalJSON extracts the encryption algorithm from the json data.
func (typ *EncryptionAlgorithm) UnmarshalJSON(b []byte) error {
t := string(b[1 : len(b)-1])
for k, v := range encAlgMap {
if v == t {
*typ = k
return nil
}
}
*typ = EncryptionAlgorithmNone
return nil
}
const (
// EncryptionAlgorithmNone no encryption is used.
EncryptionAlgorithmNone EncryptionAlgorithm = iota
// EncryptionAlgorithmAES256GCM the AES-256-GCM cipher.
EncryptionAlgorithmAES256GCM
// EncryptionAlgorithmChaCha20Poly1305 the ChaCha20-Poly1305 stream
// cipher.
EncryptionAlgorithmChaCha20Poly1305
// EncryptionAlgorithmMimeTypeIndicated mean encryption algorithm is
// self-defined by the artifact's data. The specified mime-type tells you
// which format it is, e.g., Word Doc or GPG. This is intended for formats
// like Zip files and Word files which take a simple password, or GPG
// armored files that contain the key blob along with the file.
EncryptionAlgorithmMimeTypeIndicated
)
var encAlgMap = map[EncryptionAlgorithm]string{
EncryptionAlgorithmNone: "",
EncryptionAlgorithmAES256GCM: "AES-256-GCM",
EncryptionAlgorithmChaCha20Poly1305: "ChaCha20-Poly1305",
EncryptionAlgorithmMimeTypeIndicated: "mime-type-indicated",
}