Files
2025-03-23 17:05:04 +01:00

50 lines
2.9 KiB
Plaintext

1. Get the application URL by running these commands:
{{- if .Values.ingress.enabled }}
{{- range $host := .Values.ingress.hosts }}
{{- range .paths }}
http{{ if $.Values.ingress.tls }}s{{ end }}://{{ $host.host }}{{ .path }}
{{- end }}
{{- end }}
{{- else if contains "NodePort" .Values.service.type }}
export NODE_PORT=$(kubectl get --namespace {{ .Release.Namespace }} -o jsonpath="{.spec.ports[0].nodePort}" services {{ include "donetick.fullname" . }})
export NODE_IP=$(kubectl get nodes --namespace {{ .Release.Namespace }} -o jsonpath="{.items[0].status.addresses[0].address}")
echo http://$NODE_IP:$NODE_PORT
{{- else if contains "LoadBalancer" .Values.service.type }}
NOTE: It may take a few minutes for the LoadBalancer IP to be available.
You can watch the status of by running 'kubectl get --namespace {{ .Release.Namespace }} svc -w {{ include "donetick.fullname" . }}'
export SERVICE_IP=$(kubectl get svc --namespace {{ .Release.Namespace }} {{ include "donetick.fullname" . }} --template "{{"{{ range (index .status.loadBalancer.ingress 0) }}{{.}}{{ end }}"}}")
echo http://$SERVICE_IP:{{ .Values.service.port }}
{{- else if contains "ClusterIP" .Values.service.type }}
export POD_NAME=$(kubectl get pods --namespace {{ .Release.Namespace }} -l "app.kubernetes.io/name={{ include "donetick.name" . }},app.kubernetes.io/instance={{ .Release.Name }}" -o jsonpath="{.items[0].metadata.name}")
export CONTAINER_PORT=$(kubectl get pod --namespace {{ .Release.Namespace }} $POD_NAME -o jsonpath="{.spec.containers[0].ports[0].containerPort}")
echo "Visit http://127.0.0.1:8080 to use your application"
kubectl --namespace {{ .Release.Namespace }} port-forward $POD_NAME 8080:$CONTAINER_PORT
{{- end }}
2. Application is accessible at port {{ .Values.service.port }}
3. Donetick application is configured with:
- Database: {{ .Values.config.database.type }}
- User creation: {{ if .Values.config.is_user_creation_disabled }}disabled{{ else }}enabled{{ end }}
{{- if .Values.persistence.enabled }}
4. Data is persisted using PVC: {{ include "donetick.fullname" . }}-data
{{- else }}
4. WARNING: No persistence enabled. Data will be lost when pods are restarted.
{{- end }}
{{- if or .Values.config.jwt.existingSecret .Values.config.oauth2.existingSecret }}
5. Using external secrets for sensitive information:
{{- if .Values.config.jwt.existingSecret }}
- JWT secret from: {{ .Values.config.jwt.existingSecret }}
{{- end }}
{{- if .Values.config.oauth2.existingSecret }}
- OAuth2 credentials from: {{ .Values.config.oauth2.existingSecret }}
{{- end }}
{{- else }}
5. SECURITY NOTE: For production use, it's recommended to store sensitive data in Kubernetes Secrets.
- Set config.jwt.existingSecret to use an external secret for JWT
- Set config.oauth2.existingSecret to use an external secret for OAuth2 credentials
{{- end }}
For more information about using this Helm chart, please refer to the README.md file.