2024-03-21 08:25:40 +01:00
|
|
|
// Copyright 2024 The forgejo Authors. All rights reserved.
|
|
|
|
// SPDX-License-Identifier: MIT
|
2024-03-22 17:51:20 +01:00
|
|
|
// ToDo: Is this package the right place for federated repo? May need to diskuss this.
|
2024-03-21 08:25:40 +01:00
|
|
|
package repo
|
|
|
|
|
|
|
|
import (
|
2024-03-22 17:41:59 +01:00
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
2024-03-21 08:25:40 +01:00
|
|
|
"code.gitea.io/gitea/models/db"
|
2024-03-22 17:41:59 +01:00
|
|
|
"code.gitea.io/gitea/modules/validation"
|
2024-03-21 08:25:40 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
db.RegisterModel(new(FederatedRepo))
|
|
|
|
}
|
2024-03-22 17:41:59 +01: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
|
|
|
|
}
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
|
|
|
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 UpdateFederatedRepo(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).ID(repo.ID).Update(repo)
|
|
|
|
return err
|
|
|
|
}
|