Skip to content

Commit

Permalink
Add supervisor logs (#131)
Browse files Browse the repository at this point in the history
* Update devcontainer config

* Add supervisor logs proxy
  • Loading branch information
wendevlin authored Nov 19, 2024
1 parent 67abf8b commit ac9b202
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 17 deletions.
32 changes: 17 additions & 15 deletions .devcontainer.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,19 +7,21 @@
"containerEnv": {
"DEVELOPMENT": "True"
},
"settings": {
"terminal.integrated.shell.linux": "/bin/bash",
"go.useGoProxyToCheckForToolUpdates": false,
"go.useLanguageServer": true,
"go.gopath": "/go",
"go.goroot": "/usr/local/go",
"go.toolsGopath": "/go/bin",
"go.lintTool":"golangci-lint",
"go.lintFlags": [
"--fast"
]
},
"extensions": [
"golang.Go"
]
"customizations": {
"vscode": {
"settings": {
"terminal.integrated.shell.linux": "/bin/bash",
"go.useGoProxyToCheckForToolUpdates": false,
"go.useLanguageServer": true,
"go.gopath": "/go",
"go.goroot": "/usr/local/go",
"go.toolsGopath": "/go/bin",
"go.lintTool":"golangci-lint",
"go.lintFlags": [
"--fast"
]
},
"extensions": ["golang.Go"]
}
}
}
16 changes: 15 additions & 1 deletion http.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,13 @@ func httpSupervisorProxy(w http.ResponseWriter, r *http.Request) {
log.Printf("Proxy request: %s", r.URL.Path)

// Base Supervisor URL
u, err := url.Parse("http://supervisor/")
supervisorHost := "supervisor"

if development && os.Getenv("SUPERVISOR_HOST") != "" {
supervisorHost = os.Getenv("SUPERVISOR_HOST")
}

u, err := url.Parse("http://" + supervisorHost + "/")
if err != nil {
// Handle error in parsing URL
w.Write([]byte(err.Error()))
Expand Down Expand Up @@ -100,6 +106,14 @@ func httpSupervisorProxy(w http.ResponseWriter, r *http.Request) {
// Add authorization header
r.Header.Add("Authorization", "Bearer "+os.Getenv("SUPERVISOR_TOKEN"))

if cleanPath == "/logs" {
// for logs download add text/plain headers
r.Header.Add("Accept", "text/plain")
} else if cleanPath == "/logs/follow" {
// Set FlushInterval to enable streaming
proxy.FlushInterval = -1
}

// Forward the request
proxy.ServeHTTP(w, r)
}
6 changes: 5 additions & 1 deletion main.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@ var development bool
func main() {
development = (os.Getenv("DEVELOPMENT") == "True")

if development {
if development && os.Getenv("FRONTEND_PATH") != "" {
wwwRoot = os.Getenv("FRONTEND_PATH") + "/landing-page/dist/"
} else if development {
wwwRoot = "./rootfs/usr/share/www/"
} else {
wwwRoot = "/usr/share/www/"
Expand All @@ -27,6 +29,8 @@ func main() {
http.HandleFunc("/api/", httpUnauthorized)
http.HandleFunc("/auth/token", httpBad)
http.HandleFunc("/observer/logs", httpLogs)
http.HandleFunc("/supervisor/supervisor/logs", httpSupervisorProxy)
http.HandleFunc("/supervisor/supervisor/logs/follow", httpSupervisorProxy)
http.HandleFunc("/supervisor/resolution/", httpSupervisorProxy)
http.HandleFunc("/supervisor/network/", httpSupervisorProxy)

Expand Down

0 comments on commit ac9b202

Please sign in to comment.