|
@@ -10,18 +10,21 @@ import (
|
|
|
clustertypes "github.com/docker/docker/daemon/cluster/provider"
|
|
|
networktypes "github.com/docker/libnetwork/types"
|
|
|
"github.com/docker/swarmkit/agent/exec"
|
|
|
+ "github.com/docker/swarmkit/agent/secrets"
|
|
|
"github.com/docker/swarmkit/api"
|
|
|
"golang.org/x/net/context"
|
|
|
)
|
|
|
|
|
|
type executor struct {
|
|
|
backend executorpkg.Backend
|
|
|
+ secrets exec.SecretsManager
|
|
|
}
|
|
|
|
|
|
// NewExecutor returns an executor from the docker client.
|
|
|
func NewExecutor(b executorpkg.Backend) exec.Executor {
|
|
|
return &executor{
|
|
|
backend: b,
|
|
|
+ secrets: secrets.NewManager(),
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -120,12 +123,12 @@ func (e *executor) Configure(ctx context.Context, node *api.Node) error {
|
|
|
}
|
|
|
|
|
|
// Controller returns a docker container runner.
|
|
|
-func (e *executor) Controller(t *api.Task, secrets exec.SecretProvider) (exec.Controller, error) {
|
|
|
+func (e *executor) Controller(t *api.Task) (exec.Controller, error) {
|
|
|
if t.Spec.GetAttachment() != nil {
|
|
|
- return newNetworkAttacherController(e.backend, t, secrets)
|
|
|
+ return newNetworkAttacherController(e.backend, t, e.secrets)
|
|
|
}
|
|
|
|
|
|
- ctlr, err := newController(e.backend, t, secrets)
|
|
|
+ ctlr, err := newController(e.backend, t, e.secrets)
|
|
|
if err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
@@ -150,6 +153,10 @@ func (e *executor) SetNetworkBootstrapKeys(keys []*api.EncryptionKey) error {
|
|
|
return nil
|
|
|
}
|
|
|
|
|
|
+func (e *executor) Secrets() exec.SecretsManager {
|
|
|
+ return e.secrets
|
|
|
+}
|
|
|
+
|
|
|
type sortedPlugins []api.PluginDescription
|
|
|
|
|
|
func (sp sortedPlugins) Len() int { return len(sp) }
|