代码拉取完成,页面将自动刷新
package cibot
import (
"context"
"encoding/json"
"fmt"
"net/http"
"gitee.com/openeuler/ci-bot/pkg/cibot/config"
"gitee.com/openeuler/go-gitee/gitee"
"github.com/golang/glog"
)
type Server struct {
Config config.Config
Context context.Context
GiteeClient *gitee.APIClient
}
// ServeHTTP validates an incoming webhook and invoke its handler.
func (s *Server) ServeHTTP(w http.ResponseWriter, r *http.Request) {
glog.Info("received a webhook event")
// validate the webhook secret
payload, err := gitee.ValidatePayload(r, []byte(s.Config.WebhookSecret))
if err != nil {
glog.Errorf("invalid payload: %v", err)
w.WriteHeader(http.StatusBadRequest)
fmt.Fprint(w, err.Error())
return
}
// parse into Event
messagetype := gitee.WebHookType(r)
glog.Infof("message type: %v", messagetype)
event, err := gitee.ParseWebHook(messagetype, payload)
if err != nil {
glog.Errorf("failed to parse webhook event: %v", err)
w.WriteHeader(http.StatusInternalServerError)
fmt.Fprint(w, err.Error())
return
}
// response avoids gitee timeout 5s
fmt.Fprint(w, "handle webhook event successfully")
var client http.Client
client.Do(r)
// handle events
switch event.(type) {
case *gitee.NoteEvent:
glog.Info("received a note event")
go s.HandleNoteEvent(event.(*gitee.NoteEvent))
case *gitee.PushEvent:
glog.Info("received a push event")
go s.HandlePushEvent(event.(*gitee.PushEvent))
case *gitee.IssueEvent:
glog.Info("received a issue event")
go s.HandleIssueEvent(event.(*gitee.IssueEvent))
case *gitee.PullRequestEvent:
glog.Info("received a pull request event")
actionDesc:= struct {
ActionDesc string `json:"action_desc,omitempty"`
}{}
err := json.Unmarshal(payload, &actionDesc)
if err != nil{
glog.Info(err)
}
go s.HandlePullRequestEvent(actionDesc.ActionDesc,event.(*gitee.PullRequestEvent))
case *gitee.TagPushEvent:
glog.Info("received a tag push event")
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。