本文整理汇总了Golang中github.com/flynn/flynn/controller/types.App.ReleaseID方法的典型用法代码示例。如果您正苦于以下问题:Golang App.ReleaseID方法的具体用法?Golang App.ReleaseID怎么用?Golang App.ReleaseID使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/flynn/flynn/controller/types.App
的用法示例。
在下文中一共展示了App.ReleaseID方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: SetRelease
func (r *AppRepo) SetRelease(app *ct.App, releaseID string) error {
tx, err := r.db.Begin()
if err != nil {
return err
}
var release *ct.Release
var prevRelease *ct.Release
if app.ReleaseID != "" {
row := tx.QueryRow("release_select", app.ReleaseID)
prevRelease, _ = scanRelease(row)
}
row := tx.QueryRow("release_select", releaseID)
if release, err = scanRelease(row); err != nil {
return err
}
app.ReleaseID = releaseID
if err := tx.Exec("app_update_release", app.ID, app.ReleaseID); err != nil {
tx.Rollback()
return err
}
if err := createEvent(tx.Exec, &ct.Event{
AppID: app.ID,
ObjectID: release.ID,
ObjectType: ct.EventTypeAppRelease,
}, &ct.AppRelease{
PrevRelease: prevRelease,
Release: release,
}); err != nil {
tx.Rollback()
return err
}
return tx.Commit()
}
示例2: SetRelease
func (r *AppRepo) SetRelease(app *ct.App, releaseID string) error {
tx, err := r.db.Begin()
if err != nil {
return err
}
var release *ct.Release
row := tx.QueryRow("SELECT release_id, artifact_id, data, created_at FROM releases WHERE release_id = $1 AND deleted_at IS NULL", releaseID)
if release, err = scanRelease(row); err != nil {
return err
}
app.ReleaseID = releaseID
if _, err := tx.Exec("UPDATE apps SET release_id = $2, updated_at = now() WHERE app_id = $1", app.ID, app.ReleaseID); err != nil {
tx.Rollback()
return err
}
if err := createEvent(tx.Exec, &ct.Event{
AppID: app.ID,
ObjectID: release.ID,
ObjectType: ct.EventTypeAppRelease,
}, release); err != nil {
tx.Rollback()
return err
}
return tx.Commit()
}
示例3: SetRelease
func (r *AppRepo) SetRelease(app *ct.App, releaseID string) error {
tx, err := r.db.Begin()
if err != nil {
return err
}
app.ReleaseID = releaseID
if _, err := tx.Exec("UPDATE apps SET release_id = $2, updated_at = now() WHERE app_id = $1", app.ID, app.ReleaseID); err != nil {
tx.Rollback()
return err
}
if err := createEvent(tx.Exec, &ct.Event{
AppID: app.ID,
ObjectID: app.ID,
ObjectType: ct.EventTypeApp,
}, app); err != nil {
tx.Rollback()
return err
}
return tx.Commit()
}