本文整理匯總了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()
}