1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
package main
import (
"encoding/json"
"html/template"
"log"
"net/http"
"os/exec"
)
// Templates
var tpl = template.Must(template.ParseFiles("index.html"))
// Handlers
func indexHandler(w http.ResponseWriter, r *http.Request) {
tpl.Execute(w, nil)
}
// Run `networkctl status --json=short`
func statusHandler(w http.ResponseWriter, r *http.Request) {
cmd := exec.Command("networkctl", "status", "--json=short")
out, err := cmd.Output()
if err != nil {
http.Error(w, err.Error(), 500)
return
}
w.Header().Set("Content-Type", "application/json")
w.Write(out)
}
// Run `journalctl -u systemd-networkd.service --no-pager -n 200`
func logsHandler(w http.ResponseWriter, r *http.Request) {
cmd := exec.Command("journalctl", "-u", "systemd-networkd.service", "--no-pager", "-n", "200")
out, err := cmd.Output()
if err != nil {
http.Error(w, err.Error(), 500)
return
}
w.Header().Set("Content-Type", "text/plain")
w.Write(out)
}
// Reload systemd-networkd
func reloadHandler(w http.ResponseWriter, r *http.Request) {
cmd := exec.Command("systemctl", "restart", "systemd-networkd")
if err := cmd.Run(); err != nil {
http.Error(w, err.Error(), 500)
return
}
json.NewEncoder(w).Encode(map[string]string{"status": "restarted"})
}
// Reboot the system
func rebootHandler(w http.ResponseWriter, r *http.Request) {
cmd := exec.Command("systemctl", "reboot")
if err := cmd.Start(); err != nil {
http.Error(w, err.Error(), 500)
return
}
json.NewEncoder(w).Encode(map[string]string{"status": "rebooting"})
}
func main() {
http.HandleFunc("/", indexHandler)
http.HandleFunc("/api/status", statusHandler)
http.HandleFunc("/api/logs", logsHandler)
http.HandleFunc("/api/reload", reloadHandler)
http.HandleFunc("/api/reboot", rebootHandler)
log.Println("Listening on :8080")
log.Fatal(http.ListenAndServe(":8080", nil))
}
|