2024-03-21 07:25:40 +00:00
|
|
|
// Copyright 2024 The forgejo Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
2024-03-22 16:51:20 +00:00
|
|
|
// ToDo: Is this package the right place for federated repo? May need to diskuss this.
|
2024-03-21 07:25:40 +00:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
2024-03-22 16:41:59 +00:00
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2024-03-21 07:25:40 +00:00
|
|
|
"code.gitea.io/gitea/models/db"
|
2024-03-22 16:41:59 +00:00
|
|
|
"code.gitea.io/gitea/modules/validation"
|
2024-03-21 07:25:40 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
db.RegisterModel(new(FederatedRepo))
|
|
|
|
}
|
2024-03-22 16:41:59 +00:00
|
|
|
|
2024-03-22 19:14:20 +00:00
|
|
|
// TODO: do we need this?
|
2024-03-22 16:41:59 +00:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2024-03-22 19:14:20 +00:00
|
|
|
// TODO: do we need this?
|
2024-03-22 16:41:59 +00:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2024-03-22 19:14:20 +00:00
|
|
|
// TODO: do we need this?
|
2024-03-22 16:41:59 +00:00
|
|
|
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
|
|
|
|
}
|
|
|
|
|
2024-03-22 19:14:20 +00:00
|
|
|
func UpdateFederatedRepo(ctx context.Context, localRepoId int64, federatedRepoList []*FederatedRepo) error {
|
|
|
|
for _, federatedRepo := range federatedRepoList {
|
2024-03-23 16:01:25 +00:00
|
|
|
if res, err := validation.IsValid(*federatedRepo); !res {
|
2024-03-22 19:14:20 +00:00
|
|
|
return fmt.Errorf("FederationInfo is not valid: %v", err)
|
|
|
|
}
|
2024-03-22 16:41:59 +00:00
|
|
|
}
|
2024-03-22 19:14:20 +00:00
|
|
|
|
|
|
|
// Begin transaction
|
|
|
|
ctx, committer, err := db.TxContext((ctx))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
defer committer.Close()
|
|
|
|
|
|
|
|
_, err = db.GetEngine(ctx).Where("repo_id=?", localRepoId).Delete(FederatedRepo{})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
for _, federatedRepo := range federatedRepoList {
|
|
|
|
_, err = db.GetEngine(ctx).Insert(federatedRepo)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Commit transaction
|
|
|
|
return committer.Commit()
|
2024-03-22 16:41:59 +00:00
|
|
|
}
|