Improve kubernetes package to handle deployment from url
When I was working on ArgoCD test integration, I found that to expose ArgoCD server, we need to add `ingress` to expose an endpoint. To do it with Kind, it's necessary to apply a custom yaml available on Github. It simply then need `kubectl apply -f <url>` Signed-off-by: Tom Chauveau <tom.chauveau@epitech.eu>
This commit is contained in:
parent
3ef1196cb6
commit
97cd00332a
@ -11,7 +11,7 @@ import (
|
|||||||
#Kubectl: {
|
#Kubectl: {
|
||||||
|
|
||||||
// Kubectl version
|
// Kubectl version
|
||||||
version: *"v1.19.9" | string
|
version: dagger.#Input & {*"v1.19.9" | string}
|
||||||
|
|
||||||
#code: #"""
|
#code: #"""
|
||||||
[ -e /usr/local/bin/kubectl ] || {
|
[ -e /usr/local/bin/kubectl ] || {
|
||||||
@ -50,23 +50,35 @@ import (
|
|||||||
#Resources: {
|
#Resources: {
|
||||||
|
|
||||||
// Kubernetes config to deploy
|
// Kubernetes config to deploy
|
||||||
source?: dagger.#Artifact @dagger(input)
|
source: dagger.#Input & {*null | dagger.#Artifact}
|
||||||
|
|
||||||
// Kubernetes manifest to deploy inlined in a string
|
// Kubernetes manifest to deploy inlined in a string
|
||||||
manifest?: string @dagger(input)
|
manifest: dagger.#Input & {*null | string}
|
||||||
|
|
||||||
|
// Kubernetes manifest url to deploy remote configuration
|
||||||
|
url: dagger.#Input & {*null | string}
|
||||||
|
|
||||||
// Kubernetes Namespace to deploy to
|
// Kubernetes Namespace to deploy to
|
||||||
namespace: *"default" | string @dagger(input)
|
namespace: dagger.#Input & {*"default" | string}
|
||||||
|
|
||||||
// Version of kubectl client
|
// Version of kubectl client
|
||||||
version: *"v1.19.9" | string @dagger(input)
|
version: dagger.#Input & {*"v1.19.9" | string}
|
||||||
|
|
||||||
// Kube config file
|
// Kube config file
|
||||||
kubeconfig: string @dagger(input)
|
kubeconfig: dagger.#Input & {string}
|
||||||
|
|
||||||
#code: #"""
|
#code: #"""
|
||||||
kubectl create namespace "$KUBE_NAMESPACE" > /dev/null 2>&1 || true
|
kubectl create namespace "$KUBE_NAMESPACE" > /dev/null 2>&1 || true
|
||||||
kubectl --namespace "$KUBE_NAMESPACE" apply -R -f /source
|
|
||||||
|
if [ -d /source ] || [ -f /source ]; then
|
||||||
|
kubectl --namespace "$KUBE_NAMESPACE" apply -R -f /source
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$DEPLOYMENT_URL" ]; then
|
||||||
|
kubectl --namespace "$KUBE_NAMESPACE" apply -R -f "$DEPLOYMENT_URL"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
"""#
|
"""#
|
||||||
|
|
||||||
#up: [
|
#up: [
|
||||||
@ -82,7 +94,7 @@ import (
|
|||||||
content: kubeconfig
|
content: kubeconfig
|
||||||
mode: 0o600
|
mode: 0o600
|
||||||
},
|
},
|
||||||
if manifest != _|_ {
|
if manifest != null {
|
||||||
op.#WriteFile & {
|
op.#WriteFile & {
|
||||||
dest: "/source"
|
dest: "/source"
|
||||||
content: manifest
|
content: manifest
|
||||||
@ -101,8 +113,11 @@ import (
|
|||||||
env: {
|
env: {
|
||||||
KUBECONFIG: "/kubeconfig"
|
KUBECONFIG: "/kubeconfig"
|
||||||
KUBE_NAMESPACE: namespace
|
KUBE_NAMESPACE: namespace
|
||||||
|
if url != null {
|
||||||
|
DEPLOYMENT_URL: url
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if manifest == _|_ {
|
if manifest == null && source != null {
|
||||||
mount: "/source": from: source
|
mount: "/source": from: source
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
Reference in New Issue
Block a user