Compare commits
2 commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 59af24f695 | |||
| 8b7df15883 |
3 changed files with 8 additions and 8 deletions
|
|
@ -4,7 +4,6 @@ import (
|
||||||
"context"
|
"context"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
|
||||||
|
|
||||||
sdk "git.happydns.org/checker-sdk-go/checker"
|
sdk "git.happydns.org/checker-sdk-go/checker"
|
||||||
)
|
)
|
||||||
|
|
@ -64,7 +63,6 @@ func (p *caaProvider) Collect(ctx context.Context, opts sdk.CheckerOptions) (any
|
||||||
return &CAAData{
|
return &CAAData{
|
||||||
Domain: domain,
|
Domain: domain,
|
||||||
Records: records,
|
Records: records,
|
||||||
RunAt: time.Now().UTC().Format(time.RFC3339),
|
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -31,6 +31,7 @@ type issuerAgg struct {
|
||||||
code string
|
code string
|
||||||
msg string
|
msg string
|
||||||
endpoints map[string]bool
|
endpoints map[string]bool
|
||||||
|
count int // number of certificates observed from this issuer
|
||||||
}
|
}
|
||||||
|
|
||||||
type allowList struct {
|
type allowList struct {
|
||||||
|
|
@ -152,6 +153,7 @@ func (r *caaRule) Evaluate(ctx context.Context, obs sdk.ObservationGetter, opts
|
||||||
cur = &issuerAgg{sample: p, endpoints: map[string]bool{}}
|
cur = &issuerAgg{sample: p, endpoints: map[string]bool{}}
|
||||||
agg[k] = cur
|
agg[k] = cur
|
||||||
}
|
}
|
||||||
|
cur.count++
|
||||||
if severityRank(severity) >= severityRank(cur.severity) {
|
if severityRank(severity) >= severityRank(cur.severity) {
|
||||||
cur.severity = severity
|
cur.severity = severity
|
||||||
cur.code = code
|
cur.code = code
|
||||||
|
|
@ -233,22 +235,23 @@ func (r *caaRule) Evaluate(ctx context.Context, obs sdk.ObservationGetter, opts
|
||||||
endpoints = append(endpoints, ep)
|
endpoints = append(endpoints, ep)
|
||||||
}
|
}
|
||||||
sort.Strings(endpoints)
|
sort.Strings(endpoints)
|
||||||
meta := map[string]any{"endpoints": endpoints}
|
meta := map[string]any{"endpoints": endpoints, "cert_count": a.count}
|
||||||
|
|
||||||
|
certSuffix := fmt.Sprintf(" (%d certificate(s) checked)", a.count)
|
||||||
switch a.severity {
|
switch a.severity {
|
||||||
case SeverityCrit:
|
case SeverityCrit:
|
||||||
out = append(out, sdk.CheckState{
|
out = append(out, sdk.CheckState{
|
||||||
Status: sdk.StatusCrit, Message: a.msg, Code: a.code,
|
Status: sdk.StatusCrit, Message: a.msg + certSuffix, Code: a.code,
|
||||||
Subject: subject, Meta: meta,
|
Subject: subject, Meta: meta,
|
||||||
})
|
})
|
||||||
case SeverityWarn:
|
case SeverityWarn:
|
||||||
out = append(out, sdk.CheckState{
|
out = append(out, sdk.CheckState{
|
||||||
Status: sdk.StatusWarn, Message: a.msg, Code: a.code,
|
Status: sdk.StatusWarn, Message: a.msg + certSuffix, Code: a.code,
|
||||||
Subject: subject, Meta: meta,
|
Subject: subject, Meta: meta,
|
||||||
})
|
})
|
||||||
case SeverityInfo:
|
case SeverityInfo:
|
||||||
out = append(out, sdk.CheckState{
|
out = append(out, sdk.CheckState{
|
||||||
Status: sdk.StatusInfo, Message: a.msg, Code: a.code,
|
Status: sdk.StatusInfo, Message: a.msg + certSuffix, Code: a.code,
|
||||||
Subject: subject, Meta: meta,
|
Subject: subject, Meta: meta,
|
||||||
})
|
})
|
||||||
default:
|
default:
|
||||||
|
|
@ -257,7 +260,7 @@ func (r *caaRule) Evaluate(ctx context.Context, obs sdk.ObservationGetter, opts
|
||||||
msg = "Certificate observed; no CAA records published"
|
msg = "Certificate observed; no CAA records published"
|
||||||
}
|
}
|
||||||
out = append(out, sdk.CheckState{
|
out = append(out, sdk.CheckState{
|
||||||
Status: sdk.StatusOK, Message: msg, Code: CodeOK,
|
Status: sdk.StatusOK, Message: msg + certSuffix, Code: CodeOK,
|
||||||
Subject: subject, Meta: meta,
|
Subject: subject, Meta: meta,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -40,7 +40,6 @@ const (
|
||||||
type CAAData struct {
|
type CAAData struct {
|
||||||
Domain string `json:"domain,omitempty"`
|
Domain string `json:"domain,omitempty"`
|
||||||
Records []CAARecord `json:"records,omitempty"`
|
Records []CAARecord `json:"records,omitempty"`
|
||||||
RunAt string `json:"run_at,omitempty"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type CAARecord struct {
|
type CAARecord struct {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue