-
Notifications
You must be signed in to change notification settings - Fork 0
/
justfile
84 lines (73 loc) · 2.66 KB
/
justfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
set dotenv-load
default:
@just --list
namespace:= "deals-extractor"
deployment:= "deals-extractor"
deployerServiceAccountName:= "deals-extractor-deployer"
tag := "$(git rev-parse --short HEAD)"
imageRepo := "ghcr.io/psuzn/deals-scrapper"
run:
go run cmd/main.go
build-push-image imageTag=tag:
#!/usr/bin/env sh
tags="{{tag}},latest"
docker build -t {{imageRepo}}:{{tag}} -t {{imageRepo}}:latest .
docker push {{imageRepo}}:{{tag}}
docker push {{imageRepo}}:latest
echo Pushed tags $tags
ns-create:
kubectl create namespace {{ namespace }}
ns-delete:
kubectl delete namespace {{ namespace }}
# Uninstalls the helm chart
helm-delete:
helm uninstall -n {{namespace}} {{deployment}}
# Runs helm upgrade
helm-upgrade imageTag=tag:
#!/usr/bin/env sh
echo "Deploying {{imageRepo}}:{{imageTag}} to $(kubectl config current-context)"
helm upgrade {{deployment}} --create-namespace \
--install --namespace {{namespace}} ./deployment/helm/scrapper \
--set image.tag={{imageTag}} \
--set image.repository={{imageRepo}} \
--set serverUrl=$SERVER_URL \
--set urls=$URLS
# creates a service account and token for a deployer
helm-create-deployer:
echo "Creating deployer service account to $(kubectl config current-context)"
helm install {{deployment}}-deployer ./deployment/helm/service-account \
--namespace {{namespace}} --create-namespace \
--set serviceAccountName={{deployerServiceAccountName}} \
--set namespace={{namespace}}
# deletes the deployer service account
helm-delete-deployer:
echo "Deleting deployer service account to $(kubectl config current-context)"
helm uninstall {{deployment}}-deployer --namespace {{namespace}}
# gets the deployer kubeconfig
deployer-cubeconfig:
#!/usr/bin/env sh
CLUSTER_NAME=$(kubectl config current-context)
SECRET_NAME="sa-{{ deployerServiceAccountName }}-token"
SA_TOKEN=$(kubectl get secret $SECRET_NAME -n {{namespace}} -o jsonpath='{.data.token}' | base64 -D)
CA_DATA=$(kubectl get secret $SECRET_NAME -n {{namespace}} -o jsonpath='{.data.ca\.crt}')
K8S_ENDPOINT=$(kubectl config view -o jsonpath="{.clusters[?(@.name=='${CLUSTER_NAME}')].cluster.server}")
echo "
apiVersion: v1
kind: Config
clusters:
- name: default-cluster
cluster:
certificate-authority-data: ${CA_DATA}
server: ${K8S_ENDPOINT}
contexts:
- name: default-context
context:
cluster: default-cluster
namespace: {{namespace}}
user: default-user
current-context: default-context
users:
- name: default-user
user:
token: ${SA_TOKEN}
"