flux diff artifact: Use the `tar.Untar()` convenience function.

Signed-off-by: Florian Forster <fforster@gitlab.com>
pull/4916/head
Florian Forster 10 months ago
parent ba36b37ac1
commit a45a0ee7c5
No known key found for this signature in database

@ -17,9 +17,7 @@ limitations under the License.
package main
import (
"archive/tar"
"bytes"
"compress/gzip"
"context"
"errors"
"fmt"
@ -31,6 +29,7 @@ import (
"strings"
oci "github.com/fluxcd/pkg/oci/client"
"github.com/fluxcd/pkg/tar"
sourcev1 "github.com/fluxcd/source-controller/api/v1beta2"
"github.com/gonvenience/ytbx"
"github.com/google/shlex"
@ -272,38 +271,8 @@ func extractTo(archivePath, destDir string) error {
return err
}
gzipReader, err := gzip.NewReader(archiveFH)
if err != nil {
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)
}
if err := tar.Untar(archiveFH, destDir); err != nil {
return fmt.Errorf("Untar(%q, %q): %w", archivePath, destDir, err)
}
return nil

Loading…
Cancel
Save