mirror of
https://github.com/aljazceru/kata-containers.git
synced 2025-12-23 17:24:18 +01:00
A proxy is mostly associated with an agent. Decouple it from sandbox so that we can start it before linking vm with an actual sandbox. Signed-off-by: Peng Tao <bergwolf@gmail.com>
176 lines
3.9 KiB
Go
176 lines
3.9 KiB
Go
// Copyright (c) 2017 Intel Corporation
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
//
|
|
|
|
package virtcontainers
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
// ProxyConfig is a structure storing information needed from any
|
|
// proxy in order to be properly initialized.
|
|
type ProxyConfig struct {
|
|
Path string
|
|
Debug bool
|
|
}
|
|
|
|
// proxyParams is the structure providing specific parameters needed
|
|
// for the execution of the proxy binary.
|
|
type proxyParams struct {
|
|
id string
|
|
path string
|
|
agentURL string
|
|
consoleURL string
|
|
logger *logrus.Entry
|
|
debug bool
|
|
}
|
|
|
|
// ProxyType describes a proxy type.
|
|
type ProxyType string
|
|
|
|
const (
|
|
// NoopProxyType is the noopProxy.
|
|
NoopProxyType ProxyType = "noopProxy"
|
|
|
|
// NoProxyType is the noProxy.
|
|
NoProxyType ProxyType = "noProxy"
|
|
|
|
// CCProxyType is the ccProxy.
|
|
CCProxyType ProxyType = "ccProxy"
|
|
|
|
// KataProxyType is the kataProxy.
|
|
KataProxyType ProxyType = "kataProxy"
|
|
|
|
// KataBuiltInProxyType is the kataBuiltInProxy.
|
|
KataBuiltInProxyType ProxyType = "kataBuiltInProxy"
|
|
)
|
|
|
|
const (
|
|
// Number of seconds to wait for the proxy to respond to a connection
|
|
// request.
|
|
waitForProxyTimeoutSecs = 5.0
|
|
)
|
|
|
|
const (
|
|
// unix socket type of console
|
|
consoleProtoUnix = "unix"
|
|
|
|
// pty type of console. Used mostly by kvmtools.
|
|
consoleProtoPty = "pty"
|
|
)
|
|
|
|
// Set sets a proxy type based on the input string.
|
|
func (pType *ProxyType) Set(value string) error {
|
|
switch value {
|
|
case "noopProxy":
|
|
*pType = NoopProxyType
|
|
return nil
|
|
case "noProxy":
|
|
*pType = NoProxyType
|
|
return nil
|
|
case "ccProxy":
|
|
*pType = CCProxyType
|
|
return nil
|
|
case "kataProxy":
|
|
*pType = KataProxyType
|
|
return nil
|
|
case "kataBuiltInProxy":
|
|
*pType = KataBuiltInProxyType
|
|
return nil
|
|
default:
|
|
return fmt.Errorf("Unknown proxy type %s", value)
|
|
}
|
|
}
|
|
|
|
// String converts a proxy type to a string.
|
|
func (pType *ProxyType) String() string {
|
|
switch *pType {
|
|
case NoopProxyType:
|
|
return string(NoopProxyType)
|
|
case NoProxyType:
|
|
return string(NoProxyType)
|
|
case CCProxyType:
|
|
return string(CCProxyType)
|
|
case KataProxyType:
|
|
return string(KataProxyType)
|
|
case KataBuiltInProxyType:
|
|
return string(KataBuiltInProxyType)
|
|
default:
|
|
return ""
|
|
}
|
|
}
|
|
|
|
// newProxy returns a proxy from a proxy type.
|
|
func newProxy(pType ProxyType) (proxy, error) {
|
|
switch pType {
|
|
case NoopProxyType:
|
|
return &noopProxy{}, nil
|
|
case NoProxyType:
|
|
return &noProxy{}, nil
|
|
case CCProxyType:
|
|
return &ccProxy{}, nil
|
|
case KataProxyType:
|
|
return &kataProxy{}, nil
|
|
case KataBuiltInProxyType:
|
|
return &kataBuiltInProxy{}, nil
|
|
default:
|
|
return &noopProxy{}, nil
|
|
}
|
|
}
|
|
|
|
func validateProxyParams(p proxyParams) error {
|
|
if len(p.path) == 0 || len(p.id) == 0 || len(p.agentURL) == 0 || len(p.consoleURL) == 0 {
|
|
return fmt.Errorf("Invalid proxy parameters %+v", p)
|
|
}
|
|
|
|
if p.logger == nil {
|
|
return fmt.Errorf("Invalid proxy parameter: proxy logger is not set")
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func validateProxyConfig(proxyConfig ProxyConfig) error {
|
|
if len(proxyConfig.Path) == 0 {
|
|
return fmt.Errorf("Proxy path cannot be empty")
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func defaultProxyURL(id, socketType string) (string, error) {
|
|
switch socketType {
|
|
case SocketTypeUNIX:
|
|
socketPath := filepath.Join(runStoragePath, id, "proxy.sock")
|
|
return fmt.Sprintf("unix://%s", socketPath), nil
|
|
case SocketTypeVSOCK:
|
|
// TODO Build the VSOCK default URL
|
|
return "", nil
|
|
default:
|
|
return "", fmt.Errorf("Unknown socket type: %s", socketType)
|
|
}
|
|
}
|
|
|
|
func isProxyBuiltIn(pType ProxyType) bool {
|
|
return pType == KataBuiltInProxyType
|
|
}
|
|
|
|
// proxy is the virtcontainers proxy interface.
|
|
type proxy interface {
|
|
// start launches a proxy instance with specified parameters, returning
|
|
// the PID of the process and the URL used to connect to it.
|
|
start(params proxyParams) (int, string, error)
|
|
|
|
// stop terminates a proxy instance after all communications with the
|
|
// agent inside the VM have been properly stopped.
|
|
stop(pid int) error
|
|
|
|
//check if the proxy has watched the vm console.
|
|
consoleWatched() bool
|
|
}
|