refactor: architecture cleanup — OIDC dedup, PKCE, K8s hardening
- Extract OidcProviderHelper for shared discovery + JWK source construction - Add SystemRole.normalizeScope() to centralize role normalization - Merge duplicate claim extraction in OidcTokenExchanger - Add PKCE (S256) to OIDC authorization flow (frontend + backend) - Add SecurityContext (runAsNonRoot) to all K8s deployments - Fix postgres probe to use $POSTGRES_USER instead of hardcoded username - Remove default credentials from Dockerfile - Extract sanitize_branch() to shared .gitea/sanitize-branch.sh - Fix sidebar to use /exchanges/ paths directly, remove legacy redirects - Centralize basePath computation in router.tsx via config module Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -58,7 +58,7 @@ export function writeCollapsed(key: string, value: boolean): void {
|
||||
|
||||
/**
|
||||
* Apps tree — one node per app, routes as children.
|
||||
* Paths: /apps/{appId}, /apps/{appId}/{routeId}
|
||||
* Paths: /exchanges/{appId}, /exchanges/{appId}/{routeId}
|
||||
*/
|
||||
export function buildAppTreeNodes(
|
||||
apps: SidebarApp[],
|
||||
@@ -72,7 +72,7 @@ export function buildAppTreeNodes(
|
||||
label: app.name,
|
||||
icon: statusDot(app.health),
|
||||
badge: formatCount(app.exchangeCount),
|
||||
path: `/apps/${app.id}`,
|
||||
path: `/exchanges/${app.id}`,
|
||||
starrable: true,
|
||||
starKey: `app:${app.id}`,
|
||||
children: app.routes.map((r) => ({
|
||||
|
||||
Reference in New Issue
Block a user