Move containers, compose, secrets to /api

Signed-off-by: Guillaume Tardif <guillaume.tardif@docker.com>
This commit is contained in:
Guillaume Tardif 2020-09-07 13:22:08 +02:00
parent 9545625131
commit d06aa2827f
46 changed files with 317 additions and 55 deletions

View File

@ -35,7 +35,7 @@ import (
"github.com/docker/compose-cli/aci/convert"
"github.com/docker/compose-cli/aci/login"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/context/store"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/progress"

View File

@ -33,14 +33,14 @@ import (
"github.com/docker/compose-cli/aci/convert"
"github.com/docker/compose-cli/aci/login"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
apicontext "github.com/docker/compose-cli/context"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/context/store"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
const (

View File

@ -23,7 +23,7 @@ import (
"github.com/stretchr/testify/mock"
"gotest.tools/v3/assert"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
func TestGetContainerName(t *testing.T) {

View File

@ -22,7 +22,7 @@ import (
"github.com/compose-spec/compose-go/types"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
// ContainerToComposeProject convert container config to compose project

View File

@ -23,7 +23,7 @@ import (
"github.com/compose-spec/compose-go/types"
"gotest.tools/v3/assert"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
func TestConvertContainerEnvironment(t *testing.T) {

View File

@ -26,7 +26,7 @@ import (
"strconv"
"strings"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/utils/formatter"
"github.com/Azure/azure-sdk-for-go/services/containerinstance/mgmt/2018-10-01/containerinstance"
@ -35,7 +35,7 @@ import (
"github.com/pkg/errors"
"github.com/docker/compose-cli/aci/login"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/context/store"
)

View File

@ -21,7 +21,7 @@ import (
"os"
"testing"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
"github.com/Azure/azure-sdk-for-go/profiles/latest/containerinstance/mgmt/containerinstance"
"github.com/Azure/go-autorest/autorest/to"
@ -29,7 +29,7 @@ import (
"gotest.tools/v3/assert"
is "gotest.tools/v3/assert/cmp"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/context/store"
)

View File

@ -21,7 +21,7 @@ import (
"github.com/Azure/azure-sdk-for-go/services/containerinstance/mgmt/2018-10-01/containerinstance"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
// ToPorts converts Azure container ports to api ports

View File

@ -23,7 +23,7 @@ import (
"github.com/Azure/go-autorest/autorest/to"
"gotest.tools/v3/assert"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
func TestPortConvert(t *testing.T) {

88
api/client/client.go Normal file
View File

@ -0,0 +1,88 @@
/*
Copyright 2020 Docker, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package client
import (
"context"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
apicontext "github.com/docker/compose-cli/context"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/context/store"
)
// New returns a backend client associated with current context
func New(ctx context.Context) (*Client, error) {
currentContext := apicontext.CurrentContext(ctx)
s := store.ContextStore(ctx)
cc, err := s.Get(currentContext)
if err != nil {
return nil, err
}
service, err := backend.Get(ctx, cc.Type())
if err != nil {
return nil, err
}
return &Client{
backendType: cc.Type(),
bs: service,
}, nil
}
// GetCloudService returns a backend CloudService (typically login, create context)
func GetCloudService(ctx context.Context, backendType string) (cloud.Service, error) {
return backend.GetCloudService(ctx, backendType)
}
// Client is a multi-backend client
type Client struct {
backendType string
bs backend.Service
}
// ContainerService returns the backend service for the current context
func (c *Client) ContainerService() containers.Service {
if cs := c.bs.ContainerService(); cs != nil {
return cs
}
return &containerService{}
}
// ComposeService returns the backend service for the current context
func (c *Client) ComposeService() compose.Service {
if cs := c.bs.ComposeService(); cs != nil {
return cs
}
return &composeService{}
}
// SecretsService returns the backend service for the current context
func (c *Client) SecretsService() secrets.Service {
if ss := c.bs.SecretsService(); ss != nil {
return ss
}
return &secretsService{}
}

60
api/client/compose.go Normal file
View File

@ -0,0 +1,60 @@
/*
Copyright 2020 Docker, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package client
import (
"context"
"io"
"github.com/compose-spec/compose-go/types"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/errdefs"
)
type composeService struct {
}
// Up executes the equivalent to a `compose up`
func (c *composeService) Up(context.Context, *types.Project) error {
return errdefs.ErrNotImplemented
}
// Down executes the equivalent to a `compose down`
func (c *composeService) Down(context.Context, string) error {
return errdefs.ErrNotImplemented
}
// Logs executes the equivalent to a `compose logs`
func (c *composeService) Logs(context.Context, string, io.Writer) error {
return errdefs.ErrNotImplemented
}
// Ps executes the equivalent to a `compose ps`
func (c *composeService) Ps(context.Context, string) ([]compose.ServiceStatus, error) {
return nil, errdefs.ErrNotImplemented
}
// List executes the equivalent to a `docker stack ls`
func (c *composeService) List(context.Context, string) ([]compose.Stack, error) {
return nil, errdefs.ErrNotImplemented
}
// Convert translate compose model into backend's native format
func (c *composeService) Convert(context.Context, *types.Project) ([]byte, error) {
return nil, errdefs.ErrNotImplemented
}

71
api/client/containers.go Normal file
View File

@ -0,0 +1,71 @@
/*
Copyright 2020 Docker, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package client
import (
"context"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/errdefs"
)
type containerService struct {
}
// List returns all the containers
func (c *containerService) List(context.Context, bool) ([]containers.Container, error) {
return nil, errdefs.ErrNotImplemented
}
// Start starts a stopped container
func (c *containerService) Start(context.Context, string) error {
return errdefs.ErrNotImplemented
}
// Stop stops the running container
func (c *containerService) Stop(context.Context, string, *uint32) error {
return errdefs.ErrNotImplemented
}
func (c *containerService) Kill(ctx context.Context, containerID string, signal string) error {
return errdefs.ErrNotImplemented
}
// Run creates and starts a container
func (c *containerService) Run(context.Context, containers.ContainerConfig) error {
return errdefs.ErrNotImplemented
}
// Exec executes a command inside a running container
func (c *containerService) Exec(context.Context, string, containers.ExecRequest) error {
return errdefs.ErrNotImplemented
}
// Logs returns all the logs of a container
func (c *containerService) Logs(context.Context, string, containers.LogsRequest) error {
return errdefs.ErrNotImplemented
}
// Delete removes containers
func (c *containerService) Delete(context.Context, string, containers.DeleteRequest) error {
return errdefs.ErrNotImplemented
}
// Inspect get a specific container
func (c *containerService) Inspect(context.Context, string) (containers.Container, error) {
return containers.Container{}, errdefs.ErrNotImplemented
}

43
api/client/secrets.go Normal file
View File

@ -0,0 +1,43 @@
/*
Copyright 2020 Docker, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package client
import (
"context"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/errdefs"
)
type secretsService struct {
}
func (s *secretsService) CreateSecret(context.Context, secrets.Secret) (string, error) {
return "", errdefs.ErrNotImplemented
}
func (s *secretsService) InspectSecret(context.Context, string) (secrets.Secret, error) {
return secrets.Secret{}, errdefs.ErrNotImplemented
}
func (s *secretsService) ListSecrets(context.Context) ([]secrets.Secret, error) {
return nil, errdefs.ErrNotImplemented
}
func (s *secretsService) DeleteSecret(context.Context, string, bool) error {
return errdefs.ErrNotImplemented
}

View File

@ -23,11 +23,11 @@ import (
"github.com/sirupsen/logrus"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
var (

View File

@ -26,8 +26,8 @@ import (
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/client"
"github.com/docker/compose-cli/containers"
)
type execOpts struct {

View File

@ -25,8 +25,8 @@ import (
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/client"
"github.com/docker/compose-cli/containers"
)
type logsOpts struct {

View File

@ -25,8 +25,8 @@ import (
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/client"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/errdefs"
)

View File

@ -25,7 +25,7 @@ import (
"github.com/containerd/console"
"github.com/spf13/cobra"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/cli/options/run"
"github.com/docker/compose-cli/client"

View File

@ -25,8 +25,8 @@ import (
"github.com/spf13/cobra"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/client"
"github.com/docker/compose-cli/secrets"
)
type createSecretOptions struct {

View File

@ -22,7 +22,7 @@ import (
"gotest.tools/v3/golden"
"github.com/docker/compose-cli/secrets"
"github.com/docker/compose-cli/api/secrets"
)
func TestPrintList(t *testing.T) {

View File

@ -26,7 +26,7 @@ import (
"github.com/docker/docker/pkg/namesgenerator"
"github.com/docker/go-connections/nat"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/formatter"
)

View File

@ -25,7 +25,7 @@ import (
"gotest.tools/v3/assert"
"gotest.tools/v3/assert/cmp"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
var (

View File

@ -19,13 +19,13 @@ package client
import (
"context"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
apicontext "github.com/docker/compose-cli/context"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/context/store"
"github.com/docker/compose-cli/secrets"
)
// New returns a backend client associated with current context

View File

@ -22,7 +22,7 @@ import (
"github.com/compose-spec/compose-go/types"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/errdefs"
)

View File

@ -19,7 +19,7 @@ package client
import (
"context"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/errdefs"
)

View File

@ -19,8 +19,8 @@ package client
import (
"context"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
type secretsService struct {

View File

@ -22,14 +22,14 @@ import (
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
apicontext "github.com/docker/compose-cli/context"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/context/store"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
const backendType = store.EcsContextType

View File

@ -23,7 +23,7 @@ import (
"regexp"
"strings"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
ecsapi "github.com/aws/aws-sdk-go/service/ecs"
"github.com/aws/aws-sdk-go/service/elbv2"

View File

@ -21,7 +21,7 @@ import (
"reflect"
"testing"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
"github.com/aws/aws-sdk-go/service/elbv2"
"github.com/awslabs/goformation/v4/cloudformation"

View File

@ -19,7 +19,7 @@ package ecs
import (
"context"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
)
func (b *ecsAPIService) List(ctx context.Context, project string) ([]compose.Stack, error) {

View File

@ -19,9 +19,9 @@ package local
import (
"context"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/secrets"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/docker/client"
"github.com/docker/compose-cli/backend"

View File

@ -30,7 +30,7 @@ import (
types2 "github.com/docker/docker/api/types"
"github.com/docker/docker/api/types/filters"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/errdefs"
"github.com/aws/aws-sdk-go/aws"

View File

@ -21,7 +21,7 @@ import (
"fmt"
"strings"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/api/compose"
)
func (b *ecsAPIService) Ps(ctx context.Context, project string) ([]compose.ServiceStatus, error) {

View File

@ -24,8 +24,8 @@ import (
"github.com/aws/aws-sdk-go/aws/client"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/secrets"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/secrets"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/cloudformation"

View File

@ -19,7 +19,7 @@ package ecs
import (
"context"
"github.com/docker/compose-cli/secrets"
"github.com/docker/compose-cli/api/secrets"
)
func (b *ecsAPIService) CreateSecret(ctx context.Context, secret secrets.Secret) (string, error) {

View File

@ -26,12 +26,12 @@ import (
"github.com/compose-spec/compose-go/types"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
type apiService struct {

View File

@ -36,12 +36,12 @@ import (
"github.com/docker/docker/pkg/stdcopy"
"github.com/pkg/errors"
"github.com/docker/compose-cli/api/compose"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/api/secrets"
"github.com/docker/compose-cli/backend"
"github.com/docker/compose-cli/compose"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/context/cloud"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/secrets"
)
type local struct {

View File

@ -20,7 +20,7 @@ import (
"context"
"errors"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/formatter"
containersv1 "github.com/docker/compose-cli/protos/containers/v1"
"github.com/docker/compose-cli/server/proxy/streams"

View File

@ -21,7 +21,7 @@ import (
"gotest.tools/v3/assert"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/formatter"
containersv1 "github.com/docker/compose-cli/protos/containers/v1"
)

View File

@ -45,7 +45,7 @@ import (
"github.com/docker/compose-cli/aci"
"github.com/docker/compose-cli/aci/login"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
"github.com/docker/compose-cli/context/store"
"github.com/docker/compose-cli/errdefs"
"github.com/docker/compose-cli/tests/aci-e2e/storage"

View File

@ -33,7 +33,7 @@ import (
is "gotest.tools/v3/assert/cmp"
"gotest.tools/v3/icmd"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
var (

View File

@ -22,7 +22,7 @@ import (
"strconv"
"strings"
"github.com/docker/compose-cli/containers"
"github.com/docker/compose-cli/api/containers"
)
type portGroup struct {