mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-04 14:48:42 +00:00
parent
ce222dfe0e
commit
5e595978fa
3 changed files with 10 additions and 16 deletions
|
@ -269,7 +269,7 @@ func DeleteBuild(c *gin.Context) {
|
||||||
_ = c.AbortWithError(http.StatusInternalServerError, err)
|
_ = c.AbortWithError(http.StatusInternalServerError, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if err := publishToTopic(c, killedBuild, repo, model.Canceled); err != nil {
|
if err := publishToTopic(c, killedBuild, repo); err != nil {
|
||||||
log.Error().Err(err).Msg("publishToTopic")
|
log.Error().Err(err).Msg("publishToTopic")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -366,6 +366,10 @@ func PostDecline(c *gin.Context) {
|
||||||
log.Error().Err(err).Msg("updateBuildStatus")
|
log.Error().Err(err).Msg("updateBuildStatus")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := publishToTopic(c, build, repo); err != nil {
|
||||||
|
log.Error().Err(err).Msg("publishToTopic")
|
||||||
|
}
|
||||||
|
|
||||||
c.JSON(200, build)
|
c.JSON(200, build)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -609,7 +613,7 @@ func startBuild(ctx context.Context, store store.Store, build *model.Build, user
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := publishToTopic(ctx, build, repo, model.Enqueued); err != nil {
|
if err := publishToTopic(ctx, build, repo); err != nil {
|
||||||
log.Error().Err(err).Msg("publishToTopic")
|
log.Error().Err(err).Msg("publishToTopic")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -245,7 +245,7 @@ func PostHook(c *gin.Context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if build.Status == model.StatusBlocked {
|
if build.Status == model.StatusBlocked {
|
||||||
if err := publishToTopic(c, build, repo, model.Enqueued); err != nil {
|
if err := publishToTopic(c, build, repo); err != nil {
|
||||||
log.Error().Err(err).Msg("publishToTopic")
|
log.Error().Err(err).Msg("publishToTopic")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -346,7 +346,7 @@ func findOrPersistPipelineConfig(store store.Store, build *model.Build, remoteYa
|
||||||
}
|
}
|
||||||
|
|
||||||
// publishes message to UI clients
|
// publishes message to UI clients
|
||||||
func publishToTopic(c context.Context, build *model.Build, repo *model.Repo, event model.EventType) (err error) {
|
func publishToTopic(c context.Context, build *model.Build, repo *model.Repo) (err error) {
|
||||||
message := pubsub.Message{
|
message := pubsub.Message{
|
||||||
Labels: map[string]string{
|
Labels: map[string]string{
|
||||||
"repo": repo.FullName,
|
"repo": repo.FullName,
|
||||||
|
@ -359,7 +359,6 @@ func publishToTopic(c context.Context, build *model.Build, repo *model.Repo, eve
|
||||||
}
|
}
|
||||||
|
|
||||||
message.Data, _ = json.Marshal(model.Event{
|
message.Data, _ = json.Marshal(model.Event{
|
||||||
Type: model.Enqueued,
|
|
||||||
Repo: *repo,
|
Repo: *repo,
|
||||||
Build: buildCopy,
|
Build: buildCopy,
|
||||||
})
|
})
|
||||||
|
|
|
@ -17,17 +17,8 @@ package model
|
||||||
// EventType defines the possible types of build events.
|
// EventType defines the possible types of build events.
|
||||||
type EventType string
|
type EventType string
|
||||||
|
|
||||||
const (
|
|
||||||
Enqueued EventType = "enqueued"
|
|
||||||
Started EventType = "started"
|
|
||||||
Finished EventType = "finished"
|
|
||||||
Canceled EventType = "canceled"
|
|
||||||
)
|
|
||||||
|
|
||||||
// Event represents a build event.
|
// Event represents a build event.
|
||||||
type Event struct {
|
type Event struct {
|
||||||
Type EventType `json:"type"`
|
Repo Repo `json:"repo"`
|
||||||
Repo Repo `json:"repo"`
|
Build Build `json:"build"`
|
||||||
Build Build `json:"build"`
|
|
||||||
Proc Proc `json:"proc"`
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue