mirror of
https://github.com/docker/compose.git
synced 2025-07-15 17:54:29 +02:00
ignore services without image attribute
Signed-off-by: Nicolas De Loof <nicolas.deloof@gmail.com>
This commit is contained in:
parent
b560f0cbe9
commit
5a455e47c3
@ -55,6 +55,14 @@ func (s *composeService) Pull(ctx context.Context, project *types.Project) error
|
|||||||
|
|
||||||
for _, srv := range project.Services {
|
for _, srv := range project.Services {
|
||||||
service := srv
|
service := srv
|
||||||
|
if service.Image == "" {
|
||||||
|
w.Event(progress.Event{
|
||||||
|
ID: service.Name,
|
||||||
|
Status: progress.Done,
|
||||||
|
Text: "Skipped",
|
||||||
|
})
|
||||||
|
continue
|
||||||
|
}
|
||||||
eg.Go(func() error {
|
eg.Go(func() error {
|
||||||
w.Event(progress.Event{
|
w.Event(progress.Event{
|
||||||
ID: service.Name,
|
ID: service.Name,
|
||||||
|
@ -23,6 +23,8 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
|
"github.com/docker/buildx/driver"
|
||||||
|
|
||||||
"github.com/docker/compose-cli/config"
|
"github.com/docker/compose-cli/config"
|
||||||
"github.com/docker/compose-cli/progress"
|
"github.com/docker/compose-cli/progress"
|
||||||
|
|
||||||
@ -51,64 +53,72 @@ func (s *composeService) Push(ctx context.Context, project *types.Project) error
|
|||||||
info.IndexServerAddress = registry.IndexServer
|
info.IndexServerAddress = registry.IndexServer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
w := progress.ContextWriter(ctx)
|
||||||
for _, service := range project.Services {
|
for _, service := range project.Services {
|
||||||
if service.Build == nil {
|
if service.Build == nil || service.Image == "" {
|
||||||
|
w.Event(progress.Event{
|
||||||
|
ID: service.Name,
|
||||||
|
Status: progress.Done,
|
||||||
|
Text: "Skipped",
|
||||||
|
})
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
service := service
|
service := service
|
||||||
eg.Go(func() error {
|
eg.Go(func() error {
|
||||||
w := progress.ContextWriter(ctx)
|
return s.pullServiceImage(ctx, service, info, configFile, w)
|
||||||
|
|
||||||
ref, err := reference.ParseNormalizedNamed(service.Image)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
repoInfo, err := registry.ParseRepositoryInfo(ref)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
key := repoInfo.Index.Name
|
|
||||||
if repoInfo.Index.Official {
|
|
||||||
key = info.IndexServerAddress
|
|
||||||
}
|
|
||||||
authConfig, err := configFile.GetAuthConfig(key)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
buf, err := json.Marshal(authConfig)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
stream, err := s.apiClient.ImagePush(ctx, service.Image, moby.ImagePushOptions{
|
|
||||||
RegistryAuth: base64.URLEncoding.EncodeToString(buf),
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
dec := json.NewDecoder(stream)
|
|
||||||
for {
|
|
||||||
var jm jsonmessage.JSONMessage
|
|
||||||
if err := dec.Decode(&jm); err != nil {
|
|
||||||
if err == io.EOF {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if jm.Error != nil {
|
|
||||||
return errors.New(jm.Error.Message)
|
|
||||||
}
|
|
||||||
toPushProgressEvent("Pushing "+service.Name, jm, w)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
return eg.Wait()
|
return eg.Wait()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *composeService) pullServiceImage(ctx context.Context, service types.ServiceConfig, info moby.Info, configFile driver.Auth, w progress.Writer) error {
|
||||||
|
ref, err := reference.ParseNormalizedNamed(service.Image)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
repoInfo, err := registry.ParseRepositoryInfo(ref)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
key := repoInfo.Index.Name
|
||||||
|
if repoInfo.Index.Official {
|
||||||
|
key = info.IndexServerAddress
|
||||||
|
}
|
||||||
|
authConfig, err := configFile.GetAuthConfig(key)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
buf, err := json.Marshal(authConfig)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
stream, err := s.apiClient.ImagePush(ctx, service.Image, moby.ImagePushOptions{
|
||||||
|
RegistryAuth: base64.URLEncoding.EncodeToString(buf),
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
dec := json.NewDecoder(stream)
|
||||||
|
for {
|
||||||
|
var jm jsonmessage.JSONMessage
|
||||||
|
if err := dec.Decode(&jm); err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if jm.Error != nil {
|
||||||
|
return errors.New(jm.Error.Message)
|
||||||
|
}
|
||||||
|
toPushProgressEvent("Pushing "+service.Name, jm, w)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func toPushProgressEvent(prefix string, jm jsonmessage.JSONMessage, w progress.Writer) {
|
func toPushProgressEvent(prefix string, jm jsonmessage.JSONMessage, w progress.Writer) {
|
||||||
if jm.ID == "" {
|
if jm.ID == "" {
|
||||||
// skipped
|
// skipped
|
||||||
|
Loading…
x
Reference in New Issue
Block a user