Files
p/main.go

113 lines
2.2 KiB
Go
Raw Normal View History

2024-11-21 14:59:10 -08:00
package main
import (
2024-11-21 21:42:03 -08:00
"bytes"
"encoding/json"
2024-11-21 14:59:10 -08:00
"fmt"
2024-11-21 21:42:03 -08:00
"io"
"log"
2024-11-21 14:59:10 -08:00
"net/http"
"os"
)
2024-11-21 21:42:03 -08:00
type PDAlert struct {
RoutingKey string `json:"routing_key"`
EventAction string `json:"event_action"`
Payload PDPayload `json:"payload"`
}
type PDPayload struct {
Summary string `json:"summary"`
Source string `json:"source"`
Severity string `json:"severity"`
}
type PHandler struct {
2024-11-22 13:49:31 -08:00
routingKey string
2024-11-21 21:42:03 -08:00
next http.Handler
}
2024-11-22 13:49:31 -08:00
func NewPHandler(routingKey string, next http.Handler) *PHandler {
2024-11-21 21:42:03 -08:00
return &PHandler{
2024-11-22 13:49:31 -08:00
routingKey: routingKey,
2024-11-21 21:42:03 -08:00
next: next,
}
}
func (ph *PHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
err := r.ParseForm()
if err != nil {
http.Error(w, fmt.Sprintf("invalid form: %s\n", err), http.StatusBadRequest)
return
}
2024-11-22 13:49:31 -08:00
log.Printf("%s %s", r.RemoteAddr, r.Form.Encode())
2024-11-21 21:42:03 -08:00
msg := r.Form.Get("msg")
if msg == "" {
ph.next.ServeHTTP(w, r)
return
}
2024-11-21 14:59:10 -08:00
2024-11-21 21:42:03 -08:00
buf := &bytes.Buffer{}
err = json.NewEncoder(buf).Encode(PDAlert{
2024-11-22 13:49:31 -08:00
RoutingKey: ph.routingKey,
2024-11-21 21:42:03 -08:00
EventAction: "trigger",
Payload: PDPayload{
Summary: msg,
2024-11-22 13:49:31 -08:00
Source: r.RemoteAddr,
2024-11-21 21:42:03 -08:00
Severity: "critical",
},
})
if err != nil {
http.Error(w, fmt.Sprintf("failed to create PD request: %s\n", err), http.StatusBadRequest)
return
}
req, err := http.NewRequest("POST", "https://events.pagerduty.com/v2/enqueue", buf)
if err != nil {
http.Error(w, fmt.Sprintf("failed to create HTTP request: %s\n", err), http.StatusBadRequest)
return
}
c := &http.Client{}
res, err := c.Do(req)
if err != nil {
http.Error(w, fmt.Sprintf("error from PD: %s\n", err), http.StatusBadRequest)
return
}
body, _ := io.ReadAll(res.Body)
res.Body.Close()
if res.StatusCode != 202 {
http.Error(w, fmt.Sprintf("error from PD: %s", string(body)), http.StatusBadRequest)
return
}
w.Write([]byte("page sent\n"))
}
func main() {
2024-11-22 13:49:31 -08:00
routingKey := os.Getenv("PD_ROUTING_KEY")
if routingKey == "" {
log.Fatalf("please set PD_ROUTING_KEY")
}
http.Handle("/", NewPHandler(routingKey, http.FileServer(http.Dir("./static"))))
2024-11-21 14:59:10 -08:00
port := os.Getenv("PORT")
if port == "" {
port = "80"
}
2024-11-21 21:42:03 -08:00
bind := fmt.Sprintf(":%s", port)
log.Printf("listening on %s", bind)
2024-11-21 14:59:10 -08:00
2024-11-21 21:42:03 -08:00
if err := http.ListenAndServe(bind, nil); err != nil {
2024-11-22 13:49:31 -08:00
log.Fatalf("listen: %s", err)
2024-11-21 14:59:10 -08:00
}
}