mirror of
https://github.com/k8sgpt-ai/k8sgpt.git
synced 2025-09-09 11:10:40 +00:00
feat: add simple health endpoint
Signed-off-by: Thomas Schuetz <thomas.schuetz@t-sc.eu>
This commit is contained in:
@@ -1,11 +1,11 @@
|
|||||||
package server
|
package server
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
json "encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/fatih/color"
|
"github.com/fatih/color"
|
||||||
"github.com/k8sgpt-ai/k8sgpt/pkg/analysis"
|
"github.com/k8sgpt-ai/k8sgpt/pkg/analysis"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
@@ -18,6 +18,18 @@ type Config struct {
|
|||||||
Output string
|
Output string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type Health struct {
|
||||||
|
Status string `json:"status"`
|
||||||
|
Success int `json:"success"`
|
||||||
|
Failure int `json:"failure"`
|
||||||
|
}
|
||||||
|
|
||||||
|
var health = Health{
|
||||||
|
Status: "ok",
|
||||||
|
Success: 0,
|
||||||
|
Failure: 0,
|
||||||
|
}
|
||||||
|
|
||||||
type Result struct {
|
type Result struct {
|
||||||
Analysis []analysis.Analysis `json:"analysis"`
|
Analysis []analysis.Analysis `json:"analysis"`
|
||||||
}
|
}
|
||||||
@@ -31,35 +43,40 @@ func (s *Config) analyzeHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
|
|
||||||
config, err := analysis.NewAnalysis(s.Backend, language, []string{}, namespace, nocache, explain)
|
config, err := analysis.NewAnalysis(s.Backend, language, []string{}, namespace, nocache, explain)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
health.Failure++
|
||||||
fmt.Fprintf(w, err.Error())
|
fmt.Fprintf(w, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
err = config.RunAnalysis()
|
err = config.RunAnalysis()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
color.Red("Error: %v", err)
|
color.Red("Error: %v", err)
|
||||||
os.Exit(1)
|
health.Failure++
|
||||||
|
fmt.Fprintf(w, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
if explain {
|
if explain {
|
||||||
err := config.GetAIResults(s.Output, anonymize)
|
err := config.GetAIResults(s.Output, anonymize)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
color.Red("Error: %v", err)
|
color.Red("Error: %v", err)
|
||||||
os.Exit(1)
|
health.Failure++
|
||||||
|
fmt.Fprintf(w, err.Error())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
output, err := config.JsonOutput()
|
output, err := config.JsonOutput()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
color.Red("Error: %v", err)
|
color.Red("Error: %v", err)
|
||||||
os.Exit(1)
|
health.Failure++
|
||||||
|
fmt.Fprintf(w, err.Error())
|
||||||
}
|
}
|
||||||
|
health.Success++
|
||||||
fmt.Fprintf(w, string(output))
|
fmt.Fprintf(w, string(output))
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Config) Serve() error {
|
func (s *Config) Serve() error {
|
||||||
http.HandleFunc("/analyze", s.analyzeHandler)
|
http.HandleFunc("/analyze", s.analyzeHandler)
|
||||||
color.Green("Starting server on port %d", s.Port)
|
http.HandleFunc("/healthz", s.healthzHandler)
|
||||||
|
color.Green("Starting server on port %s", s.Port)
|
||||||
err := http.ListenAndServe(":"+s.Port, nil)
|
err := http.ListenAndServe(":"+s.Port, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("error starting server: %s\n", err)
|
fmt.Printf("error starting server: %s\n", err)
|
||||||
@@ -68,6 +85,15 @@ func (s *Config) Serve() error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *Config) healthzHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
|
js, err := json.MarshalIndent(health, "", " ")
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
fmt.Fprintf(w, string(js))
|
||||||
|
}
|
||||||
|
|
||||||
func getBoolParam(param string) bool {
|
func getBoolParam(param string) bool {
|
||||||
b, err := strconv.ParseBool(strings.ToLower(param))
|
b, err := strconv.ParseBool(strings.ToLower(param))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Reference in New Issue
Block a user