forked from freetaxii/libstix2
/
confidence.go
51 lines (42 loc) · 1.66 KB
/
confidence.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
// Copyright 2015-2020 Bret Jordan, All rights reserved.
//
// Use of this source code is governed by an Apache 2.0 license that can be
// found in the LICENSE file in the root of the source tree.
package properties
import "fmt"
// ----------------------------------------------------------------------
// Define Types
// ----------------------------------------------------------------------
/*
ConfidenceProperty - A property used by one or more STIX objects that
captures the STIX confidence score, which is a value from 0-100.
*/
type ConfidenceProperty struct {
Confidence int `json:"confidence,omitempty"`
}
// ----------------------------------------------------------------------
// Public Methods - ConfidenceProperty - Checks
// ----------------------------------------------------------------------
/*
Compare - This method will compare two properties to make sure they are the
same and will return a boolean, an integer that tracks the number of problems
found, and a slice of strings that contain the detailed results, whether good or
bad.
*/
func (o *ConfidenceProperty) Compare(obj2 *ConfidenceProperty) (bool, int, []string) {
problemsFound := 0
resultDetails := make([]string, 0)
// Check Confidence Value
if o.Confidence != obj2.Confidence {
problemsFound++
str := fmt.Sprintf("-- The confidence values do not match: %d | %d", o.Confidence, obj2.Confidence)
resultDetails = append(resultDetails, str)
} else {
str := fmt.Sprintf("++ The confidence values match: %d | %d", o.Confidence, obj2.Confidence)
resultDetails = append(resultDetails, str)
}
if problemsFound > 0 {
return false, problemsFound, resultDetails
}
return true, 0, resultDetails
}