Exemple #1
0
func pushLayer(ctx context.Context, address, imageDir string,
	blobs distribution.BlobStore) (descriptor distribution.Descriptor, err error) {
	fmt.Printf("push layer: %s", address)

	layer, err := os.Open(filepath.Join(imageDir, address, "layer.tar"))
	if err != nil {
		log.Printf("Error reading embedded tar: %v", err)
		return
	}
	defer layer.Close()

	stat, err := layer.Stat()

	digester := digest.Canonical.New()

	bar := pb.New(int(stat.Size())).SetUnits(pb.U_BYTES)
	bar.Start()

	writer, err := blobs.Create(ctx)
	if err != nil {
		log.Printf("Error creating blob writer: %v", err)
		return
	}

	_, err = io.Copy(io.MultiWriter(writer, bar, digester.Hash()), layer)
	if err != nil {
		log.Printf("Error copying to blob writer: %v", err)
		return
	}

	descriptor, err = writer.Commit(ctx, distribution.Descriptor{
		Digest: digester.Digest(),
	})
	if err != nil {
		log.Printf("Error commiting blob writer: %v", err)
		return
	}

	bar.Finish()
	return
}