Compare commits
15 Commits
feature/ka
...
feature/ai
| Author | SHA1 | Date | |
|---|---|---|---|
| 093e57c4cc | |||
| 01ba25f097 | |||
| c3b2b03c13 | |||
| 9ad7efc09d | |||
| d7ac8b5b26 | |||
| c4f6a1c028 | |||
| a3507fd7f1 | |||
| 72ab85d0cd | |||
| 077be9fbf3 | |||
| 16da2fa6b3 | |||
| 9ab283f1e5 | |||
| e06b270e67 | |||
| 89d2952d7a | |||
| 3d6eadf128 | |||
| 260b45637e |
@@ -4,5 +4,4 @@ resources:
|
|||||||
- dot-ai-stack.yaml
|
- dot-ai-stack.yaml
|
||||||
- mcp10x.yaml
|
- mcp10x.yaml
|
||||||
- musicman.yaml
|
- musicman.yaml
|
||||||
- ts-mcp.yaml
|
|
||||||
- argo-mcp.yaml
|
- argo-mcp.yaml
|
||||||
|
|||||||
@@ -1,40 +0,0 @@
|
|||||||
apiVersion: argoproj.io/v1alpha1
|
|
||||||
kind: Application
|
|
||||||
metadata:
|
|
||||||
name: ts-mcp
|
|
||||||
namespace: argocd
|
|
||||||
annotations:
|
|
||||||
argocd.argoproj.io/sync-wave: "11"
|
|
||||||
notifications.argoproj.io/subscribe.on-sync-succeeded.slack: ""
|
|
||||||
notifications.argoproj.io/subscribe.on-sync-failed.slack: ""
|
|
||||||
notifications.argoproj.io/subscribe.on-degraded.slack: ""
|
|
||||||
labels:
|
|
||||||
app.kubernetes.io/name: ts-mcp
|
|
||||||
app.kubernetes.io/part-of: apps
|
|
||||||
app.kubernetes.io/managed-by: argocd
|
|
||||||
finalizers:
|
|
||||||
- resources-finalizer.argocd.argoproj.io
|
|
||||||
spec:
|
|
||||||
project: default
|
|
||||||
sources:
|
|
||||||
- repoURL: ssh://git@git.forteapps.net:2222/Forte/forte-helm.git
|
|
||||||
path: forteapp
|
|
||||||
targetRevision: HEAD
|
|
||||||
helm:
|
|
||||||
valueFiles:
|
|
||||||
- $values/ts-mcp/values.yaml
|
|
||||||
|
|
||||||
- repoURL: ssh://git@git.forteapps.net:2222/Forte/helm-prod-values.git
|
|
||||||
targetRevision: HEAD
|
|
||||||
ref: values
|
|
||||||
|
|
||||||
destination:
|
|
||||||
server: https://kubernetes.default.svc
|
|
||||||
namespace: ts-mcp
|
|
||||||
|
|
||||||
syncPolicy:
|
|
||||||
automated:
|
|
||||||
prune: true
|
|
||||||
selfHeal: true
|
|
||||||
syncOptions:
|
|
||||||
- CreateNamespace=true
|
|
||||||
@@ -962,46 +962,6 @@ User sees application (authenticated)
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### Accessing Authenticated User Information
|
|
||||||
|
|
||||||
The auth sidecar handles all authentication before requests reach your application. Your app never sees unauthenticated traffic — the sidecar returns 401 or redirects to the IdP first.
|
|
||||||
|
|
||||||
After successful authentication, the sidecar forwards the request to your application with user identity injected as HTTP headers:
|
|
||||||
|
|
||||||
| Header | Description | Available in |
|
|
||||||
|--------|-------------|-------------|
|
|
||||||
| `X-Auth-User` | Username or display name | Token, OIDC, MCP |
|
|
||||||
| `X-Auth-Email` | User email address | OIDC |
|
|
||||||
| `X-Auth-Subject` | OIDC `sub` claim (stable user ID) | OIDC, MCP |
|
|
||||||
| `X-Auth-Groups` | Comma-separated group memberships | OIDC (if scope includes `groups`) |
|
|
||||||
| `X-Auth-Token` | The validated access token | All modes |
|
|
||||||
|
|
||||||
**Your application reads these headers — no auth library needed:**
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Express.js example
|
|
||||||
app.get('/profile', (req, res) => {
|
|
||||||
const user = req.headers['x-auth-user'];
|
|
||||||
const email = req.headers['x-auth-email'];
|
|
||||||
res.json({ user, email });
|
|
||||||
});
|
|
||||||
```
|
|
||||||
|
|
||||||
```python
|
|
||||||
# Flask example
|
|
||||||
@app.route('/profile')
|
|
||||||
def profile():
|
|
||||||
user = request.headers.get('X-Auth-User')
|
|
||||||
email = request.headers.get('X-Auth-Email')
|
|
||||||
return jsonify(user=user, email=email)
|
|
||||||
```
|
|
||||||
|
|
||||||
**Why this is safe**: The Kyverno-generated NetworkPolicy restricts ingress to the sidecar port only. Traffic cannot bypass the sidecar to reach the application port directly, so the `X-Auth-*` headers can be trusted unconditionally.
|
|
||||||
|
|
||||||
**Key principle**: Your application is zero-trust-unaware by design. It reads headers and renders UI. All authentication complexity lives in the sidecar and Kyverno policy.
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
### Authentication Configuration Reference
|
### Authentication Configuration Reference
|
||||||
|
|
||||||
#### Helm Values Schema
|
#### Helm Values Schema
|
||||||
|
|||||||
@@ -602,15 +602,6 @@ retry:
|
|||||||
4. 40 seconds
|
4. 40 seconds
|
||||||
5. 80 seconds (capped at 3 minutes)
|
5. 80 seconds (capped at 3 minutes)
|
||||||
|
|
||||||
### Global Settings (`argocd-cm`)
|
|
||||||
|
|
||||||
| Setting | Value | Purpose |
|
|
||||||
|---------|-------|---------|
|
|
||||||
| `application.resourceTrackingMethod` | `annotation` | Track resources via annotations |
|
|
||||||
| `timeout.reconciliation` | `60s` | Reconciliation interval |
|
|
||||||
| `admin.enabled` | `true` | Enable admin account |
|
|
||||||
| `git.submodule.enabled` | `false` | Disable git submodule checkout — submodules are not needed for manifest generation |
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## Infrastructure Components
|
## Infrastructure Components
|
||||||
@@ -1078,33 +1069,6 @@ kubectl get secret keycloak-client-<app> -n keycloak -o jsonpath='{.metadata.ann
|
|||||||
|
|
||||||
**See**: [Developer Guide - Adding a New Keycloak Client](DEVELOPER-GUIDE.md#adding-a-new-keycloak-client)
|
**See**: [Developer Guide - Adding a New Keycloak Client](DEVELOPER-GUIDE.md#adding-a-new-keycloak-client)
|
||||||
|
|
||||||
### Karpor
|
|
||||||
|
|
||||||
**Chart**: `karpor` from `https://kusionstack.github.io/charts`
|
|
||||||
**Version**: 0.7.6 (app v0.6.4)
|
|
||||||
**Namespace**: `karpor`
|
|
||||||
**Sync Wave**: 1
|
|
||||||
|
|
||||||
**Purpose**: Kubernetes visualization and intelligence tool. Provides cross-cluster resource search, compliance checking, and topology visualization. Gives platform engineers a unified view of all cluster resources and their relationships.
|
|
||||||
|
|
||||||
**Architecture** (4 components):
|
|
||||||
- **Server** — main Karpor API/UI (port 7443)
|
|
||||||
- **Syncer** — syncs cluster state into the search index
|
|
||||||
- **ElasticSearch** — search backend for resource indexing
|
|
||||||
- **etcd** — persistent key-value store (10Gi PVC)
|
|
||||||
|
|
||||||
**Configuration** (`infra/values/base/karpor-values.yaml`):
|
|
||||||
- `namespaceEnabled: false` — ArgoCD manages namespace creation
|
|
||||||
- Default resource limits tuned for small clusters
|
|
||||||
- ElasticSearch: 2 CPU / 4Gi memory (the heaviest component)
|
|
||||||
- AI features available but not enabled (requires `server.ai.authToken` + backend config)
|
|
||||||
|
|
||||||
**Access**: Port-forward to reach the UI:
|
|
||||||
```bash
|
|
||||||
kubectl port-forward svc/karpor-release-server -n karpor 7443:7443
|
|
||||||
# Open https://localhost:7443
|
|
||||||
```
|
|
||||||
|
|
||||||
### Renovate
|
### Renovate
|
||||||
|
|
||||||
**Chart**: `renovate` (OCI: `ghcr.io/renovatebot/charts`)
|
**Chart**: `renovate` (OCI: `ghcr.io/renovatebot/charts`)
|
||||||
@@ -1552,23 +1516,7 @@ Forward to Application (localhost:3000)
|
|||||||
Application processes request
|
Application processes request
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Forwarded Headers
|
**See**: [Developer Guide - Enabling Authentication](DEVELOPER-GUIDE.md#enabling-authentication-for-applications) for usage examples.
|
||||||
|
|
||||||
After successful authentication, the sidecar injects user identity as HTTP headers before forwarding the request to the application container:
|
|
||||||
|
|
||||||
| Header | Description | Auth Modes |
|
|
||||||
|--------|-------------|------------|
|
|
||||||
| `X-Auth-User` | Username or display name | Token, OIDC, MCP |
|
|
||||||
| `X-Auth-Email` | User email address | OIDC |
|
|
||||||
| `X-Auth-Subject` | OIDC `sub` claim (stable user ID) | OIDC, MCP |
|
|
||||||
| `X-Auth-Groups` | Comma-separated group memberships | OIDC (if `groups` scope) |
|
|
||||||
| `X-Auth-Token` | The validated access token | All modes |
|
|
||||||
|
|
||||||
These headers are trustworthy because the auto-generated `NetworkPolicy` restricts pod ingress to the sidecar port only — external traffic cannot reach the application container directly, so headers cannot be spoofed.
|
|
||||||
|
|
||||||
Applications should read these headers to obtain authenticated user information (e.g. for display, authorisation decisions, or audit logging) instead of implementing their own authentication.
|
|
||||||
|
|
||||||
**See**: [Developer Guide - Accessing Authenticated User Information](DEVELOPER-GUIDE.md#accessing-authenticated-user-information) for code examples.
|
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
|||||||
@@ -1,42 +0,0 @@
|
|||||||
apiVersion: argoproj.io/v1alpha1
|
|
||||||
kind: Application
|
|
||||||
metadata:
|
|
||||||
name: karpor
|
|
||||||
namespace: argocd
|
|
||||||
annotations:
|
|
||||||
argocd.argoproj.io/sync-wave: "1"
|
|
||||||
labels:
|
|
||||||
app.kubernetes.io/name: karpor
|
|
||||||
app.kubernetes.io/part-of: developer-portal
|
|
||||||
app.kubernetes.io/managed-by: argocd
|
|
||||||
finalizers:
|
|
||||||
- resources-finalizer.argocd.argoproj.io
|
|
||||||
spec:
|
|
||||||
project: default
|
|
||||||
|
|
||||||
sources:
|
|
||||||
- repoURL: https://kusionstack.github.io/charts
|
|
||||||
chart: karpor
|
|
||||||
targetRevision: "0.7.6"
|
|
||||||
helm:
|
|
||||||
releaseName: karpor
|
|
||||||
valueFiles:
|
|
||||||
- $values/infra/values/base/karpor-values.yaml
|
|
||||||
|
|
||||||
- repoURL: ssh://git@git.forteapps.net:2222/Forte/launchpad.git
|
|
||||||
targetRevision: HEAD
|
|
||||||
ref: values
|
|
||||||
|
|
||||||
destination:
|
|
||||||
server: https://kubernetes.default.svc
|
|
||||||
namespace: karpor
|
|
||||||
|
|
||||||
syncPolicy:
|
|
||||||
automated:
|
|
||||||
prune: true
|
|
||||||
selfHeal: true
|
|
||||||
allowEmpty: false
|
|
||||||
syncOptions:
|
|
||||||
- CreateNamespace=true
|
|
||||||
- Validate=true
|
|
||||||
- ServerSideApply=true
|
|
||||||
@@ -22,4 +22,3 @@ resources:
|
|||||||
- tempo.yaml
|
- tempo.yaml
|
||||||
- grafana-dashboards.yaml
|
- grafana-dashboards.yaml
|
||||||
- network-policies-application.yaml
|
- network-policies-application.yaml
|
||||||
- karpor.yaml
|
|
||||||
|
|||||||
@@ -2,21 +2,12 @@ configs:
|
|||||||
secret:
|
secret:
|
||||||
createSecret: true
|
createSecret: true
|
||||||
argocdServerAdminPassword: "$2b$12$Tmb1jH7ADvwWoUoNPXXsfOf6JqEluqhq8mL06a8DGT2AP1GzbNsCm"
|
argocdServerAdminPassword: "$2b$12$Tmb1jH7ADvwWoUoNPXXsfOf6JqEluqhq8mL06a8DGT2AP1GzbNsCm"
|
||||||
ssh:
|
|
||||||
knownHosts: |
|
|
||||||
[git.forteapps.net]:2222 ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQDTwi40de8yTGUuRT0i/XGicQ672BLhYR6D/lDquJrp/tdrWoZhVVPy0wxSkWsq1V92iiAUuQnXagOGsLBGZT9uDLWKvEmNDnCfjzTMq3J1iA3vk2rQ8WBlCzhvmeCV/r0ufl6vsgfwxSRomLZeqa2UkLHx69gy2Njb1S2/aZK1Q53f466hCUfDULZrTn2Nn5Sj8cEbJ8EyvVN2YG9HYBxQdzKRPZEmS1vyzmn8YrYIkZseIRQElabzWGh86owuaaqnwJhTJj1j2sEUeIet04sGKJcnxx2UL4H90N66LKMldmMiuli+ve/CjJmMwDl0zGkjIniT3XR8CyEXYHli7B1hR8Z+dbK6DBgjz+28lFgMIRY70KkZJNsJcBNZLZ5fHwCI13a9U3Uhg3Pu/6s0zlosM4CrAQNQCRe95ZPtCpdFhlGrOl4m1rdSK2meL6rND0TBBuZbaFF6Py7TawLCAiO2KRaVqhu9OFVjwJ/nifgLzFGwWj+WcYmpuR+DwozrF/Hl7QYsz1x4GO1SONY07KbIFkUCHOMAh0AELY5YE4eGI4mtG6SecdPaAdLREGZYK4IcyP5i1QW9g0wmfRSsV9jy+r0ivBxixxh4yJiNpkg6NXak40gQtGIme9EJ+DxrRLruNsfDILWcdSuH/wvuorv56NpQFGB0FzB6LXMloSYptQ==
|
|
||||||
cm:
|
cm:
|
||||||
application.resourceTrackingMethod: annotation
|
application.resourceTrackingMethod: annotation
|
||||||
timeout.reconciliation: 60s
|
timeout.reconciliation: 60s
|
||||||
admin.enabled: "true"
|
admin.enabled: "true"
|
||||||
params:
|
params:
|
||||||
"server.insecure": true
|
"server.insecure": true
|
||||||
repoServer:
|
|
||||||
env:
|
|
||||||
# Disable git submodule checkout - submodules (e.g. shared-prompts)
|
|
||||||
# are not needed for K8s manifest generation
|
|
||||||
- name: ARGOCD_GIT_MODULES_ENABLED
|
|
||||||
value: "false"
|
|
||||||
server:
|
server:
|
||||||
ingress:
|
ingress:
|
||||||
enabled: false
|
enabled: false
|
||||||
|
|||||||
@@ -1,44 +0,0 @@
|
|||||||
# Karpor - Kubernetes Visualization & Intelligence Tool
|
|
||||||
# Helm chart: https://github.com/KusionStack/charts/tree/master/charts/karpor
|
|
||||||
|
|
||||||
# Let the ArgoCD Application manage the namespace
|
|
||||||
namespaceEnabled: false
|
|
||||||
|
|
||||||
server:
|
|
||||||
replicas: 1
|
|
||||||
port: 7443
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
cpu: 250m
|
|
||||||
memory: 256Mi
|
|
||||||
limits:
|
|
||||||
cpu: 500m
|
|
||||||
memory: 1Gi
|
|
||||||
|
|
||||||
syncer:
|
|
||||||
replicas: 1
|
|
||||||
port: 7443
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
cpu: 250m
|
|
||||||
memory: 256Mi
|
|
||||||
limits:
|
|
||||||
cpu: 500m
|
|
||||||
memory: 1Gi
|
|
||||||
|
|
||||||
elasticsearch:
|
|
||||||
replicas: 1
|
|
||||||
port: 9200
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
cpu: 500m
|
|
||||||
memory: 2Gi
|
|
||||||
limits:
|
|
||||||
cpu: "2"
|
|
||||||
memory: 4Gi
|
|
||||||
|
|
||||||
etcd:
|
|
||||||
replicas: 1
|
|
||||||
port: 2379
|
|
||||||
persistence:
|
|
||||||
size: 5Gi
|
|
||||||
Submodule shared-prompts deleted from c5bc55b3d7
Reference in New Issue
Block a user