2023-07-01 05:21:49 -07:00
// Copyright 2023 The Prometheus 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 collector
import (
"fmt"
2024-09-11 01:51:28 -07:00
"log/slog"
2023-07-01 05:21:49 -07:00
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/procfs/sysfs"
)
const (
cpuVulerabilitiesCollector = "cpu_vulnerabilities"
)
var (
vulnerabilityDesc = prometheus . NewDesc (
prometheus . BuildFQName ( namespace , cpuVulerabilitiesCollector , "info" ) ,
"Details of each CPU vulnerability reported by sysfs. The value of the series is an int encoded state of the vulnerability. The same state is stored as a string in the label" ,
2023-12-14 04:15:27 -08:00
[ ] string { "codename" , "state" , "mitigation" } ,
2023-07-01 05:21:49 -07:00
nil ,
)
)
type cpuVulnerabilitiesCollector struct { }
func init ( ) {
registerCollector ( cpuVulerabilitiesCollector , defaultDisabled , NewVulnerabilitySysfsCollector )
}
2024-09-11 01:51:28 -07:00
func NewVulnerabilitySysfsCollector ( logger * slog . Logger ) ( Collector , error ) {
2023-07-01 05:21:49 -07:00
return & cpuVulnerabilitiesCollector { } , nil
}
func ( v * cpuVulnerabilitiesCollector ) Update ( ch chan <- prometheus . Metric ) error {
fs , err := sysfs . NewFS ( * sysPath )
if err != nil {
return fmt . Errorf ( "failed to open sysfs: %w" , err )
}
vulnerabilities , err := fs . CPUVulnerabilities ( )
if err != nil {
return fmt . Errorf ( "failed to get vulnerabilities: %w" , err )
}
for _ , vulnerability := range vulnerabilities {
ch <- prometheus . MustNewConstMetric (
vulnerabilityDesc ,
prometheus . GaugeValue ,
1.0 ,
vulnerability . CodeName ,
sysfs . VulnerabilityHumanEncoding [ vulnerability . State ] ,
2023-12-14 04:15:27 -08:00
vulnerability . Mitigation ,
2023-07-01 05:21:49 -07:00
)
}
return nil
}