Integrate frontend UI into backend container and update Dockerfile to multi-stage build
This commit is contained in:
38
Dockerfile
38
Dockerfile
@@ -1,33 +1,27 @@
|
||||
# Step 1: Build Phase | مرحلة البناء
|
||||
FROM node:20-alpine AS builder
|
||||
|
||||
WORKDIR /usr/src/app
|
||||
|
||||
# Copy package files | نسخ ملفات الحزم
|
||||
COPY package*.json ./
|
||||
|
||||
# Install dependencies | تثبيت الاعتماديات
|
||||
# Step 1: Build Frontend | مرحلة بناء الواجهة
|
||||
FROM node:20-alpine AS frontend-builder
|
||||
WORKDIR /usr/src/app/frontend
|
||||
COPY frontend/package*.json ./
|
||||
RUN npm install
|
||||
|
||||
# Copy source code | نسخ كود المصدر
|
||||
COPY . .
|
||||
|
||||
# Build the app | بناء التطبيق
|
||||
COPY frontend/ ./
|
||||
RUN npm run build
|
||||
|
||||
# Step 2: Production Phase | مرحلة الإنتاج
|
||||
FROM node:20-alpine
|
||||
|
||||
# Step 2: Build Backend | مرحلة بناء الخلفية
|
||||
FROM node:20-alpine AS builder
|
||||
WORKDIR /usr/src/app
|
||||
|
||||
# Copy package files | نسخ ملفات الحزم
|
||||
COPY package*.json ./
|
||||
RUN npm install
|
||||
COPY . .
|
||||
RUN npm run build
|
||||
|
||||
# Install only production dependencies | تثبيت اعتماديات الإنتاج فقط
|
||||
# Step 3: Production Phase | مرحلة الإنتاج
|
||||
FROM node:20-alpine
|
||||
WORKDIR /usr/src/app
|
||||
COPY package*.json ./
|
||||
RUN npm install --only=production
|
||||
|
||||
# Copy built files from builder | نسخ الملفات المبنية من مرحلة البناء
|
||||
COPY --from=builder /usr/src/app/dist ./dist
|
||||
# Copy frontend build to backend public folder | نسخ واجهة المستخدم إلى الملفات العامة
|
||||
COPY --from=frontend-builder /usr/src/app/frontend/dist ./public
|
||||
|
||||
# Expose port | فتح المنفذ
|
||||
EXPOSE 3660
|
||||
|
||||
@@ -32,7 +32,7 @@ services:
|
||||
image: redis:alpine
|
||||
container_name: ads-analytics-redis
|
||||
ports:
|
||||
- "6379:6379"
|
||||
- "6380:6379"
|
||||
restart: always
|
||||
|
||||
volumes:
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
import { auth } from './auth.js';
|
||||
|
||||
export const BASE_URL = 'http://localhost:3001/api';
|
||||
export const BASE_URL = '/api';
|
||||
|
||||
/**
|
||||
* API Wrapper for SaaS Meta Backend
|
||||
|
||||
@@ -4,15 +4,14 @@ import { ApiOperation, ApiResponse, ApiTags } from '@nestjs/swagger';
|
||||
@ApiTags('root')
|
||||
@Controller()
|
||||
export class AppController {
|
||||
@Get()
|
||||
@ApiOperation({ summary: 'Welcome to the API | الترحيب بالـ API' })
|
||||
@Get('status')
|
||||
@ApiOperation({ summary: 'API Status | حالة الـ API' })
|
||||
@ApiResponse({ status: 200, description: 'API is running | الـ API يعمل بنجاح' })
|
||||
getHello() {
|
||||
return {
|
||||
message: 'Welcome to Ads Analytics SaaS API',
|
||||
version: '1.0',
|
||||
docs: '/api/docs',
|
||||
message: 'Ads Analytics SaaS API',
|
||||
status: 'active',
|
||||
docs: '/api/docs',
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
@@ -23,9 +23,7 @@ async function bootstrap() {
|
||||
|
||||
// Serve Static Assets | تقديم الملفات الثابتة
|
||||
// This allows us to share ad images for analysis
|
||||
app.useStaticAssets(join(__dirname, '..', 'public'), {
|
||||
prefix: '/api',
|
||||
});
|
||||
app.useStaticAssets(join(__dirname, '..', 'public'));
|
||||
|
||||
// Get ConfigService for port | الحصول على خدمة الإعدادات للمنفذ
|
||||
const configService = app.get(ConfigService);
|
||||
|
||||
Reference in New Issue
Block a user