From b38a391e050914fa78579975b0993245f24cc2a4 Mon Sep 17 00:00:00 2001 From: Fang-Pen Lin Date: Fri, 16 Jun 2023 15:20:15 -0700 Subject: [PATCH] Pass bundle dir as the workdir for hooks exec run function Signed-off-by: Fang-Pen Lin --- run_linux.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/run_linux.go b/run_linux.go index e3c12196f15..63af2ecd094 100644 --- a/run_linux.go +++ b/run_linux.go @@ -318,7 +318,7 @@ rootless=%d } // Setup OCI hooks - _, err = b.setupOCIHooks(spec, (len(options.Mounts) > 0 || len(volumes) > 0)) + _, err = b.setupOCIHooks(spec, path, (len(options.Mounts) > 0 || len(volumes) > 0)) if err != nil { return fmt.Errorf("unable to setup OCI hooks: %w", err) } @@ -379,7 +379,7 @@ rootless=%d return err } -func (b *Builder) setupOCIHooks(config *specs.Spec, hasVolumes bool) (map[string][]specs.Hook, error) { +func (b *Builder) setupOCIHooks(config *specs.Spec, bundlePath string, hasVolumes bool) (map[string][]specs.Hook, error) { allHooks := make(map[string][]specs.Hook) if len(b.CommonBuildOpts.OCIHooksDir) == 0 { if unshare.IsRootless() { @@ -416,7 +416,15 @@ func (b *Builder) setupOCIHooks(config *specs.Spec, hasVolumes bool) (map[string } } - hookErr, err := hooksExec.RuntimeConfigFilter(context.Background(), allHooks["precreate"], config, hooksExec.DefaultPostKillTimeout) //nolint:staticcheck + hookErr, err := hooksExec.RuntimeConfigFilterWithOptions( + context.Background(), + hooksExec.RuntimeConfigFilterOptions{ + Hooks: allHooks["precreate"], + Dir: bundlePath, + Config: config, + PostKillTimeout: hooksExec.DefaultPostKillTimeout, + }, + ) if err != nil { logrus.Warnf("Container: precreate hook: %v", err) if hookErr != nil && hookErr != err {