feat: Switch from Loki to something else
All checks were successful
ci/woodpecker/push/woodpecker Pipeline was successful

This commit is contained in:
PapaTutuWawa 2024-02-09 15:31:04 +01:00
parent 4b4bc9792b
commit 617b68f43e
4 changed files with 25 additions and 48 deletions

View File

@ -145,7 +145,7 @@ func runServer(ctx *cli.Context) error {
acmeDnsProvider := ctx.String("acme-dns-provider") acmeDnsProvider := ctx.String("acme-dns-provider")
acmeDisable := ctx.Bool("acme-disable") acmeDisable := ctx.Bool("acme-disable")
defaultCsp := ctx.String("default-csp") defaultCsp := ctx.String("default-csp")
lokiUrl := ctx.String("loki-url") metricsUrl := ctx.String("metrics-url")
metricsBotList := ctx.String("metrics-bot-list") metricsBotList := ctx.String("metrics-bot-list")
tokenFile := ctx.String("token-file") tokenFile := ctx.String("token-file")
@ -157,9 +157,9 @@ func runServer(ctx *cli.Context) error {
} }
// Set up the Loki metrics // Set up the Loki metrics
var lokiConfig metrics.LokiMetricConfig var lokiConfig metrics.MetricConfig
if lokiUrl == "" { if metricsUrl == "" {
lokiConfig = metrics.LokiMetricConfig{ lokiConfig = metrics.MetricConfig{
Enabled: false, Enabled: false,
} }
} else { } else {
@ -171,10 +171,10 @@ func runServer(ctx *cli.Context) error {
} }
log.Infof("Read %d bot patterns from disk", len(patterns)) log.Infof("Read %d bot patterns from disk", len(patterns))
lokiConfig = metrics.LokiMetricConfig{ lokiConfig = metrics.MetricConfig{
Enabled: true, Enabled: true,
BotUserAgents: &patterns, BotUserAgents: &patterns,
Url: lokiUrl, Url: metricsUrl,
} }
} }
@ -414,10 +414,10 @@ func main() {
EnvVars: []string{"DEFAULT_CSP"}, EnvVars: []string{"DEFAULT_CSP"},
}, },
&cli.StringFlag{ &cli.StringFlag{
Name: "loki-url", Name: "metrics-url",
Usage: "The URL for Loki metric pings", Usage: "The URL for metric pings",
Value: "", Value: "",
EnvVars: []string{"LOKI_URL"}, EnvVars: []string{"METRICS_URL"},
}, },
&cli.StringFlag{ &cli.StringFlag{
Name: "metrics-bot-list", Name: "metrics-bot-list",

View File

@ -23,7 +23,7 @@ type GlobalContext struct {
DefaultCSP string DefaultCSP string
PagesDomain string PagesDomain string
Gitea *gitea.GiteaClient Gitea *gitea.GiteaClient
MetricConfig *metrics.LokiMetricConfig MetricConfig *metrics.MetricConfig
Cache *CacheContext Cache *CacheContext
} }

View File

@ -2,25 +2,22 @@ package metrics
import ( import (
"encoding/json" "encoding/json"
"fmt"
"io/ioutil"
"net/http" "net/http"
"os"
"regexp" "regexp"
"strconv"
"strings" "strings"
"time"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
) )
type LokiMetricConfig struct { type MetricConfig struct {
Url string Url string
BotUserAgents *[]regexp.Regexp BotUserAgents *[]regexp.Regexp
Enabled bool Enabled bool
} }
// Checks if we should send a metric ping to Loki based on the served path. // Checks if we should send a metric ping to Loki based on the served path.
func (c *LokiMetricConfig) ShouldSendMetrics(path, userAgent string) bool { func (c *MetricConfig) ShouldSendMetrics(path, userAgent string) bool {
if !strings.HasSuffix(path, ".html") || !c.Enabled { if !strings.HasSuffix(path, ".html") || !c.Enabled {
return false return false
} }
@ -35,35 +32,21 @@ func (c *LokiMetricConfig) ShouldSendMetrics(path, userAgent string) bool {
return true return true
} }
func (c *LokiMetricConfig) SendMetricPing(domain, path, referrer string) { func (c *MetricConfig) SendMetricPing(domain, path, referrer string) {
msg := fmt.Sprintf("path=\"%s\" referrer=\"%s\"", path, referrer) data := map[string]string{
data := map[string]interface{}{
"streams": []map[string]interface{}{
{
"stream": map[string]string{
// Labels
"service": "rio",
"domain": domain, "domain": domain,
"type": "metric", "path": path,
}, "referer": referrer,
"values": [][]interface{}{
{
strconv.Itoa(int(time.Now().UnixNano())),
msg,
},
},
},
},
} }
jsonData, err := json.Marshal(data) jsonData, err := json.Marshal(data)
if err != nil { if err != nil {
log.Errorf("Failed to send metric ping to Loki: %v", err) log.Errorf("Failed to send metric ping: %v", err)
return return
} }
log.Debugf("Sending payload %s", string(jsonData)) log.Debugf("Sending payload %s", string(jsonData))
// Send the ping to the Loki server // Send the ping to the server
go func() { go func() {
res, err := http.Post( res, err := http.Post(
c.Url, c.Url,
@ -71,19 +54,13 @@ func (c *LokiMetricConfig) SendMetricPing(domain, path, referrer string) {
strings.NewReader(string(jsonData)), strings.NewReader(string(jsonData)),
) )
if err != nil { if err != nil {
log.Errorf("Failed to send payload to Loki: %v", err) log.Errorf("Failed to send payload to: %v", err)
return return
} }
defer res.Body.Close() defer res.Body.Close()
if res.StatusCode != 204 { if res.StatusCode != 200 {
log.Errorf("Loki returned non-204 status code %d", res.StatusCode) log.Errorf("Server returned non-200 status code %d", res.StatusCode)
body, err := ioutil.ReadAll(res.Body)
if err != nil {
log.Warnf("Failed to read body. No more specific error message")
return
}
log.Errorf("-> %s", body)
} }
}() }()
} }
@ -91,7 +68,7 @@ func (c *LokiMetricConfig) SendMetricPing(domain, path, referrer string) {
// Reads a JSON array of bot user agents from disk and parses them // Reads a JSON array of bot user agents from disk and parses them
// into regular expressions. // into regular expressions.
func ReadBotPatterns(file string) ([]regexp.Regexp, error) { func ReadBotPatterns(file string) ([]regexp.Regexp, error) {
content, err := ioutil.ReadFile(file) content, err := os.ReadFile(file)
if err != nil { if err != nil {
log.Warnf("Failed to read bot metrics file: %v", err) log.Warnf("Failed to read bot metrics file: %v", err)
return []regexp.Regexp{}, err return []regexp.Regexp{}, err

View File

@ -6,7 +6,7 @@ import (
) )
func TestShouldPing(t *testing.T) { func TestShouldPing(t *testing.T) {
cfg := LokiMetricConfig{ cfg := MetricConfig{
Enabled: true, Enabled: true,
Url: "", Url: "",
BotUserAgents: &[]regexp.Regexp{ BotUserAgents: &[]regexp.Regexp{