/
metric_types.go
88 lines (71 loc) · 2.67 KB
/
metric_types.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
/*
Copyright 2019 The Knative Authors
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.
*/
package v1alpha1
import (
"time"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"knative.dev/pkg/apis"
duckv1 "knative.dev/pkg/apis/duck/v1"
"knative.dev/pkg/kmeta"
)
// Metric represents a resource to configure the metric collector with.
//
// +genclient
// +genreconciler
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type Metric struct {
metav1.TypeMeta `json:",inline"`
// +optional
metav1.ObjectMeta `json:"metadata,omitempty"`
// Spec holds the desired state of the Metric (from the client).
// +optional
Spec MetricSpec `json:"spec,omitempty"`
// Status communicates the observed state of the Metric (from the controller).
// +optional
Status MetricStatus `json:"status,omitempty"`
}
// Verify that Metric adheres to the appropriate interfaces.
var (
// Check that Metric can be validated and can be defaulted.
_ apis.Validatable = (*Metric)(nil)
_ apis.Defaultable = (*Metric)(nil)
// Check that we can create OwnerReferences to a Metric.
_ kmeta.OwnerRefable = (*Metric)(nil)
// Check that the type conforms to the duck Knative Resource shape.
_ duckv1.KRShaped = (*Metric)(nil)
)
// MetricSpec contains all values a metric collector needs to operate.
type MetricSpec struct {
// StableWindow is the aggregation window for metrics in a stable state.
StableWindow time.Duration `json:"stableWindow"`
// PanicWindow is the aggregation window for metrics where quick reactions are needed.
PanicWindow time.Duration `json:"panicWindow"`
// ScrapeTarget is the K8s service that publishes the metric endpoint.
ScrapeTarget string `json:"scrapeTarget"`
}
// MetricStatus reflects the status of metric collection for this specific entity.
type MetricStatus struct {
duckv1.Status `json:",inline"`
}
// MetricList is a list of Metric resources
//
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
type MetricList struct {
metav1.TypeMeta `json:",inline"`
metav1.ListMeta `json:"metadata"`
Items []Metric `json:"items"`
}
// GetStatus retrieves the status of the Metric. Implements the KRShaped interface.
func (m *Metric) GetStatus() *duckv1.Status {
return &m.Status.Status
}