diff --git a/pkg/config-reader/go_version_file.go b/pkg/config-reader/go_version_file.go index ec40f0c7d..445cb497d 100644 --- a/pkg/config-reader/go_version_file.go +++ b/pkg/config-reader/go_version_file.go @@ -15,9 +15,6 @@ import ( var goVersionPattern = regexp.MustCompile(`(?m)^go (\d+\.\d+.\d+)$`) func readGoVersionFile(fs afero.Fs, filePath string, pkg *aqua.Package) error { - if pkg.GoVersionFile == "" { - return nil - } p := filepath.Join(filepath.Dir(filePath), pkg.GoVersionFile) b, err := afero.ReadFile(fs, p) if err != nil { diff --git a/pkg/config-reader/reader.go b/pkg/config-reader/reader.go index 4cbacc730..1871edb1f 100644 --- a/pkg/config-reader/reader.go +++ b/pkg/config-reader/reader.go @@ -43,7 +43,15 @@ func (r *ConfigReader) Read(logE *logrus.Entry, configFilePath string, cfg *aqua if err := yaml.NewDecoder(file).Decode(cfg); err != nil { return fmt.Errorf("parse a configuration file as YAML: %w", err) } - var configFileDir string + configFileDir := filepath.Dir(configFilePath) + if err := r.readRegistries(configFileDir, cfg); err != nil { + return err + } + r.readPackages(logE, configFilePath, cfg) + return nil +} + +func (r *ConfigReader) readRegistries(configFileDir string, cfg *aqua.Config) error { for _, rgst := range cfg.Registries { if rgst.Type == "local" { if strings.HasPrefix(rgst.Path, homePrefix) { @@ -52,54 +60,64 @@ func (r *ConfigReader) Read(logE *logrus.Entry, configFilePath string, cfg *aqua } rgst.Path = filepath.Join(r.homeDir, rgst.Path[6:]) } - if configFileDir == "" { - configFileDir = filepath.Dir(configFilePath) - } rgst.Path = osfile.Abs(configFileDir, rgst.Path) } } - r.readImports(logE, configFilePath, cfg) return nil } -func (r *ConfigReader) readImports(logE *logrus.Entry, configFilePath string, cfg *aqua.Config) { +func (r *ConfigReader) readPackages(logE *logrus.Entry, configFilePath string, cfg *aqua.Config) { pkgs := []*aqua.Package{} for _, pkg := range cfg.Packages { if pkg == nil { continue } - if pkg.Import == "" { - if err := readGoVersionFile(r.fs, configFilePath, pkg); err != nil { - logerr.WithError(logE, err).Error("read a go version file") - continue - } - pkgs = append(pkgs, pkg) - continue - } - logE := logE.WithField("import", pkg.Import) - p := filepath.Join(filepath.Dir(configFilePath), pkg.Import) - filePaths, err := afero.Glob(r.fs, p) + subPkgs, err := r.readPackage(logE, configFilePath, pkg) if err != nil { - logerr.WithError(logE, err).Error("read files with glob pattern") + logerr.WithError(logE, err).Error("read a package") continue } - sort.Strings(filePaths) - for _, filePath := range filePaths { - logE := logE.WithField("imported_file", filePath) - subCfg := &aqua.Config{} - if err := r.Read(logE, filePath, subCfg); err != nil { - logerr.WithError(logE, err).Error("read an import file") - continue - } - for _, pkg := range subCfg.Packages { - pkg.FilePath = filePath - if err := readGoVersionFile(r.fs, filePath, pkg); err != nil { - logerr.WithError(logE, err).Error("read a go version file") - continue - } - pkgs = append(pkgs, pkg) - } + if subPkgs == nil { + pkg.FilePath = configFilePath + pkgs = append(pkgs, pkg) + continue } + pkgs = append(pkgs, subPkgs...) } cfg.Packages = pkgs } + +func (r *ConfigReader) readPackage(logE *logrus.Entry, configFilePath string, pkg *aqua.Package) ([]*aqua.Package, error) { + if pkg.GoVersionFile != "" { + // go_version_file + if err := readGoVersionFile(r.fs, configFilePath, pkg); err != nil { + return nil, fmt.Errorf("read a go version file: %w", logerr.WithFields(err, logrus.Fields{ + "go_version_file": pkg.GoVersionFile, + })) + } + return nil, nil + } + if pkg.Import == "" { + // version + return nil, nil + } + // import + logE = logE.WithField("import", pkg.Import) + p := filepath.Join(filepath.Dir(configFilePath), pkg.Import) + filePaths, err := afero.Glob(r.fs, p) + if err != nil { + return nil, fmt.Errorf("find files with a glob pattern: %w", err) + } + sort.Strings(filePaths) + pkgs := []*aqua.Package{} + for _, filePath := range filePaths { + logE := logE.WithField("imported_file", filePath) + subCfg := &aqua.Config{} + if err := r.Read(logE, filePath, subCfg); err != nil { + logerr.WithError(logE, err).Error("read an import file") + continue + } + pkgs = append(pkgs, subCfg.Packages...) + } + return pkgs, nil +} diff --git a/pkg/config-reader/reader_test.go b/pkg/config-reader/reader_test.go index 9a7a1c972..9f77411cc 100644 --- a/pkg/config-reader/reader_test.go +++ b/pkg/config-reader/reader_test.go @@ -87,6 +87,7 @@ packages: Name: "suzuki-shunsuke/ci-info", Registry: "standard", Version: "v1.0.0", + FilePath: "/home/workspace/foo/aqua.yaml", }, { Name: "aquaproj/aqua-installer", diff --git a/pkg/controller/which/which_test.go b/pkg/controller/which/which_test.go index f3d996a67..424adff5a 100644 --- a/pkg/controller/which/which_test.go +++ b/pkg/controller/which/which_test.go @@ -70,6 +70,7 @@ packages: Name: "aquaproj/aqua-installer", Registry: "standard", Version: "v1.0.0", + FilePath: "/home/foo/workspace/aqua.yaml", }, PackageInfo: &cfgRegistry.PackageInfo{ Type: "github_content", @@ -92,6 +93,7 @@ packages: Name: "aquaproj/aqua-installer", Registry: "standard", Version: "v1.0.0", + FilePath: "/home/foo/workspace/aqua.yaml", }, }, Registries: aqua.Registries{ @@ -189,6 +191,7 @@ packages: Name: "aquaproj/aqua-installer", Registry: "standard", Version: "v1.0.0", + FilePath: "/etc/aqua/aqua.yaml", }, PackageInfo: &cfgRegistry.PackageInfo{ Type: "github_content", @@ -211,11 +214,13 @@ packages: Name: "suzuki-shunsuke/ci-info", Registry: "standard", Version: "v1.0.0", + FilePath: "/etc/aqua/aqua.yaml", }, { Name: "aquaproj/aqua-installer", Registry: "standard", Version: "v1.0.0", + FilePath: "/etc/aqua/aqua.yaml", }, }, Registries: aqua.Registries{