2023-01-09 13:42:53 +08:00
|
|
|
/*
|
|
|
|
* If changed, have to run `npm run build-docker-builder-go`.
|
|
|
|
* This script should be run after a period of time (180s), because the server may need some time to prepare.
|
|
|
|
*/
|
2022-12-07 16:15:00 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
|
|
|
"io/ioutil"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"runtime"
|
2023-01-30 21:46:27 +08:00
|
|
|
"strings"
|
2022-12-07 16:15:00 +08:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
isFreeBSD := runtime.GOOS == "freebsd"
|
|
|
|
|
2023-01-30 21:46:27 +08:00
|
|
|
// Is K8S + uptime-kuma as the container name
|
|
|
|
// See #2083
|
|
|
|
isK8s := strings.HasPrefix(os.Getenv("UPTIME_KUMA_PORT"), "tcp://")
|
|
|
|
|
2022-12-07 16:15:00 +08:00
|
|
|
// process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
|
|
|
|
http.DefaultTransport.(*http.Transport).TLSClientConfig = &tls.Config{
|
|
|
|
InsecureSkipVerify: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
client := http.Client{
|
|
|
|
Timeout: 28 * time.Second,
|
|
|
|
}
|
|
|
|
|
|
|
|
sslKey := os.Getenv("UPTIME_KUMA_SSL_KEY")
|
|
|
|
if len(sslKey) == 0 {
|
|
|
|
sslKey = os.Getenv("SSL_KEY")
|
|
|
|
}
|
|
|
|
|
|
|
|
sslCert := os.Getenv("UPTIME_KUMA_SSL_CERT")
|
|
|
|
if len(sslCert) == 0 {
|
|
|
|
sslCert = os.Getenv("SSL_CERT")
|
|
|
|
}
|
|
|
|
|
|
|
|
hostname := os.Getenv("UPTIME_KUMA_HOST")
|
|
|
|
if len(hostname) == 0 && !isFreeBSD {
|
|
|
|
hostname = os.Getenv("HOST")
|
|
|
|
}
|
|
|
|
if len(hostname) == 0 {
|
|
|
|
hostname = "127.0.0.1"
|
|
|
|
}
|
|
|
|
|
2023-01-30 21:46:27 +08:00
|
|
|
port := ""
|
|
|
|
// UPTIME_KUMA_PORT is override by K8S unexpectedly,
|
|
|
|
if !isK8s {
|
|
|
|
port = os.Getenv("UPTIME_KUMA_PORT")
|
|
|
|
}
|
2022-12-07 16:15:00 +08:00
|
|
|
if len(port) == 0 {
|
|
|
|
port = os.Getenv("PORT")
|
|
|
|
}
|
|
|
|
if len(port) == 0 {
|
|
|
|
port = "3001"
|
|
|
|
}
|
|
|
|
|
|
|
|
protocol := ""
|
2022-12-10 23:30:32 +08:00
|
|
|
if len(sslKey) != 0 && len(sslCert) != 0 {
|
2022-12-07 16:15:00 +08:00
|
|
|
protocol = "https"
|
|
|
|
} else {
|
|
|
|
protocol = "http"
|
|
|
|
}
|
|
|
|
|
|
|
|
url := protocol + "://" + hostname + ":" + port
|
|
|
|
|
|
|
|
log.Println("Checking " + url)
|
|
|
|
resp, err := client.Get(url)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
_, err = ioutil.ReadAll(resp.Body)
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
log.Printf("Health Check OK [Res Code: %d]\n", resp.StatusCode)
|
|
|
|
|
|
|
|
}
|