From f76ae529a325ebb3ddb158feb5a6b49bd8d1ab89 Mon Sep 17 00:00:00 2001 From: Denis O Date: Fri, 20 Dec 2024 20:10:48 +0000 Subject: [PATCH] Units parsing --- cli/commands/stack/action.go | 27 +++++++++++++++------------ 1 file changed, 15 insertions(+), 12 deletions(-) diff --git a/cli/commands/stack/action.go b/cli/commands/stack/action.go index dd98f8b2a0..5692a5087b 100644 --- a/cli/commands/stack/action.go +++ b/cli/commands/stack/action.go @@ -53,25 +53,28 @@ func processStackFile(ctx context.Context, opts *options.TerragruntOptions, stac return errors.New(fmt.Errorf("failed to create base directory: %w", err)) } + //client := getter.Client{ + // Getters: getter.Getters, + // Decompressors: getter.Decompressors, + // DisableSymlinks: true, + //} + for _, unit := range stackFile.Units { destPath := filepath.Join(baseDir, unit.Path) - src := unit.Source - src, err := filepath.Abs(src) + dest, err := filepath.Abs(destPath) if err != nil { - return errors.New(fmt.Errorf("failed to get absolute path for source '%s': %w", unit.Source, err)) + return errors.New(fmt.Errorf("failed to get absolute path for destination '%s': %w", destPath, err)) } - opts.Logger.Infof("Processing unit: %s (%s) to %s", unit.Name, src, destPath) - req := &getter.Request{ - Src: src, - Dst: destPath, - GetMode: getter.ModeAny, - Copy: true, - DisableSymlinks: true, - Umask: 0755, + src := unit.Source + src, err = filepath.Abs(src) + if err != nil { + opts.Logger.Warnf("failed to get absolute path for source '%s': %v", unit.Source, err) + src = unit.Source } + opts.Logger.Infof("Processing unit: %s (%s) to %s", unit.Name, src, dest) - if _, err := getter.DefaultClient.Get(ctx, req); err != nil { + if _, err := getter.GetAny(ctx, dest, src); err != nil { return fmt.Errorf("failed to fetch source '%s' to destination '%s': %w", unit.Source, destPath, err) } }