mirror of
https://github.com/fluxcd/flux2.git
synced 2026-02-22 07:31:47 +00:00
flux diff artifact: Use the tar.Untar() convenience function.
Signed-off-by: Florian Forster <fforster@gitlab.com>
This commit is contained in:
parent
ba36b37ac1
commit
a45a0ee7c5
1 changed files with 3 additions and 34 deletions
|
|
@ -17,9 +17,7 @@ limitations under the License.
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"archive/tar"
|
|
||||||
"bytes"
|
"bytes"
|
||||||
"compress/gzip"
|
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
@ -31,6 +29,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
oci "github.com/fluxcd/pkg/oci/client"
|
oci "github.com/fluxcd/pkg/oci/client"
|
||||||
|
"github.com/fluxcd/pkg/tar"
|
||||||
sourcev1 "github.com/fluxcd/source-controller/api/v1beta2"
|
sourcev1 "github.com/fluxcd/source-controller/api/v1beta2"
|
||||||
"github.com/gonvenience/ytbx"
|
"github.com/gonvenience/ytbx"
|
||||||
"github.com/google/shlex"
|
"github.com/google/shlex"
|
||||||
|
|
@ -272,38 +271,8 @@ func extractTo(archivePath, destDir string) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
gzipReader, err := gzip.NewReader(archiveFH)
|
if err := tar.Untar(archiveFH, destDir); err != nil {
|
||||||
if err != nil {
|
return fmt.Errorf("Untar(%q, %q): %w", archivePath, destDir, err)
|
||||||
return fmt.Errorf("gzip.NewREader(): %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
tarReader := tar.NewReader(gzipReader)
|
|
||||||
|
|
||||||
for {
|
|
||||||
header, err := tarReader.Next()
|
|
||||||
if errors.Is(err, io.EOF) {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("tarReader.Next(): %w", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
switch header.Typeflag {
|
|
||||||
case tar.TypeDir:
|
|
||||||
dir := filepath.Join(destDir, header.Name)
|
|
||||||
if err := os.Mkdir(dir, 0755); err != nil {
|
|
||||||
return fmt.Errorf("os.Mkdir(%q): %w", dir, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
case tar.TypeReg:
|
|
||||||
name := filepath.Join(destDir, header.Name)
|
|
||||||
if err := copyFile(tarReader, name); err != nil {
|
|
||||||
return fmt.Errorf("extracting %q: %w", header.Name, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
logger.Warningf("unsupported tar type: %v", header.Typeflag)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue