mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-30 10:11:23 +02:00
Use same func for accept gated pipelines and none gated pipelines (#594)
* write back to webhook caller what happend * skip sound like an error - it is none change that * improve hook func * dedup code & fix bugs that only existed on gated builds * startBuild use std context * wordings Co-authored-by: Anbraten <anton@ju60.de> * nit * todo done Co-authored-by: Anbraten <anton@ju60.de>
This commit is contained in:
parent
9e8d1a9294
commit
039bce7758
@ -19,6 +19,9 @@ package api
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"context"
|
||||||
|
"database/sql"
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -276,7 +279,6 @@ func DeleteBuild(c *gin.Context) {
|
|||||||
|
|
||||||
func PostApproval(c *gin.Context) {
|
func PostApproval(c *gin.Context) {
|
||||||
var (
|
var (
|
||||||
_remote = server.Config.Services.Remote
|
|
||||||
_store = store.FromContext(c)
|
_store = store.FromContext(c)
|
||||||
repo = session.Repo(c)
|
repo = session.Repo(c)
|
||||||
user = session.User(c)
|
user = session.User(c)
|
||||||
@ -289,7 +291,7 @@ func PostApproval(c *gin.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
if build.Status != model.StatusBlocked {
|
if build.Status != model.StatusBlocked {
|
||||||
c.String(500, "cannot decline a build with status %s", build.Status)
|
c.String(http.StatusBadRequest, "cannot decline a build with status %s", build.Status)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -301,30 +303,47 @@ func PostApproval(c *gin.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
netrc, err := _remote.Netrc(user, repo)
|
|
||||||
if err != nil {
|
|
||||||
c.String(500, "failed to generate netrc file. %s", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
if build, err = shared.UpdateToStatusPending(_store, *build, user.Login); err != nil {
|
if build, err = shared.UpdateToStatusPending(_store, *build, user.Login); err != nil {
|
||||||
c.String(500, "error updating build. %s", err)
|
c.String(http.StatusInternalServerError, "error updating build. %s", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
c.JSON(200, build)
|
var yamls []*remote.FileMeta
|
||||||
|
for _, y := range configs {
|
||||||
|
yamls = append(yamls, &remote.FileMeta{Data: y.Data, Name: y.Name})
|
||||||
|
}
|
||||||
|
|
||||||
|
build, err = startBuild(c, _store, build, user, repo, yamls)
|
||||||
|
if err != nil {
|
||||||
|
c.String(http.StatusInternalServerError, fmt.Sprintf("startBuild: %v", err))
|
||||||
|
}
|
||||||
|
c.JSON(200, build)
|
||||||
|
}
|
||||||
|
|
||||||
|
func startBuild(ctx context.Context, store store.Store, build *model.Build, user *model.User, repo *model.Repo, yamls []*remote.FileMeta) (*model.Build, error) {
|
||||||
|
netrc, err := server.Config.Services.Remote.Netrc(user, repo)
|
||||||
|
if err != nil {
|
||||||
|
msg := "Failed to generate netrc file"
|
||||||
|
log.Error().Err(err).Msg(msg)
|
||||||
|
return nil, fmt.Errorf("%s: %v", msg, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the previous build so that we can send status change notifications
|
||||||
|
last, err := store.GetBuildLastBefore(repo, build.Branch, build.ID)
|
||||||
|
if err != nil && !errors.Is(err, sql.ErrNoRows) {
|
||||||
|
log.Error().Err(err).Str("repo", repo.FullName).Msgf("Error getting last build before build number '%d'", build.Number)
|
||||||
|
}
|
||||||
|
|
||||||
// get the previous build so that we can send
|
|
||||||
// on status change notifications
|
|
||||||
last, _ := _store.GetBuildLastBefore(repo, build.Branch, build.ID)
|
|
||||||
secs, err := server.Config.Services.Secrets.SecretListBuild(repo, build)
|
secs, err := server.Config.Services.Secrets.SecretListBuild(repo, build)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Debug().Msgf("Error getting secrets for %s#%d. %s", repo.FullName, build.Number, err)
|
log.Error().Err(err).Msgf("Error getting secrets for %s#%d", repo.FullName, build.Number)
|
||||||
}
|
}
|
||||||
|
|
||||||
regs, err := server.Config.Services.Registries.RegistryList(repo)
|
regs, err := server.Config.Services.Registries.RegistryList(repo)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Debug().Msgf("Error getting registry credentials for %s#%d. %s", repo.FullName, build.Number, err)
|
log.Error().Err(err).Msgf("Error getting registry credentials for %s#%d", repo.FullName, build.Number)
|
||||||
}
|
}
|
||||||
|
|
||||||
envs := map[string]string{}
|
envs := map[string]string{}
|
||||||
if server.Config.Services.Environ != nil {
|
if server.Config.Services.Environ != nil {
|
||||||
globals, _ := server.Config.Services.Environ.EnvironList(repo)
|
globals, _ := server.Config.Services.Environ.EnvironList(repo)
|
||||||
@ -333,11 +352,6 @@ func PostApproval(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var yamls []*remote.FileMeta
|
|
||||||
for _, y := range configs {
|
|
||||||
yamls = append(yamls, &remote.FileMeta{Data: y.Data, Name: y.Name})
|
|
||||||
}
|
|
||||||
|
|
||||||
b := shared.ProcBuilder{
|
b := shared.ProcBuilder{
|
||||||
Repo: repo,
|
Repo: repo,
|
||||||
Curr: build,
|
Curr: build,
|
||||||
@ -345,44 +359,45 @@ func PostApproval(c *gin.Context) {
|
|||||||
Netrc: netrc,
|
Netrc: netrc,
|
||||||
Secs: secs,
|
Secs: secs,
|
||||||
Regs: regs,
|
Regs: regs,
|
||||||
|
Envs: envs,
|
||||||
Link: server.Config.Server.Host,
|
Link: server.Config.Server.Host,
|
||||||
Yamls: yamls,
|
Yamls: yamls,
|
||||||
Envs: envs,
|
|
||||||
}
|
}
|
||||||
buildItems, err := b.Build()
|
buildItems, err := b.Build()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if _, err = shared.UpdateToStatusError(_store, *build, err); err != nil {
|
if _, err := shared.UpdateToStatusError(store, *build, err); err != nil {
|
||||||
log.Error().Msgf("Error setting error status of build for %s#%d. %s", repo.FullName, build.Number, err)
|
log.Error().Err(err).Msgf("Error setting error status of build for %s#%d", repo.FullName, build.Number)
|
||||||
}
|
}
|
||||||
return
|
return nil, err
|
||||||
}
|
}
|
||||||
build = shared.SetBuildStepsOnBuild(b.Curr, buildItems)
|
build = shared.SetBuildStepsOnBuild(b.Curr, buildItems)
|
||||||
|
|
||||||
err = _store.ProcCreate(build.Procs)
|
if err := store.ProcCreate(build.Procs); err != nil {
|
||||||
if err != nil {
|
log.Error().Err(err).Str("repo", repo.FullName).Msgf("error persisting procs for %s#%d", repo.FullName, build.Number)
|
||||||
log.Error().Msgf("error persisting procs %s/%d: %s", repo.FullName, build.Number, err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
for _, item := range buildItems {
|
for _, item := range buildItems {
|
||||||
uri := fmt.Sprintf("%s/%s/%d", server.Config.Server.Host, repo.FullName, build.Number)
|
uri := fmt.Sprintf("%s/%s/build/%d", server.Config.Server.Host, repo.FullName, build.Number)
|
||||||
if len(buildItems) > 1 {
|
if len(buildItems) > 1 {
|
||||||
err = _remote.Status(c, user, repo, build, uri, item.Proc)
|
err = server.Config.Services.Remote.Status(ctx, user, repo, build, uri, item.Proc)
|
||||||
} else {
|
} else {
|
||||||
err = _remote.Status(c, user, repo, build, uri, nil)
|
err = server.Config.Services.Remote.Status(ctx, user, repo, build, uri, nil)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("error setting commit status for %s/%d: %v", repo.FullName, build.Number, err)
|
log.Error().Err(err).Msgf("error setting commit status for %s/%d", repo.FullName, build.Number)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
if err := publishToTopic(c, build, repo, model.Enqueued); err != nil {
|
if err := publishToTopic(ctx, build, repo, model.Enqueued); err != nil {
|
||||||
log.Error().Err(err).Msg("publishToTopic")
|
log.Error().Err(err).Msg("publishToTopic")
|
||||||
}
|
}
|
||||||
if err := queueBuild(build, repo, buildItems); err != nil {
|
if err := queueBuild(build, repo, buildItems); err != nil {
|
||||||
log.Error().Err(err).Msg("queueBuild")
|
log.Error().Err(err).Msg("queueBuild")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return build, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func PostDecline(c *gin.Context) {
|
func PostDecline(c *gin.Context) {
|
||||||
|
@ -76,22 +76,21 @@ func BlockTilQueueHasRunningItem(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func PostHook(c *gin.Context) {
|
func PostHook(c *gin.Context) {
|
||||||
_remote := server.Config.Services.Remote
|
|
||||||
_store := store.FromContext(c)
|
_store := store.FromContext(c)
|
||||||
|
|
||||||
tmpRepo, build, err := _remote.Hook(c.Request)
|
tmpRepo, build, err := server.Config.Services.Remote.Hook(c.Request)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to parse hook. %s", err)
|
msg := "failure to parse hook"
|
||||||
_ = c.AbortWithError(400, err)
|
log.Debug().Err(err).Msg(msg)
|
||||||
|
c.String(http.StatusBadRequest, "%s: %v", msg, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if build == nil {
|
if build == nil {
|
||||||
c.Writer.WriteHeader(200)
|
c.String(http.StatusOK, "ignoring hook: hook parsing resulted in empty build")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if tmpRepo == nil {
|
if tmpRepo == nil {
|
||||||
log.Error().Msgf("failure to ascertain repo from hook.")
|
c.String(http.StatusBadRequest, "failure to ascertain repo from hook")
|
||||||
c.Writer.WriteHeader(400)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -99,94 +98,104 @@ func PostHook(c *gin.Context) {
|
|||||||
// wrapped in square brackets appear in the commit message
|
// wrapped in square brackets appear in the commit message
|
||||||
skipMatch := skipRe.FindString(build.Message)
|
skipMatch := skipRe.FindString(build.Message)
|
||||||
if len(skipMatch) > 0 {
|
if len(skipMatch) > 0 {
|
||||||
log.Info().Msgf("ignoring hook. %s found in %s", skipMatch, build.Commit)
|
msg := fmt.Sprintf("ignoring hook: %s found in %s", skipMatch, build.Commit)
|
||||||
c.Writer.WriteHeader(204)
|
log.Debug().Msg(msg)
|
||||||
|
c.String(http.StatusNoContent, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
repo, err := _store.GetRepoName(tmpRepo.Owner + "/" + tmpRepo.Name)
|
repo, err := _store.GetRepoName(tmpRepo.Owner + "/" + tmpRepo.Name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to find repo %s/%s from hook. %s", tmpRepo.Owner, tmpRepo.Name, err)
|
msg := fmt.Sprintf("failure to get repo %s/%s from store", tmpRepo.Owner, tmpRepo.Name)
|
||||||
_ = c.AbortWithError(404, err)
|
log.Error().Err(err).Msg(msg)
|
||||||
|
c.String(http.StatusNotFound, "%s: %v", msg, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if !repo.IsActive {
|
if !repo.IsActive {
|
||||||
log.Error().Msgf("ignoring hook. %s/%s is inactive.", tmpRepo.Owner, tmpRepo.Name)
|
c.String(204, "ignoring hook: %s/%s is inactive.", tmpRepo.Owner, tmpRepo.Name)
|
||||||
_ = c.AbortWithError(204, err)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the token and verify the hook is authorized
|
// get the token and verify the hook is authorized
|
||||||
parsed, err := token.ParseRequest(c.Request, func(t *token.Token) (string, error) {
|
parsed, err := token.ParseRequest(c.Request, func(_ *token.Token) (string, error) {
|
||||||
return repo.Hash, nil
|
return repo.Hash, nil
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to parse token from hook for %s. %s", repo.FullName, err)
|
msg := fmt.Sprintf("failure to parse token from hook for %s", repo.FullName)
|
||||||
_ = c.AbortWithError(400, err)
|
log.Error().Err(err).Msg(msg)
|
||||||
|
c.String(http.StatusBadRequest, "%s: %v", msg, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if parsed.Text != repo.FullName {
|
if parsed.Text != repo.FullName {
|
||||||
log.Error().Msgf("failure to verify token from hook. Expected %s, got %s", repo.FullName, parsed.Text)
|
msg := fmt.Sprintf("failure to verify token from hook. Expected %s, got %s", repo.FullName, parsed.Text)
|
||||||
c.AbortWithStatus(403)
|
log.Debug().Msg(msg)
|
||||||
|
c.String(http.StatusForbidden, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if repo.UserID == 0 {
|
if repo.UserID == 0 {
|
||||||
log.Warn().Msgf("ignoring hook. repo %s has no owner.", repo.FullName)
|
msg := fmt.Sprintf("ignoring hook. repo %s has no owner.", repo.FullName)
|
||||||
c.Writer.WriteHeader(204)
|
log.Warn().Msg(msg)
|
||||||
|
c.String(http.StatusNoContent, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if build.Event == model.EventPull && !repo.AllowPull {
|
if build.Event == model.EventPull && !repo.AllowPull {
|
||||||
log.Info().Msgf("ignoring hook. repo %s is disabled for pull requests.", repo.FullName)
|
msg := "ignoring hook: pull requests are disabled for this repo in woodpecker"
|
||||||
_, _ = c.Writer.Write([]byte("pulls are disabled on woodpecker for this repo"))
|
log.Debug().Str("repo", repo.FullName).Msg(msg)
|
||||||
c.Writer.WriteHeader(204)
|
c.String(http.StatusNoContent, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
user, err := _store.GetUser(repo.UserID)
|
repoUser, err := _store.GetUser(repo.UserID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to find repo owner %s. %s", repo.FullName, err)
|
log.Error().Err(err).Str("repo", repo.FullName).Msgf("failure to find repo owner via id '%d'", repo.UserID)
|
||||||
_ = c.AbortWithError(500, err)
|
_ = c.AbortWithError(http.StatusInternalServerError, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// if the remote has a refresh token, the current access token
|
// if the remote has a refresh token, the current access token
|
||||||
// may be stale. Therefore, we should refresh prior to dispatching
|
// may be stale. Therefore, we should refresh prior to dispatching
|
||||||
// the build.
|
// the build.
|
||||||
if refresher, ok := _remote.(remote.Refresher); ok {
|
if refresher, ok := server.Config.Services.Remote.(remote.Refresher); ok {
|
||||||
ok, err := refresher.Refresh(c, user)
|
refreshed, err := refresher.Refresh(c, repoUser)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failed to refresh oauth2 token: %s", err)
|
log.Error().Err(err).Msgf("failed to refresh oauth2 token for repoUser: %s", repoUser.Login)
|
||||||
} else if ok {
|
} else if refreshed {
|
||||||
if err := _store.UpdateUser(user); err != nil {
|
if err := _store.UpdateUser(repoUser); err != nil {
|
||||||
log.Error().Msgf("error while updating user: %s", err)
|
log.Error().Err(err).Msgf("error while updating repoUser: %s", repoUser.Login)
|
||||||
// move forward
|
// move forward
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// fetch the build file from the remote
|
// fetch the build file from the remote
|
||||||
configFetcher := shared.NewConfigFetcher(_remote, user, repo, build)
|
configFetcher := shared.NewConfigFetcher(server.Config.Services.Remote, repoUser, repo, build)
|
||||||
remoteYamlConfigs, err := configFetcher.Fetch(c)
|
remoteYamlConfigs, err := configFetcher.Fetch(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("error: %s: cannot find %s in %s: %s", repo.FullName, repo.Config, build.Ref, err)
|
msg := fmt.Sprintf("cannot find '%s' in '%s', context user: '%s'", repo.Config, build.Ref, repoUser.Login)
|
||||||
_ = c.AbortWithError(404, err)
|
log.Debug().Err(err).Str("repo", repo.FullName).Msg(msg)
|
||||||
|
c.String(http.StatusNotFound, "%s: %v", msg, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
filtered, err := branchFiltered(build, remoteYamlConfigs)
|
filtered, err := branchFiltered(build, remoteYamlConfigs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to parse yaml from hook for %s. %s", repo.FullName, err)
|
msg := "failure to parse yaml from hook"
|
||||||
_ = c.AbortWithError(400, err)
|
log.Debug().Err(err).Str("repo", repo.FullName).Msg(msg)
|
||||||
|
c.String(http.StatusBadRequest, "%s: %v", msg, err)
|
||||||
}
|
}
|
||||||
if filtered {
|
if filtered {
|
||||||
c.String(200, "Branch does not match restrictions defined in yaml")
|
msg := "ignoring hook: branch does not match restrictions defined in yaml"
|
||||||
|
log.Debug().Str("repo", repo.FullName).Msg(msg)
|
||||||
|
c.String(200, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if zeroSteps(build, remoteYamlConfigs) {
|
if zeroSteps(build, remoteYamlConfigs) {
|
||||||
c.String(200, "Step conditions yield zero runnable steps")
|
msg := "ignoring hook: step conditions yield zero runnable steps"
|
||||||
|
log.Debug().Str("repo", repo.FullName).Msg(msg)
|
||||||
|
c.String(200, msg)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -195,14 +204,15 @@ func PostHook(c *gin.Context) {
|
|||||||
build.Verified = true
|
build.Verified = true
|
||||||
build.Status = model.StatusPending
|
build.Status = model.StatusPending
|
||||||
|
|
||||||
if repo.IsGated && build.Sender != user.Login {
|
// TODO(336) extend gated feature with an allow/block List
|
||||||
|
if repo.IsGated && build.Sender != repoUser.Login {
|
||||||
build.Status = model.StatusBlocked
|
build.Status = model.StatusBlocked
|
||||||
}
|
}
|
||||||
|
|
||||||
err = _store.CreateBuild(build, build.Procs...)
|
err = _store.CreateBuild(build, build.Procs...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to save commit for %s. %s", repo.FullName, err)
|
log.Error().Err(err).Msgf("failure to save commit for %s", repo.FullName)
|
||||||
_ = c.AbortWithError(500, err)
|
_ = c.AbortWithError(http.StatusInternalServerError, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -210,90 +220,22 @@ func PostHook(c *gin.Context) {
|
|||||||
for _, remoteYamlConfig := range remoteYamlConfigs {
|
for _, remoteYamlConfig := range remoteYamlConfigs {
|
||||||
_, err := findOrPersistPipelineConfig(repo, build, remoteYamlConfig)
|
_, err := findOrPersistPipelineConfig(repo, build, remoteYamlConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Error().Msgf("failure to find or persist build config for %s. %s", repo.FullName, err)
|
log.Error().Err(err).Msgf("failure to find or persist build config for %s", repo.FullName)
|
||||||
_ = c.AbortWithError(500, err)
|
_ = c.AbortWithError(http.StatusInternalServerError, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
c.JSON(200, build)
|
|
||||||
|
|
||||||
if build.Status == model.StatusBlocked {
|
if build.Status == model.StatusBlocked {
|
||||||
|
c.JSON(200, build)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
netrc, err := _remote.Netrc(user, repo)
|
build, err = startBuild(c, _store, build, repoUser, repo, remoteYamlConfigs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
c.String(500, "Failed to generate netrc file. %s", err)
|
c.String(http.StatusInternalServerError, fmt.Sprintf("startBuild: %v", err))
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
envs := map[string]string{}
|
|
||||||
if server.Config.Services.Environ != nil {
|
|
||||||
globals, _ := server.Config.Services.Environ.EnvironList(repo)
|
|
||||||
for _, global := range globals {
|
|
||||||
envs[global.Name] = global.Value
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
secs, err := server.Config.Services.Secrets.SecretListBuild(repo, build)
|
|
||||||
if err != nil {
|
|
||||||
log.Debug().Msgf("Error getting secrets for %s#%d. %s", repo.FullName, build.Number, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
regs, err := server.Config.Services.Registries.RegistryList(repo)
|
|
||||||
if err != nil {
|
|
||||||
log.Debug().Msgf("Error getting registry credentials for %s#%d. %s", repo.FullName, build.Number, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// get the previous build so that we can send status change notifications
|
|
||||||
last, _ := _store.GetBuildLastBefore(repo, build.Branch, build.ID)
|
|
||||||
|
|
||||||
b := shared.ProcBuilder{
|
|
||||||
Repo: repo,
|
|
||||||
Curr: build,
|
|
||||||
Last: last,
|
|
||||||
Netrc: netrc,
|
|
||||||
Secs: secs,
|
|
||||||
Regs: regs,
|
|
||||||
Envs: envs,
|
|
||||||
Link: server.Config.Server.Host,
|
|
||||||
Yamls: remoteYamlConfigs,
|
|
||||||
}
|
|
||||||
buildItems, err := b.Build()
|
|
||||||
if err != nil {
|
|
||||||
if _, err = shared.UpdateToStatusError(_store, *build, err); err != nil {
|
|
||||||
log.Error().Msgf("Error setting error status of build for %s#%d. %s", repo.FullName, build.Number, err)
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
build = shared.SetBuildStepsOnBuild(b.Curr, buildItems)
|
|
||||||
|
|
||||||
err = _store.ProcCreate(build.Procs)
|
|
||||||
if err != nil {
|
|
||||||
log.Error().Msgf("error persisting procs %s/%d: %s", repo.FullName, build.Number, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
defer func() {
|
|
||||||
for _, item := range buildItems {
|
|
||||||
uri := fmt.Sprintf("%s/%s/build/%d", server.Config.Server.Host, repo.FullName, build.Number)
|
|
||||||
if len(buildItems) > 1 {
|
|
||||||
err = _remote.Status(c, user, repo, build, uri, item.Proc)
|
|
||||||
} else {
|
|
||||||
err = _remote.Status(c, user, repo, build, uri, nil)
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
log.Error().Msgf("error setting commit status for %s/%d: %v", repo.FullName, build.Number, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
|
|
||||||
if err := publishToTopic(c, build, repo, model.Enqueued); err != nil {
|
|
||||||
log.Error().Err(err).Msg("publishToTopic")
|
|
||||||
}
|
|
||||||
if err := queueBuild(build, repo, buildItems); err != nil {
|
|
||||||
log.Error().Err(err).Msg("queueBuild")
|
|
||||||
}
|
}
|
||||||
|
c.JSON(200, build)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: parse yaml once and not for each filter function
|
// TODO: parse yaml once and not for each filter function
|
||||||
@ -371,7 +313,7 @@ func findOrPersistPipelineConfig(repo *model.Repo, build *model.Build, remoteYam
|
|||||||
}
|
}
|
||||||
|
|
||||||
// publishes message to UI clients
|
// publishes message to UI clients
|
||||||
func publishToTopic(c *gin.Context, build *model.Build, repo *model.Repo, event model.EventType) (err error) {
|
func publishToTopic(c context.Context, build *model.Build, repo *model.Repo, event model.EventType) (err error) {
|
||||||
message := pubsub.Message{
|
message := pubsub.Message{
|
||||||
Labels: map[string]string{
|
Labels: map[string]string{
|
||||||
"repo": repo.FullName,
|
"repo": repo.FullName,
|
||||||
|
@ -17,6 +17,7 @@ package model
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -80,7 +81,7 @@ func (s *Secret) Match(event WebhookEvent) bool {
|
|||||||
func (s *Secret) Validate() error {
|
func (s *Secret) Validate() error {
|
||||||
for _, event := range s.Events {
|
for _, event := range s.Events {
|
||||||
if !ValidateWebhookEvent(event) {
|
if !ValidateWebhookEvent(event) {
|
||||||
return errSecretEventInvalid
|
return fmt.Errorf("%s: '%s'", errSecretEventInvalid, event)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user