2025-01-14 08:49:42 +00:00
|
|
|
package repos
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"plemya-x.ru/alr/internal/config"
|
2025-01-14 10:18:51 +00:00
|
|
|
"plemya-x.ru/alr/internal/db"
|
2025-01-14 08:49:42 +00:00
|
|
|
database "plemya-x.ru/alr/internal/db"
|
|
|
|
"plemya-x.ru/alr/internal/types"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Pull pulls the provided repositories. If a repo doesn't exist, it will be cloned
|
|
|
|
// and its packages will be written to the DB. If it does exist, it will be pulled.
|
|
|
|
// In this case, only changed packages will be processed if possible.
|
|
|
|
// If repos is set to nil, the repos in the ALR config will be used.
|
|
|
|
//
|
|
|
|
// Deprecated: use struct method
|
|
|
|
func Pull(ctx context.Context, repos []types.Repo) error {
|
|
|
|
return GetInstance(ctx).Pull(ctx, repos)
|
|
|
|
}
|
|
|
|
|
2025-01-14 10:18:51 +00:00
|
|
|
// FindPkgs looks for packages matching the inputs inside the database.
|
|
|
|
// It returns a map that maps the package name input to any packages found for it.
|
|
|
|
// It also returns a slice that contains the names of all packages that were not found.
|
|
|
|
//
|
|
|
|
// Deprecated: use struct method
|
|
|
|
func FindPkgs(ctx context.Context, pkgs []string) (map[string][]db.Package, []string, error) {
|
|
|
|
return GetInstance(ctx).FindPkgs(ctx, pkgs)
|
|
|
|
}
|
|
|
|
|
2025-01-14 08:49:42 +00:00
|
|
|
// =======================
|
|
|
|
// FOR LEGACY ONLY
|
|
|
|
// =======================
|
|
|
|
|
|
|
|
var (
|
|
|
|
reposInstance *Repos
|
|
|
|
alrConfigOnce sync.Once
|
|
|
|
)
|
|
|
|
|
|
|
|
// Deprecated: For legacy only
|
|
|
|
func GetInstance(ctx context.Context) *Repos {
|
|
|
|
alrConfigOnce.Do(func() {
|
|
|
|
cfg := config.GetInstance(ctx)
|
|
|
|
db := database.GetInstance(ctx)
|
|
|
|
|
|
|
|
reposInstance = New(
|
|
|
|
cfg,
|
|
|
|
db,
|
|
|
|
)
|
|
|
|
})
|
|
|
|
|
|
|
|
return reposInstance
|
|
|
|
}
|