mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-10 18:41:17 +00:00
use new table to populate settings
This commit is contained in:
parent
a9d18e5327
commit
828e7a76f6
3 changed files with 16 additions and 39 deletions
|
@ -6,7 +6,6 @@ package repo
|
|||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"strings"
|
||||
|
||||
"code.gitea.io/gitea/models/db"
|
||||
"code.gitea.io/gitea/modules/validation"
|
||||
|
@ -16,43 +15,12 @@ func init() {
|
|||
db.RegisterModel(new(FederatedRepo))
|
||||
}
|
||||
|
||||
// TODO: do we need this?
|
||||
func GetFederatedRepo(ctx context.Context, ID int64) (*FederatedRepo, error) {
|
||||
repo := new(FederatedRepo)
|
||||
has, err := db.GetEngine(ctx).Where("id=?", ID).Get(repo)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
} else if !has {
|
||||
return nil, fmt.Errorf("FederationInfo record %v does not exist", ID)
|
||||
}
|
||||
if res, err := validation.IsValid(repo); !res {
|
||||
return nil, fmt.Errorf("FederationInfo is not valid: %v", err)
|
||||
}
|
||||
return repo, nil
|
||||
}
|
||||
|
||||
// TODO: do we need this?
|
||||
func FindFederatedRepoByFQDN(ctx context.Context, fqdn string) (*FederatedRepo, error) {
|
||||
repo := new(FederatedRepo)
|
||||
has, err := db.GetEngine(ctx).Where("host_fqdn=?", strings.ToLower(fqdn)).Get(repo)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
} else if !has {
|
||||
return nil, nil
|
||||
}
|
||||
if res, err := validation.IsValid(repo); !res {
|
||||
return nil, fmt.Errorf("FederationInfo is not valid: %v", err)
|
||||
}
|
||||
return repo, nil
|
||||
}
|
||||
|
||||
// TODO: do we need this?
|
||||
func CreateFederatedRepo(ctx context.Context, repo *FederatedRepo) error {
|
||||
if res, err := validation.IsValid(repo); !res {
|
||||
return fmt.Errorf("FederationInfo is not valid: %v", err)
|
||||
}
|
||||
_, err := db.GetEngine(ctx).Insert(repo)
|
||||
return err
|
||||
func FindFederatedRepoByRepoID(ctx context.Context, repoId int64) ([]*FederatedRepo, error) {
|
||||
maxFederatedRepos := 10
|
||||
sess := db.GetEngine(ctx).Where("repo_id=?", repoId)
|
||||
sess = sess.Limit(maxFederatedRepos, 0)
|
||||
federatedRepoList := make([]*FederatedRepo, 0, maxFederatedRepos)
|
||||
return federatedRepoList, sess.Find(&federatedRepoList)
|
||||
}
|
||||
|
||||
func UpdateFederatedRepo(ctx context.Context, localRepoId int64, federatedRepoList []*FederatedRepo) error {
|
||||
|
|
|
@ -380,6 +380,15 @@ func repoAssignment(ctx *Context, repo *repo_model.Repository) {
|
|||
ctx.Data["HasAccess"] = true
|
||||
ctx.Data["Permission"] = &ctx.Repo.Permission
|
||||
|
||||
federatedRepo, err := repo_model.FindFederatedRepoByRepoID(ctx, repo.ID)
|
||||
if err == nil {
|
||||
// TODO: concat string to semicolon sperated list here
|
||||
ctx.Data["FederatedRepos"] = federatedRepo
|
||||
} else if err != repo_model.ErrMirrorNotExist {
|
||||
ctx.ServerError("FindFederatedRepoByRepoID", err)
|
||||
return
|
||||
}
|
||||
|
||||
if repo.IsMirror {
|
||||
pullMirror, err := repo_model.GetMirrorByRepoID(ctx, repo.ID)
|
||||
if err == nil {
|
||||
|
|
|
@ -73,7 +73,7 @@
|
|||
<input type="hidden" name="action" value="federation">
|
||||
<div class="field {{if .Err_FederationRepos}}error{{end}}">
|
||||
<label for="federation_repos">{{ctx.Locale.Tr "repo.settings.federation_labelname_repo"}}</label>
|
||||
<input id="federation_repos" name="federation_repos" value="{{.Repository.FederationRepos}}" data-repo-name="{{.Repository.FederationRepos}}">
|
||||
<input id="federation_repos" name="federation_repos" value="{{.FederationRepos}}" data-repo-name="{{.Repository.FederationRepos}}">
|
||||
</div>
|
||||
<div class="field">
|
||||
<button class="ui primary button">{{ctx.Locale.Tr "repo.settings.update_settings"}}</button>
|
||||
|
|
Loading…
Reference in a new issue