checker: split monolithic rule into per-concern rules
Replace the single matrix_federation rule with individual rules for federation status, well-known delegation, SRV records, connection reachability, TLS checks, and homeserver version, so the UI surfaces a clear checklist. Drop the incorrect well-known/server_name equality check: m.server points at the delegated federation endpoint, which is intentionally distinct from server_name.
This commit is contained in:
parent
2bd0ae99bd
commit
e4b6481d32
8 changed files with 346 additions and 60 deletions
40
checker/rules_connection.go
Normal file
40
checker/rules_connection.go
Normal file
|
|
@ -0,0 +1,40 @@
|
|||
package checker
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
sdk "git.happydns.org/checker-sdk-go/checker"
|
||||
)
|
||||
|
||||
// connectionReachableRule checks that every federation endpoint returned
|
||||
// by DNS accepted the TLS connection the tester attempted.
|
||||
type connectionReachableRule struct{}
|
||||
|
||||
func (r *connectionReachableRule) Name() string { return "matrix.connection_reachable" }
|
||||
func (r *connectionReachableRule) Description() string {
|
||||
return "Checks that every discovered federation endpoint accepts an inbound connection."
|
||||
}
|
||||
|
||||
func (r *connectionReachableRule) Evaluate(ctx context.Context, obs sdk.ObservationGetter, _ sdk.CheckerOptions) []sdk.CheckState {
|
||||
data, errSt := loadMatrixData(ctx, obs)
|
||||
if errSt != nil {
|
||||
return []sdk.CheckState{*errSt}
|
||||
}
|
||||
|
||||
if len(data.ConnectionErrors) == 0 && len(data.ConnectionReports) == 0 {
|
||||
return []sdk.CheckState{infoState("matrix.connection_reachable.unknown", "No endpoint was probed by the federation tester.")}
|
||||
}
|
||||
|
||||
if len(data.ConnectionErrors) == 0 {
|
||||
return []sdk.CheckState{passState("matrix.connection_reachable.ok", fmt.Sprintf("All %d endpoint(s) accepted the connection.", len(data.ConnectionReports)))}
|
||||
}
|
||||
|
||||
out := make([]sdk.CheckState, 0, len(data.ConnectionErrors))
|
||||
for addr, cerr := range data.ConnectionErrors {
|
||||
st := critState("matrix.connection_reachable.fail", cerr.Message)
|
||||
st.Subject = addr
|
||||
out = append(out, st)
|
||||
}
|
||||
return out
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue