forked from oss-review-toolkit/ort
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLicenseFindingCuration.kt
103 lines (91 loc) · 3.41 KB
/
LicenseFindingCuration.kt
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
/*
* Copyright (C) 2017-2019 HERE Europe B.V.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* SPDX-License-Identifier: Apache-2.0
* License-Filename: LICENSE
*/
package com.here.ort.model.config
import com.fasterxml.jackson.annotation.JsonInclude
import com.fasterxml.jackson.databind.annotation.JsonDeserialize
import com.fasterxml.jackson.databind.annotation.JsonSerialize
import com.fasterxml.jackson.databind.util.StdConverter
/**
* A curation for license findings.
*/
data class LicenseFindingCuration(
/**
* A glob to match the file path of a license finding.
*/
val path: String,
/**
* A matcher for the start line of a license finding, matches if the start line matches any of [startLines] or if
* [startLines] is empty.
*/
@JsonInclude(JsonInclude.Include.NON_EMPTY)
@JsonDeserialize(converter = CsvStringToIntListConverter::class)
@JsonSerialize(converter = IntListToCsvStringConverter::class)
val startLines: List<Int> = emptyList(),
/**
* A matcher for the line count of a license finding, matches if the line count equals [lineCount] or if
* [lineCount] is null.
*/
@JsonInclude(JsonInclude.Include.NON_NULL)
val lineCount: Int? = null,
/**
* A matcher for the detected license of a license finding, matches if the detected license equals
* [detectedLicense] or if [detectedLicense] is null.
*/
@JsonInclude(JsonInclude.Include.NON_NULL)
val detectedLicense: String?,
/**
* The concluded license as SPDX expression or [com.here.ort.spdx.SpdxLicense.NONE] for no license,
* see https://spdx.org/spdx-specification-21-web-version#h.jxpfx0ykyb60.
*/
val concludedLicense: String,
/**
* The reason why the curation was made, out of a predefined choice.
*/
val reason: LicenseFindingCurationReason,
/**
* A comment explaining this [LicenseFindingCuration].
*/
@JsonInclude(JsonInclude.Include.NON_EMPTY)
val comment: String = ""
) {
init {
require(startLines.all { it >= 0 }) {
"All values for start lines must not be negative."
}
require(lineCount == null || lineCount >= 0) {
"The value for line count must not be negative."
}
require(detectedLicense == null || detectedLicense.isNotBlank()) {
"The detected license must either be omitted or not be blank."
}
require(concludedLicense.isNotBlank()) {
"The concluded license must not be blank."
}
}
}
class IntListToCsvStringConverter : StdConverter<List<Int>, String>() {
override fun convert(value: List<Int>): String = value.joinToString(separator = ",")
}
class CsvStringToIntListConverter : StdConverter<String, List<Int>>() {
override fun convert(value: String): List<Int> = value
.split(",")
.map { it.trim() }
.filter { it.isNotEmpty() }
.map { it.toInt() }
}