Add push object
Split resolver to only return a name with separate methods for getting a fetcher and pusher. Add implementation for push. Signed-off-by: Derek McGowan <derek@mcgstyle.net>
This commit is contained in:
6
cmd/dist/fetch.go
vendored
6
cmd/dist/fetch.go
vendored
@@ -72,7 +72,11 @@ Most of this is experimental and there are few leaps to make this work.`,
|
||||
resolved := make(chan struct{})
|
||||
eg.Go(func() error {
|
||||
ongoing.add(ref)
|
||||
name, desc, fetcher, err := resolver.Resolve(ctx, ref)
|
||||
name, desc, err := resolver.Resolve(ctx, ref)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
fetcher, err := resolver.Fetcher(ctx, name)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
6
cmd/dist/fetchobject.go
vendored
6
cmd/dist/fetchobject.go
vendored
@@ -33,7 +33,11 @@ var fetchObjectCommand = cli.Command{
|
||||
ctx = log.WithLogger(ctx, log.G(ctx).WithField("ref", ref))
|
||||
|
||||
log.G(ctx).Infof("resolving")
|
||||
_, desc, fetcher, err := resolver.Resolve(ctx, ref)
|
||||
name, desc, err := resolver.Resolve(ctx, ref)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
fetcher, err := resolver.Fetcher(ctx, name)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
1
cmd/dist/main.go
vendored
1
cmd/dist/main.go
vendored
@@ -77,6 +77,7 @@ distribution tool
|
||||
fetchObjectCommand,
|
||||
applyCommand,
|
||||
rootfsCommand,
|
||||
pushObjectCommand,
|
||||
}
|
||||
app.Before = func(context *cli.Context) error {
|
||||
timeout = context.GlobalDuration("timeout")
|
||||
|
||||
7
cmd/dist/pull.go
vendored
7
cmd/dist/pull.go
vendored
@@ -64,11 +64,16 @@ command. As part of this process, we do the following:
|
||||
resolved := make(chan struct{})
|
||||
eg.Go(func() error {
|
||||
ongoing.add(ref)
|
||||
name, desc, fetcher, err := resolver.Resolve(ctx, ref)
|
||||
name, desc, err := resolver.Resolve(ctx, ref)
|
||||
if err != nil {
|
||||
log.G(ctx).WithError(err).Error("failed to resolve")
|
||||
return err
|
||||
}
|
||||
fetcher, err := resolver.Fetcher(ctx, name)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
log.G(ctx).WithField("image", name).Debug("fetching")
|
||||
resolvedImageName = name
|
||||
close(resolved)
|
||||
|
||||
75
cmd/dist/pushobject.go
vendored
Normal file
75
cmd/dist/pushobject.go
vendored
Normal file
@@ -0,0 +1,75 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"github.com/containerd/containerd/log"
|
||||
digest "github.com/opencontainers/go-digest"
|
||||
ocispec "github.com/opencontainers/image-spec/specs-go/v1"
|
||||
"github.com/urfave/cli"
|
||||
)
|
||||
|
||||
var pushObjectCommand = cli.Command{
|
||||
Name: "push-object",
|
||||
Usage: "pushes an object to a remote",
|
||||
ArgsUsage: "[flags] <remote> <object> <type>",
|
||||
Description: `Push objects by identifier to a remote.`,
|
||||
Flags: registryFlags,
|
||||
Action: func(clicontext *cli.Context) error {
|
||||
var (
|
||||
ref = clicontext.Args().Get(0)
|
||||
object = clicontext.Args().Get(1)
|
||||
media = clicontext.Args().Get(2)
|
||||
)
|
||||
dgst, err := digest.Parse(object)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
ctx, cancel := appContext()
|
||||
defer cancel()
|
||||
|
||||
resolver, err := getResolver(ctx, clicontext)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
ctx = log.WithLogger(ctx, log.G(ctx).WithField("ref", ref))
|
||||
|
||||
log.G(ctx).Infof("resolving")
|
||||
pusher, err := resolver.Pusher(ctx, ref)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
cs, err := resolveContentStore(clicontext)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
info, err := cs.Info(ctx, dgst)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
desc := ocispec.Descriptor{
|
||||
MediaType: media,
|
||||
Digest: dgst,
|
||||
Size: info.Size,
|
||||
}
|
||||
|
||||
rc, err := cs.Reader(ctx, dgst)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
defer rc.Close()
|
||||
|
||||
// TODO: Progress reader
|
||||
if err = pusher.Push(ctx, desc, rc); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
fmt.Printf("Pushed %s %s\n", desc.Digest, desc.MediaType)
|
||||
|
||||
return nil
|
||||
},
|
||||
}
|
||||
Reference in New Issue
Block a user