2019-01-12 04:58:27 +00:00
|
|
|
/*
|
|
|
|
Copyright 2017 The Kubernetes 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 audit
|
|
|
|
|
|
|
|
import (
|
2021-03-18 22:40:29 +00:00
|
|
|
"context"
|
2019-01-12 04:58:27 +00:00
|
|
|
"fmt"
|
|
|
|
|
|
|
|
auditinternal "k8s.io/apiserver/pkg/apis/audit"
|
2019-09-27 21:51:53 +00:00
|
|
|
"k8s.io/component-base/metrics"
|
|
|
|
"k8s.io/component-base/metrics/legacyregistry"
|
2020-08-10 17:43:49 +00:00
|
|
|
"k8s.io/klog/v2"
|
2019-01-12 04:58:27 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
subsystem = "apiserver_audit"
|
|
|
|
)
|
|
|
|
|
2019-09-27 21:51:53 +00:00
|
|
|
/*
|
|
|
|
* By default, all the following metrics are defined as falling under
|
2021-03-18 22:40:29 +00:00
|
|
|
* ALPHA stability level https://github.com/kubernetes/enhancements/blob/master/keps/sig-instrumentation/1209-metrics-stability/20190404-kubernetes-control-plane-metrics-stability.md#stability-classes)
|
2019-09-27 21:51:53 +00:00
|
|
|
*
|
|
|
|
* Promoting the stability level of the metric is a responsibility of the component owner, since it
|
|
|
|
* involves explicitly acknowledging support for the metric across multiple releases, in accordance with
|
|
|
|
* the metric stability policy.
|
|
|
|
*/
|
2019-01-12 04:58:27 +00:00
|
|
|
var (
|
2019-09-27 21:51:53 +00:00
|
|
|
eventCounter = metrics.NewCounter(
|
|
|
|
&metrics.CounterOpts{
|
|
|
|
Subsystem: subsystem,
|
|
|
|
Name: "event_total",
|
|
|
|
Help: "Counter of audit events generated and sent to the audit backend.",
|
|
|
|
StabilityLevel: metrics.ALPHA,
|
2019-01-12 04:58:27 +00:00
|
|
|
})
|
2019-09-27 21:51:53 +00:00
|
|
|
errorCounter = metrics.NewCounterVec(
|
|
|
|
&metrics.CounterOpts{
|
2019-01-12 04:58:27 +00:00
|
|
|
Subsystem: subsystem,
|
|
|
|
Name: "error_total",
|
|
|
|
Help: "Counter of audit events that failed to be audited properly. " +
|
|
|
|
"Plugin identifies the plugin affected by the error.",
|
2019-09-27 21:51:53 +00:00
|
|
|
StabilityLevel: metrics.ALPHA,
|
2019-01-12 04:58:27 +00:00
|
|
|
},
|
|
|
|
[]string{"plugin"},
|
|
|
|
)
|
2019-09-27 21:51:53 +00:00
|
|
|
levelCounter = metrics.NewCounterVec(
|
|
|
|
&metrics.CounterOpts{
|
|
|
|
Subsystem: subsystem,
|
|
|
|
Name: "level_total",
|
|
|
|
Help: "Counter of policy levels for audit events (1 per request).",
|
|
|
|
StabilityLevel: metrics.ALPHA,
|
2019-01-12 04:58:27 +00:00
|
|
|
},
|
|
|
|
[]string{"level"},
|
|
|
|
)
|
|
|
|
|
2019-09-27 21:51:53 +00:00
|
|
|
ApiserverAuditDroppedCounter = metrics.NewCounter(
|
|
|
|
&metrics.CounterOpts{
|
2019-01-12 04:58:27 +00:00
|
|
|
Subsystem: subsystem,
|
|
|
|
Name: "requests_rejected_total",
|
|
|
|
Help: "Counter of apiserver requests rejected due to an error " +
|
|
|
|
"in audit logging backend.",
|
2019-09-27 21:51:53 +00:00
|
|
|
StabilityLevel: metrics.ALPHA,
|
2019-01-12 04:58:27 +00:00
|
|
|
},
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2019-09-27 21:51:53 +00:00
|
|
|
legacyregistry.MustRegister(eventCounter)
|
|
|
|
legacyregistry.MustRegister(errorCounter)
|
|
|
|
legacyregistry.MustRegister(levelCounter)
|
|
|
|
legacyregistry.MustRegister(ApiserverAuditDroppedCounter)
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ObserveEvent updates the relevant prometheus metrics for the generated audit event.
|
2021-03-18 22:40:29 +00:00
|
|
|
func ObserveEvent(ctx context.Context) {
|
|
|
|
eventCounter.WithContext(ctx).Inc()
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// ObservePolicyLevel updates the relevant prometheus metrics with the audit level for a request.
|
2021-03-18 22:40:29 +00:00
|
|
|
func ObservePolicyLevel(ctx context.Context, level auditinternal.Level) {
|
|
|
|
levelCounter.WithContext(ctx).WithLabelValues(string(level)).Inc()
|
2019-01-12 04:58:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// HandlePluginError handles an error that occurred in an audit plugin. This method should only be
|
|
|
|
// used if the error may have prevented the audit event from being properly recorded. The events are
|
|
|
|
// logged to the debug log.
|
|
|
|
func HandlePluginError(plugin string, err error, impacted ...*auditinternal.Event) {
|
|
|
|
// Count the error.
|
|
|
|
errorCounter.WithLabelValues(plugin).Add(float64(len(impacted)))
|
|
|
|
|
|
|
|
// Log the audit events to the debug log.
|
|
|
|
msg := fmt.Sprintf("Error in audit plugin '%s' affecting %d audit events: %v\nImpacted events:\n",
|
|
|
|
plugin, len(impacted), err)
|
|
|
|
for _, ev := range impacted {
|
|
|
|
msg = msg + EventString(ev) + "\n"
|
|
|
|
}
|
|
|
|
klog.Error(msg)
|
|
|
|
}
|