2020-05-19 17:11:31 +02:00
|
|
|
package store
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"os/exec"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Represents a context as created by the docker cli
|
|
|
|
type defaultContext struct {
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
Metadata ContextMetadata
|
2020-05-19 17:11:31 +02:00
|
|
|
Endpoints endpoints
|
|
|
|
}
|
|
|
|
|
|
|
|
// Normally (in docker/cli code), the endpoints are mapped as map[string]interface{}
|
|
|
|
// but docker cli contexts always have a "docker" and "kubernetes" key so we
|
|
|
|
// create real types for those to no have to juggle around with interfaces.
|
|
|
|
type endpoints struct {
|
|
|
|
Docker endpoint `json:"docker,omitempty"`
|
|
|
|
Kubernetes endpoint `json:"kubernetes,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Both "docker" and "kubernetes" endpoints in the docker cli created contexts
|
|
|
|
// have a "Host", only kubernetes has the "DefaultNamespace", we put both of
|
|
|
|
// those here for easier manipulation and to not have to create two distinct
|
|
|
|
// structs
|
|
|
|
type endpoint struct {
|
|
|
|
Host string
|
|
|
|
DefaultNamespace string
|
|
|
|
}
|
|
|
|
|
2020-05-20 15:06:08 +02:00
|
|
|
func dockerDefaultContext() (*Metadata, error) {
|
2020-05-26 23:34:38 +02:00
|
|
|
cmd := exec.Command("docker-classic", "context", "inspect", "default")
|
2020-05-19 17:11:31 +02:00
|
|
|
var stdout bytes.Buffer
|
|
|
|
cmd.Stdout = &stdout
|
|
|
|
err := cmd.Run()
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var ctx []defaultContext
|
|
|
|
err = json.Unmarshal(stdout.Bytes(), &ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(ctx) != 1 {
|
|
|
|
return nil, errors.New("found more than one default context")
|
|
|
|
}
|
|
|
|
|
|
|
|
defaultCtx := ctx[0]
|
|
|
|
|
|
|
|
meta := Metadata{
|
|
|
|
Name: "default",
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
Type: "docker",
|
|
|
|
Endpoints: map[string]interface{}{
|
|
|
|
"docker": Endpoint{
|
2020-05-19 17:11:31 +02:00
|
|
|
Host: defaultCtx.Endpoints.Docker.Host,
|
|
|
|
},
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
"kubernetes": Endpoint{
|
2020-05-19 17:11:31 +02:00
|
|
|
Host: defaultCtx.Endpoints.Kubernetes.Host,
|
|
|
|
DefaultNamespace: defaultCtx.Endpoints.Kubernetes.DefaultNamespace,
|
|
|
|
},
|
|
|
|
},
|
Change the way a context is stored
Initially we stored the context data in the `Metadata` of the context
but in hindsight this data would be better of in the `Endpoints` because
that's what it is used for.
Before:
```json
{
"Name": "aci",
"Metadata": {
"Type": "aci",
"Data": {
"key": "value"
}
},
"Endpoints": {
"docker": {}
}
}
```
After:
```json
{
"Name": "aci",
"Type": "aci",
"Metadata": {},
"Endpoints": {
"aci": {
"key": "value"
},
"docker": {}
}
}
```
With this change the contexts that we create are more in line with the contexts the docker cli creates.
It also makes the code less complicated since we don't need to marsal twice any more. The API is nicer too:
```go
// Get a context:
c, err := store.Get(contextName)
// Get the stored endpoint:
var aciContext store.AciContext
if err := contextStore.GetEndpoint(currentContext, &aciContext); err != nil {
return nil, err
}
```
2020-05-22 11:16:01 +02:00
|
|
|
Metadata: ContextMetadata{
|
2020-05-19 17:11:31 +02:00
|
|
|
Description: "Current DOCKER_HOST based configuration",
|
|
|
|
StackOrchestrator: defaultCtx.Metadata.StackOrchestrator,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
return &meta, nil
|
|
|
|
}
|