mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-18 20:09:26 +00:00
e81ccc406b
Change all license headers to comply with REUSE specification. Fix #16132 Co-authored-by: flynnnnnnnnnn <flynnnnnnnnnn@github> Co-authored-by: John Olheiser <john.olheiser@gmail.com>
57 lines
1.4 KiB
Go
57 lines
1.4 KiB
Go
// Copyright 2021 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package system
|
|
|
|
import (
|
|
"context"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
)
|
|
|
|
// AppState represents a state record in database
|
|
// if one day we would make Gitea run as a cluster,
|
|
// we can introduce a new field `Scope` here to store different states for different nodes
|
|
type AppState struct {
|
|
ID string `xorm:"pk varchar(200)"`
|
|
Revision int64
|
|
Content string `xorm:"LONGTEXT"`
|
|
}
|
|
|
|
func init() {
|
|
db.RegisterModel(new(AppState))
|
|
}
|
|
|
|
// SaveAppStateContent saves the app state item to database
|
|
func SaveAppStateContent(key, content string) error {
|
|
return db.WithTx(db.DefaultContext, func(ctx context.Context) error {
|
|
eng := db.GetEngine(ctx)
|
|
// try to update existing row
|
|
res, err := eng.Exec("UPDATE app_state SET revision=revision+1, content=? WHERE id=?", content, key)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
rows, _ := res.RowsAffected()
|
|
if rows != 0 {
|
|
// the existing row is updated, so we can return
|
|
return nil
|
|
}
|
|
// if no existing row, insert a new row
|
|
_, err = eng.Insert(&AppState{ID: key, Content: content})
|
|
return err
|
|
})
|
|
}
|
|
|
|
// GetAppStateContent gets an app state from database
|
|
func GetAppStateContent(key string) (content string, err error) {
|
|
e := db.GetEngine(db.DefaultContext)
|
|
appState := &AppState{ID: key}
|
|
has, err := e.Get(appState)
|
|
if err != nil {
|
|
return "", err
|
|
} else if !has {
|
|
return "", nil
|
|
}
|
|
return appState.Content, nil
|
|
}
|