Implement backend API and database services in Docker setup

- Added a new `api` service for the NestJS backend, including health checks and dependencies on PostgreSQL, Redis, and MinIO.
- Introduced PostgreSQL and Redis services with health checks and configurations for data persistence.
- Added MinIO for S3-compatible object storage and a one-shot service to initialize required buckets.
- Updated the Nginx configuration to proxy requests to the new backend API and MinIO storage.
- Enhanced the Dockerfile to support the new API environment variables and configurations.
- Updated the `package.json` and `package-lock.json` to include new dependencies for QR code generation and other utilities.

Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
Dorian
2026-02-12 20:14:39 +00:00
parent f19fd6feef
commit cdd24a5def
478 changed files with 55355 additions and 529 deletions

View File

@@ -1,5 +1,5 @@
import { createRouter, createWebHistory } from 'vue-router'
import { setupGuards, authGuard } from './guards'
import { setupGuards, authGuard, filmmakerGuard } from './guards'
import Browse from '../views/Browse.vue'
const router = createRouter({
@@ -23,7 +23,37 @@ const router = createRouter({
component: () => import('../views/Profile.vue'),
beforeEnter: authGuard,
meta: { requiresAuth: true }
}
},
// ── Creator / Filmmaker Routes ────────────────────────────────────────────
{
path: '/backstage',
name: 'backstage',
component: () => import('../views/backstage/Backstage.vue'),
beforeEnter: filmmakerGuard,
meta: { requiresAuth: true, requiresFilmmaker: true }
},
{
path: '/backstage/project/:id',
name: 'project-editor',
component: () => import('../views/backstage/ProjectEditor.vue'),
beforeEnter: filmmakerGuard,
meta: { requiresAuth: true, requiresFilmmaker: true }
},
{
path: '/backstage/analytics',
name: 'analytics',
component: () => import('../views/backstage/Analytics.vue'),
beforeEnter: filmmakerGuard,
meta: { requiresAuth: true, requiresFilmmaker: true }
},
{
path: '/backstage/settings',
name: 'filmmaker-settings',
component: () => import('../views/backstage/Settings.vue'),
beforeEnter: filmmakerGuard,
meta: { requiresAuth: true, requiresFilmmaker: true }
},
]
})