diff --git a/deployments/game-servers/wings-valheim/deployment.yaml b/deployments/game-servers/wings-valheim/deployment.yaml new file mode 100644 index 0000000..3841f34 --- /dev/null +++ b/deployments/game-servers/wings-valheim/deployment.yaml @@ -0,0 +1,118 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: wings-valheim + namespace: game-servers + labels: + app.kubernetes.io/name: wings + app.kubernetes.io/component: game-server + app.kubernetes.io/part-of: pelican + game: valheim +spec: + strategy: + type: Recreate + selector: + matchLabels: + app: wings-valheim + template: + metadata: + labels: + app: wings-valheim + game: valheim + spec: + nodeSelector: + kubernetes.io/arch: amd64 + containers: + - name: wings + image: ghcr.io/pelican-dev/wings:latest + env: + - name: DOCKER_HOST + value: tcp://localhost:2375 + - name: WINGS_UID + value: "1000" + - name: WINGS_GID + value: "1000" + - name: WINGS_PORT + value: "8081" + - name: WINGS_API_SFTP_PORT + value: "2023" + - name: WINGS_SERVER_UUID + value: "9d09e83d-00c3-4404-8f81-07c0522a6c25" + envFrom: + - secretRef: + name: wings-valheim-config + volumeMounts: + - name: docker-socket + mountPath: /var/run/docker.sock + - name: wings-data + mountPath: /var/lib/wings + - name: server-data + mountPath: /mnt/server + readinessProbe: + httpGet: + path: /ready + port: 8081 + initialDelaySeconds: 10 + periodSeconds: 10 + livenessProbe: + httpGet: + path: /health + port: 8081 + initialDelaySeconds: 15 + periodSeconds: 30 + - name: dind + image: docker:24-dind + securityContext: + privileged: true + env: + - name: DOCKER_TLS_CERTDIR + value: "" + volumeMounts: + - name: docker-socket + mountPath: /var/run + - name: dind-storage + mountPath: /var/lib/docker + readinessProbe: + exec: + command: + - sh + - -c + - '[ -S /var/run/docker.sock ]' + initialDelaySeconds: 5 + periodSeconds: 5 + - name: game-autostart + image: curlimages/curl:latest + env: + - name: PELICAN_API_KEY + valueFrom: + secretKeyRef: + name: pelican-autostart-key + key: api_key + - name: SERVER_UUID + value: "9d09e83d-00c3-4404-8f81-07c0522a6c25" + command: + - /bin/sh + - -c + - | + echo "Waiting for Wings API to be ready..." + while ! curl -sf http://localhost:8081/ready; do + sleep 2 + done + echo "Wings ready. Starting game server..." + while true; do + sleep 60 + echo "Checking game server status..." + done + volumeMounts: + - name: server-data + mountPath: /mnt/server + volumes: + - name: docker-socket + emptyDir: {} + - name: dind-storage + emptyDir: {} + - name: wings-data + emptyDir: {} + - name: server-data + persistentVolumeClaim: + claimName: wings-valheim-data diff --git a/deployments/game-servers/wings-valheim/externalsecret.yaml b/deployments/game-servers/wings-valheim/externalsecret.yaml new file mode 100644 index 0000000..648f6ab --- /dev/null +++ b/deployments/game-servers/wings-valheim/externalsecret.yaml @@ -0,0 +1,22 @@ +apiVersion: external-secrets.io/v1beta1 +kind: ExternalSecret +metadata: + name: wings-valheim-config + namespace: game-servers +spec: + refreshInterval: 1h + secretStoreRef: + name: vault-secret-store + kind: ClusterSecretStore + target: + name: wings-valheim-config + creationPolicy: Owner + data: + - secretKey: config + remoteRef: + key: Talos Cluster/wings/valheim + property: config + - secretKey: api_key + remoteRef: + key: Talos Cluster/wings/valheim + property: api_key diff --git a/deployments/game-servers/wings-valheim/ingress.yaml b/deployments/game-servers/wings-valheim/ingress.yaml new file mode 100644 index 0000000..7a8fd8d --- /dev/null +++ b/deployments/game-servers/wings-valheim/ingress.yaml @@ -0,0 +1,17 @@ +apiVersion: traefik.containo.us/v1alpha1 +kind: IngressRoute +metadata: + name: wings-valheim-api + namespace: game-servers +spec: + entryPoints: + - websecure + tls: + secretName: wings-valheim-tls + certResolver: letsencrypt + routes: + - match: Host(`wings-valheim.khalisio.com`) + kind: Rule + services: + - name: wings-valheim-api + port: 8081 diff --git a/deployments/game-servers/wings-valheim/pvc.yaml b/deployments/game-servers/wings-valheim/pvc.yaml new file mode 100644 index 0000000..056767e --- /dev/null +++ b/deployments/game-servers/wings-valheim/pvc.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: wings-valheim-data + namespace: game-servers +spec: + accessModes: + - ReadWriteOnce + storageClassName: longhorn + resources: + requests: + storage: 30Gi diff --git a/deployments/game-servers/wings-valheim/service-api.yaml b/deployments/game-servers/wings-valheim/service-api.yaml new file mode 100644 index 0000000..4280f17 --- /dev/null +++ b/deployments/game-servers/wings-valheim/service-api.yaml @@ -0,0 +1,17 @@ +apiVersion: v1 +kind: Service +metadata: + name: wings-valheim-api + namespace: game-servers +spec: + selector: + app: wings-valheim + ports: + - name: api + port: 8081 + targetPort: 8081 + protocol: TCP + - name: sftp + port: 2023 + targetPort: 2023 + protocol: TCP diff --git a/deployments/game-servers/wings-valheim/service-game.yaml b/deployments/game-servers/wings-valheim/service-game.yaml new file mode 100644 index 0000000..1961fcf --- /dev/null +++ b/deployments/game-servers/wings-valheim/service-game.yaml @@ -0,0 +1,21 @@ +apiVersion: v1 +kind: Service +metadata: + name: wings-valheim-game + namespace: game-servers + annotations: + metallb.universe.tf/address-pool: default +spec: + type: LoadBalancer + loadBalancerIP: 10.4.4.205 + selector: + app: wings-valheim + ports: + - name: game-udp + port: 2456 + targetPort: 2456 + protocol: UDP + - name: game-tcp + port: 2457 + targetPort: 2457 + protocol: TCP