* initial * add some comments * cleanup * var * Use X509Certificate2cCollection * add missing asset files * address comments
51 lines
2.0 KiB
C#
51 lines
2.0 KiB
C#
using System;
|
|
using System.IO;
|
|
using k8s.Exceptions;
|
|
|
|
namespace k8s
|
|
{
|
|
public partial class KubernetesClientConfiguration
|
|
{
|
|
private const string ServiceAccountPath = "/var/run/secrets/kubernetes.io/serviceaccount/";
|
|
private const string ServiceAccountTokenKeyFileName = "token";
|
|
private const string ServiceAccountRootCAKeyFileName = "ca.crt";
|
|
|
|
public static Boolean IsInCluster()
|
|
{
|
|
var host = Environment.GetEnvironmentVariable("KUBERNETES_SERVICE_HOST");
|
|
var port = Environment.GetEnvironmentVariable("KUBERNETES_SERVICE_PORT");
|
|
if (string.IsNullOrWhiteSpace(host) || string.IsNullOrWhiteSpace(port))
|
|
{
|
|
return false;
|
|
}
|
|
var tokenPath = Path.Combine(ServiceAccountPath, ServiceAccountTokenKeyFileName);
|
|
if (!File.Exists(tokenPath))
|
|
{
|
|
return false;
|
|
}
|
|
var certPath = Path.Combine(ServiceAccountPath, ServiceAccountRootCAKeyFileName);
|
|
return File.Exists(certPath);
|
|
}
|
|
|
|
public static KubernetesClientConfiguration InClusterConfig()
|
|
{
|
|
if (!IsInCluster()) {
|
|
throw new KubeConfigException(
|
|
"unable to load in-cluster configuration, KUBERNETES_SERVICE_HOST and KUBERNETES_SERVICE_PORT must be defined");
|
|
}
|
|
|
|
var token = File.ReadAllText(Path.Combine(ServiceAccountPath, ServiceAccountTokenKeyFileName));
|
|
var rootCAFile = Path.Combine(ServiceAccountPath, ServiceAccountRootCAKeyFileName);
|
|
var host = Environment.GetEnvironmentVariable("KUBERNETES_SERVICE_HOST");
|
|
var port = Environment.GetEnvironmentVariable("KUBERNETES_SERVICE_PORT");
|
|
|
|
return new KubernetesClientConfiguration
|
|
{
|
|
Host = new UriBuilder("https", host, Convert.ToInt32(port)).ToString(),
|
|
AccessToken = token,
|
|
SslCaCerts = CertUtils.LoadPemFileCert(rootCAFile)
|
|
};
|
|
}
|
|
}
|
|
}
|