Skip to content

Commit

Permalink
fix(api): fix hooks with empty UUID (#5098)
Browse files Browse the repository at this point in the history
Signed-off-by: francois  samin <[email protected]>
  • Loading branch information
fsamin authored Apr 3, 2020
1 parent 88e8ccf commit 5386f91
Show file tree
Hide file tree
Showing 2 changed files with 81 additions and 0 deletions.
4 changes: 4 additions & 0 deletions engine/api/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -707,6 +707,10 @@ func (a *API) Serve(ctx context.Context) error {
return migrate.CleanDuplicateHooks(ctx, a.DBConnectionFactory.GetDBMap(), a.Cache, false)
}})

migrate.Add(ctx, sdk.Migration{Name: "FixEmptyUUIDHooks", Release: "0.44.0", Blocker: false, Automatic: false, ExecFunc: func(ctx context.Context) error {
return migrate.FixEmptyUUIDHooks(ctx, a.DBConnectionFactory.GetDBMap(), a.Cache)
}})

isFreshInstall, errF := version.IsFreshInstall(a.mustDB())
if errF != nil {
return sdk.WrapError(errF, "Unable to check if it's a fresh installation of CDS")
Expand Down
77 changes: 77 additions & 0 deletions engine/api/migrate/clean_duplicate_hooks.go
Original file line number Diff line number Diff line change
Expand Up @@ -135,3 +135,80 @@ func cleanDuplicateHooks(ctx context.Context, db *gorp.DbMap, store cache.Store,

return nil
}

func FixEmptyUUIDHooks(ctx context.Context, db *gorp.DbMap, store cache.Store) error {
q := "select distinct(workflow.id) from w_node_hook join w_node on w_node.id = w_node_hook.node_id join workflow on workflow.id = w_node.workflow_id where uuid = ''"
var ids []int64

if _, err := db.Select(&ids, q); err != nil {
return sdk.WrapError(err, "unable to select workflow")
}

var mError = new(sdk.MultiError)
for _, id := range ids {
if err := fixEmptyUUIDHooks(ctx, db, store, id); err != nil {
mError.Append(err)
log.Error(ctx, "migrate.FixEmptyUUIDHooks> unable to clean workflow %d: %v", id, err)
}
}

if mError.IsEmpty() {
return nil
}
return mError
}

func fixEmptyUUIDHooks(ctx context.Context, db *gorp.DbMap, store cache.Store, workflowID int64) error {
tx, err := db.Begin()
if err != nil {
return sdk.WithStack(err)
}

defer tx.Rollback() // nolint

projectID, err := tx.SelectInt("SELECT project_id FROM workflow WHERE id = $1", workflowID)
if err != nil {
if err == sql.ErrNoRows {
return nil
}
return sdk.WithStack(err)
}

if projectID == 0 {
return nil
}

proj, err := project.LoadByID(tx, store, projectID,
project.LoadOptions.WithApplicationWithDeploymentStrategies,
project.LoadOptions.WithPipelines,
project.LoadOptions.WithEnvironments,
project.LoadOptions.WithIntegrations)
if err != nil {
return sdk.WrapError(err, "unable to load project %d", projectID)
}

w, err := workflow.LoadAndLockByID(ctx, tx, store, *proj, workflowID, workflow.LoadOptions{})
if err != nil {
if sdk.ErrorIs(err, sdk.ErrNotFound) {
return nil
}
return err
}

for i, h := range w.WorkflowData.Node.Hooks {
if h.UUID == "" {
w.WorkflowData.Node.Hooks[i].UUID = sdk.UUID()
}
}

if err := workflow.Update(ctx, tx, store, *proj, w, workflow.UpdateOptions{}); err != nil {
return err
}

if err := tx.Commit(); err != nil {
return err
}
log.Info(ctx, "migrate.fixEmptyUUIDHooks> workflow %s/%s (%d) has been cleaned", proj.Name, w.Name, w.ID)

return nil
}

0 comments on commit 5386f91

Please sign in to comment.