gogs_runner/main.go
LollipopKit a78cd5bc3a initial
2022-06-01 16:34:03 +08:00

59 lines
1.4 KiB
Go

package main
import (
"encoding/json"
"fmt"
"io/ioutil"
"log"
"net/http"
"os/exec"
"strings"
)
const (
path = "/"
)
func main() {
http.HandleFunc(path, func(w http.ResponseWriter, r *http.Request) {
reqBody, err := ioutil.ReadAll(r.Body)
if err != nil {
log.Fatalf("Error reading request body: %v\n", err)
w.Write([]byte(fmt.Sprintf("Read body error: %s", err)))
return
}
var payload GogsPayload
err = json.Unmarshal(reqBody, &payload)
if err != nil {
log.Fatalf("Error unmarshalling request body: %v\n", err)
w.Write([]byte(fmt.Sprintf("Unmarshal body error: %s", err)))
return
}
log.Printf("Received: [Name] %s [Sender] %s", payload.Repository.FullName, payload.Sender.FullName)
for _, commit := range payload.Commits {
if strings.Contains(commit.Message, "[DEPLOY]") {
log.Printf("Commit: [SHA] %s [Message] %s\n", commit.ID, commit.Message)
log.Println("Ready to deploy")
cmd := exec.Command("python3", fmt.Sprintf("~/pro/%s/deploy.py", payload.Repository.Name))
err = cmd.Run()
if err != nil {
log.Fatalf("Error running deploy script: %v\n", err)
w.Write([]byte(fmt.Sprintf("Deploy script error: %s", err)))
}
return
}
}
log.Println("No deploy commit found")
w.Write([]byte("No deploy commit found. Skip."))
})
log.Println("Webhook service started.")
http.ListenAndServe(":3001", nil)
}