From 662d1f07a8247e9547e8b7e339e92c4695c954c5 Mon Sep 17 00:00:00 2001 From: ageekymonk Date: Wed, 15 Aug 2018 15:26:10 +1000 Subject: [PATCH] Darwin specific lookup file without cri and vic --- vkubelet/lookup_darwin.go | 50 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 vkubelet/lookup_darwin.go diff --git a/vkubelet/lookup_darwin.go b/vkubelet/lookup_darwin.go new file mode 100644 index 000000000..55d34e18a --- /dev/null +++ b/vkubelet/lookup_darwin.go @@ -0,0 +1,50 @@ +package vkubelet + +import ( + "fmt" + + "github.com/virtual-kubelet/virtual-kubelet/manager" + "github.com/virtual-kubelet/virtual-kubelet/providers/aws" + "github.com/virtual-kubelet/virtual-kubelet/providers/azure" + "github.com/virtual-kubelet/virtual-kubelet/providers/azurebatch" + "github.com/virtual-kubelet/virtual-kubelet/providers/huawei" + "github.com/virtual-kubelet/virtual-kubelet/providers/hypersh" + "github.com/virtual-kubelet/virtual-kubelet/providers/mock" + "github.com/virtual-kubelet/virtual-kubelet/providers/sfmesh" + "github.com/virtual-kubelet/virtual-kubelet/providers/web" +) + +// Compile time proof that our implementations meet the Provider interface. +var _ Provider = (*aws.FargateProvider)(nil) +var _ Provider = (*azure.ACIProvider)(nil) +var _ Provider = (*hypersh.HyperProvider)(nil) +var _ Provider = (*web.BrokerProvider)(nil) +var _ Provider = (*mock.MockProvider)(nil) +var _ Provider = (*huawei.CCIProvider)(nil) +var _ Provider = (*azurebatch.Provider)(nil) +var _ Provider = (*sfmesh.SFMeshProvider)(nil) + +func lookupProvider(provider, providerConfig string, rm *manager.ResourceManager, nodeName, operatingSystem, internalIP string, daemonEndpointPort int32) (Provider, error) { + switch provider { + case "aws": + return aws.NewFargateProvider(providerConfig, rm, nodeName, operatingSystem, internalIP, daemonEndpointPort) + case "azure": + return azure.NewACIProvider(providerConfig, rm, nodeName, operatingSystem, internalIP, daemonEndpointPort) + case "azurebatch": + return azurebatch.NewBatchProvider(providerConfig, rm, nodeName, operatingSystem, internalIP, daemonEndpointPort) + case "hyper": + return hypersh.NewHyperProvider(providerConfig, rm, nodeName, operatingSystem) + case "web": + return web.NewBrokerProvider(nodeName, operatingSystem, daemonEndpointPort) + case "mock": + return mock.NewMockProvider(providerConfig, nodeName, operatingSystem, internalIP, daemonEndpointPort) + case "huawei": + return huawei.NewCCIProvider(providerConfig, rm, nodeName, operatingSystem, internalIP, daemonEndpointPort) + case "sfmesh": + return sfmesh.NewSFMeshProvider(rm, nodeName, operatingSystem, internalIP, daemonEndpointPort) + default: + fmt.Printf("Provider '%s' is not supported\n", provider) + } + var p Provider + return p, nil +}