autogits/bots-common/listen.go

112 lines
3.3 KiB
Go
Raw Normal View History

2024-07-08 17:14:26 +02:00
package common
import (
"log"
"net/http"
"net/url"
)
2024-08-26 17:07:52 +02:00
const RequestType_CreateBrachTag = "create"
const RequestType_DeleteBranchTag = "delete"
const RequestType_Fork = "fork"
const RequestType_Issue = "issues"
const RequestType_IssueAssign = "issue_assign"
const RequestType_IssueComment = "issue_comment"
const RequestType_IssueLabel = "issue_label"
const RequestType_IssueMilestone = "issue_milestone"
2024-07-08 17:14:26 +02:00
const RequestType_Push = "push"
const RequestType_Repository = "repository"
2024-08-26 17:07:52 +02:00
const RequestType_Release = "release"
2024-07-09 12:06:24 +02:00
const RequestType_PR = "pull_request"
2024-08-26 17:30:36 +02:00
const RequestType_PRAssign = "pull_request_assign"
2024-08-26 17:38:55 +02:00
const RequestType_PRLabel = "pull_request_label"
2024-08-26 17:07:52 +02:00
const RequestType_PRComment = "pull_request_comment"
2024-08-26 17:30:36 +02:00
const RequestType_PRMilestone = "pull_request_milestone"
const RequestType_PRSync = "pull_request_sync"
const RequestType_PRReviewAccepted = "pull_request_review_approved"
const RequestType_PRReviewRejected = "pull_request_review_rejected"
const RequestType_PRReviewRequest = "pull_request_review_request"
const RequestType_Wiki = "wiki"
2024-07-08 17:14:26 +02:00
type RequestProcessor func(*RequestHandler) error
type ListenDefinitions struct {
GitAuthor, Url string
Handlers map[string]RequestProcessor
}
2024-08-26 17:07:52 +02:00
func StartServer(listenDefs ListenDefinitions, config []*AutogitConfig) {
2024-07-09 14:55:12 +02:00
}
func StartServerWithAddress(listenDefs ListenDefinitions, addr string) {
2024-07-08 17:14:26 +02:00
if listenDefs.Url != url.PathEscape(listenDefs.Url) {
log.Fatalf("Invalid Url fragment (%s) to listen on. Aborting", listenDefs.Url)
}
http.HandleFunc("/"+listenDefs.Url, func(res http.ResponseWriter, req *http.Request) {
h := CreateRequestHandler(listenDefs.GitAuthor, listenDefs.Url)
2024-08-13 16:42:20 +02:00
defer h.Close()
2024-07-08 17:14:26 +02:00
if len(req.Header.Get("Content-Type")) == 0 ||
req.Header["Content-Type"][0] != "application/json" ||
req.Method != "POST" {
h.WriteError()
res.WriteHeader(http.StatusInternalServerError)
return
}
hdr := req.Header[GiteaRequestHeader]
if len(hdr) != 1 {
2024-08-24 13:32:39 +02:00
h.ErrLogger.Printf("Unsupported number of %s headers: %d: %#v\n", GiteaRequestHeader, len(hdr), hdr)
2024-07-08 17:14:26 +02:00
h.WriteError()
res.WriteHeader(http.StatusInternalServerError)
return
}
reqType := hdr[0]
if handler, ok := listenDefs.Handlers[reqType]; ok {
2024-07-09 12:06:24 +02:00
switch reqType {
case RequestType_Repository:
h.parseRepositoryRequest(req.Body)
case RequestType_Push:
h.parsePushRequest(req.Body)
case RequestType_PR:
h.parsePullRequest(req.Body)
2024-08-26 17:30:36 +02:00
case RequestType_PRSync:
2024-07-10 17:29:36 +02:00
h.parsePullRequestSync(req.Body)
2024-07-09 12:06:24 +02:00
default:
2024-08-24 13:32:39 +02:00
h.ErrLogger.Printf("Unhandled request type: %s\n", reqType)
2024-07-09 12:06:24 +02:00
res.WriteHeader(http.StatusInternalServerError)
return
}
2024-07-09 23:52:28 +02:00
if h.HasError() {
2024-08-24 13:32:39 +02:00
h.ErrLogger.Printf("error in parser %s: %v\n", reqType, h.Error)
2024-07-09 23:52:28 +02:00
res.WriteHeader(http.StatusInternalServerError)
return
}
2024-07-08 17:14:26 +02:00
if err := handler(h); err != nil {
2024-08-24 13:32:39 +02:00
h.ErrLogger.Printf("error in handler for %s: %v\n", reqType, err)
2024-07-08 17:14:26 +02:00
res.WriteHeader(http.StatusInternalServerError)
return
}
} else {
2024-08-24 13:32:39 +02:00
h.ErrLogger.Printf("Unsupported request type: %s\n", reqType)
2024-07-08 17:14:26 +02:00
res.WriteHeader(http.StatusInternalServerError)
2024-07-09 12:06:24 +02:00
return
2024-07-08 17:14:26 +02:00
}
if h.HasError() {
h.WriteError()
res.WriteHeader(http.StatusInternalServerError)
return
}
res.Header().Add("Content-Type", "application/json")
res.WriteHeader(http.StatusOK)
})
2024-07-09 14:55:12 +02:00
log.Fatal(http.ListenAndServe(addr, nil))
2024-07-08 17:14:26 +02:00
}