Compare commits
5 Commits
3c922c861b
...
23c1d33adb
| Author | SHA1 | Date |
|---|---|---|
|
|
23c1d33adb | |
|
|
a8220921cb | |
|
|
ba85b076ad | |
|
|
f938c63cf6 | |
|
|
bf96452f1b |
|
|
@ -0,0 +1,41 @@
|
||||||
|
# Application Configuration
|
||||||
|
NODE_ENV=development
|
||||||
|
PORT=3000
|
||||||
|
LOG_LEVEL=debug
|
||||||
|
|
||||||
|
# CORS Configuration
|
||||||
|
CORS_ORIGIN=*
|
||||||
|
|
||||||
|
# Database Configuration
|
||||||
|
DB_HOST=postgres
|
||||||
|
DB_PORT=5432
|
||||||
|
DB_NAME=banatie_db
|
||||||
|
DB_USER=banatie_user
|
||||||
|
DB_PASSWORD=development_password
|
||||||
|
|
||||||
|
# MinIO Storage Configuration
|
||||||
|
STORAGE_TYPE=minio
|
||||||
|
MINIO_ENDPOINT=minio:9000
|
||||||
|
MINIO_ACCESS_KEY=minioadmin
|
||||||
|
MINIO_SECRET_KEY=minioadmin
|
||||||
|
MINIO_USE_SSL=false
|
||||||
|
MINIO_BUCKET_PREFIX=banatie
|
||||||
|
MINIO_PUBLIC_URL=http://localhost:9000
|
||||||
|
|
||||||
|
# AI Service Configuration (using the existing API key from .env)
|
||||||
|
GEMINI_API_KEY=AIzaSyBaOt9JMPGKA3811FL-ssf1n5Hh9Jauly8
|
||||||
|
|
||||||
|
# File Upload Configuration
|
||||||
|
MAX_FILE_SIZE=5242880
|
||||||
|
MAX_FILES=3
|
||||||
|
|
||||||
|
# Multi-tenancy Configuration
|
||||||
|
DEFAULT_ORG_ID=demo
|
||||||
|
DEFAULT_USER_ID=guest
|
||||||
|
|
||||||
|
# Directory Configuration (for Docker containers)
|
||||||
|
RESULTS_DIR=/app/results
|
||||||
|
UPLOADS_DIR=/app/uploads/temp
|
||||||
|
|
||||||
|
# Logging Configuration
|
||||||
|
LOG_LEVEL=info
|
||||||
|
|
@ -77,4 +77,13 @@ uploads/
|
||||||
|
|
||||||
# Temporary files
|
# Temporary files
|
||||||
temp/
|
temp/
|
||||||
tmp/
|
tmp/
|
||||||
|
|
||||||
|
# Docker data directories
|
||||||
|
data/
|
||||||
|
.env.docker
|
||||||
|
.env.production
|
||||||
|
|
||||||
|
# Docker volumes (persistent data)
|
||||||
|
postgres-data/
|
||||||
|
minio-data/
|
||||||
|
|
@ -0,0 +1,129 @@
|
||||||
|
version: '3.8'
|
||||||
|
|
||||||
|
services:
|
||||||
|
app:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
target: development
|
||||||
|
container_name: banatie-app-dev
|
||||||
|
ports:
|
||||||
|
- "3000:3000"
|
||||||
|
volumes:
|
||||||
|
- ./src:/app/src # Hot reload for development
|
||||||
|
- ./logs:/app/logs # Persistent logs
|
||||||
|
networks:
|
||||||
|
- banatie-dev
|
||||||
|
depends_on:
|
||||||
|
postgres:
|
||||||
|
condition: service_healthy
|
||||||
|
minio:
|
||||||
|
condition: service_healthy
|
||||||
|
environment:
|
||||||
|
- NODE_ENV=development
|
||||||
|
env_file:
|
||||||
|
- .env.docker
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
postgres:
|
||||||
|
image: postgres:15-alpine
|
||||||
|
container_name: banatie-postgres-dev
|
||||||
|
ports:
|
||||||
|
- "5434:5432" # Avoid conflicts with other PostgreSQL instances
|
||||||
|
volumes:
|
||||||
|
- ./data/postgres:/var/lib/postgresql/data
|
||||||
|
- ./scripts/init-db.sql:/docker-entrypoint-initdb.d/01-init.sql
|
||||||
|
networks:
|
||||||
|
- banatie-dev
|
||||||
|
environment:
|
||||||
|
POSTGRES_DB: banatie_db
|
||||||
|
POSTGRES_USER: banatie_user
|
||||||
|
POSTGRES_PASSWORD: development_password
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "pg_isready -U banatie_user -d banatie_db"]
|
||||||
|
interval: 30s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 3
|
||||||
|
start_period: 40s
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
minio:
|
||||||
|
image: minio/minio:latest
|
||||||
|
container_name: banatie-minio-dev
|
||||||
|
ports:
|
||||||
|
- "9000:9000" # S3 API
|
||||||
|
- "9001:9001" # Web Console
|
||||||
|
volumes:
|
||||||
|
- ./data/minio:/data
|
||||||
|
networks:
|
||||||
|
- banatie-dev
|
||||||
|
environment:
|
||||||
|
MINIO_ROOT_USER: minioadmin
|
||||||
|
MINIO_ROOT_PASSWORD: minioadmin
|
||||||
|
command: server /data --console-address ":9001"
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
|
||||||
|
interval: 30s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 3
|
||||||
|
start_period: 40s
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
minio-init:
|
||||||
|
image: minio/mc:latest
|
||||||
|
container_name: banatie-minio-init
|
||||||
|
networks:
|
||||||
|
- banatie-dev
|
||||||
|
depends_on:
|
||||||
|
minio:
|
||||||
|
condition: service_healthy
|
||||||
|
entrypoint: >
|
||||||
|
/bin/sh -c "
|
||||||
|
echo 'Setting up MinIO alias...';
|
||||||
|
mc alias set minio http://minio:9000 minioadmin minioadmin;
|
||||||
|
|
||||||
|
echo 'Creating demo bucket...';
|
||||||
|
mc mb --ignore-existing minio/banatie-demo;
|
||||||
|
|
||||||
|
echo 'Setting up public read policy for generated images...';
|
||||||
|
mc anonymous set download minio/banatie-demo/users/guest/generated;
|
||||||
|
|
||||||
|
echo 'Creating banatie service user...';
|
||||||
|
mc admin user add minio banatie-user banatie-password;
|
||||||
|
|
||||||
|
echo 'Attaching readwrite policy to banatie user...';
|
||||||
|
mc admin policy attach minio readwrite --user=banatie-user;
|
||||||
|
|
||||||
|
echo 'Creating lifecycle policy for temp files (7 days retention)...';
|
||||||
|
cat > /tmp/lifecycle.json << EOF
|
||||||
|
{
|
||||||
|
\"Rules\": [
|
||||||
|
{
|
||||||
|
\"ID\": \"temp-files-cleanup\",
|
||||||
|
\"Status\": \"Enabled\",
|
||||||
|
\"Filter\": {
|
||||||
|
\"Prefix\": \"users/\"
|
||||||
|
},
|
||||||
|
\"Expiration\": {
|
||||||
|
\"Days\": 7
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
mc ilm import minio/banatie-demo < /tmp/lifecycle.json;
|
||||||
|
|
||||||
|
echo 'MinIO initialization completed successfully!';
|
||||||
|
exit 0;
|
||||||
|
"
|
||||||
|
restart: "no"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
banatie-dev:
|
||||||
|
driver: bridge
|
||||||
|
name: banatie-dev-network
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
postgres-data:
|
||||||
|
driver: local
|
||||||
|
minio-data:
|
||||||
|
driver: local
|
||||||
|
|
@ -0,0 +1,103 @@
|
||||||
|
-- Banatie Database Initialization Script
|
||||||
|
-- This script creates the database schema for the Banatie image generation service
|
||||||
|
|
||||||
|
-- Enable UUID extension for generating UUIDs
|
||||||
|
CREATE EXTENSION IF NOT EXISTS "uuid-ossp";
|
||||||
|
|
||||||
|
-- Organizations table - for multi-tenant support
|
||||||
|
CREATE TABLE organizations (
|
||||||
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
|
||||||
|
name VARCHAR(255) NOT NULL,
|
||||||
|
slug VARCHAR(100) UNIQUE NOT NULL,
|
||||||
|
settings JSONB DEFAULT '{}',
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
||||||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
||||||
|
);
|
||||||
|
|
||||||
|
-- Users table - users within organizations
|
||||||
|
CREATE TABLE users (
|
||||||
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
|
||||||
|
organization_id UUID REFERENCES organizations(id) ON DELETE CASCADE,
|
||||||
|
username VARCHAR(100) NOT NULL,
|
||||||
|
email VARCHAR(255),
|
||||||
|
role VARCHAR(50) DEFAULT 'user',
|
||||||
|
settings JSONB DEFAULT '{}',
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
||||||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
||||||
|
UNIQUE(organization_id, username)
|
||||||
|
);
|
||||||
|
|
||||||
|
-- Images table - metadata for generated and uploaded images
|
||||||
|
CREATE TABLE images (
|
||||||
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
|
||||||
|
user_id UUID REFERENCES users(id) ON DELETE CASCADE,
|
||||||
|
filename VARCHAR(255) NOT NULL,
|
||||||
|
file_path VARCHAR(500), -- Legacy: local file path (for backward compatibility)
|
||||||
|
minio_key VARCHAR(500), -- MinIO object key
|
||||||
|
url VARCHAR(1000), -- Public or presigned URL to access the image
|
||||||
|
original_prompt TEXT,
|
||||||
|
enhanced_prompt TEXT,
|
||||||
|
model_used VARCHAR(100),
|
||||||
|
file_size BIGINT,
|
||||||
|
content_type VARCHAR(100),
|
||||||
|
category VARCHAR(50) DEFAULT 'generated', -- 'generated', 'references', 'temp'
|
||||||
|
metadata JSONB DEFAULT '{}',
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
|
||||||
|
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
||||||
|
);
|
||||||
|
|
||||||
|
-- Sessions table - for tracking user upload sessions
|
||||||
|
CREATE TABLE upload_sessions (
|
||||||
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
|
||||||
|
user_id UUID REFERENCES users(id) ON DELETE CASCADE,
|
||||||
|
session_data JSONB NOT NULL,
|
||||||
|
expires_at TIMESTAMP WITH TIME ZONE,
|
||||||
|
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
|
||||||
|
);
|
||||||
|
|
||||||
|
-- Create indexes for better query performance
|
||||||
|
CREATE INDEX idx_users_org_id ON users(organization_id);
|
||||||
|
CREATE INDEX idx_users_username ON users(username);
|
||||||
|
CREATE INDEX idx_images_user_id ON images(user_id);
|
||||||
|
CREATE INDEX idx_images_created_at ON images(created_at);
|
||||||
|
CREATE INDEX idx_images_category ON images(category);
|
||||||
|
CREATE INDEX idx_images_minio_key ON images(minio_key);
|
||||||
|
CREATE INDEX idx_upload_sessions_user_id ON upload_sessions(user_id);
|
||||||
|
CREATE INDEX idx_upload_sessions_expires_at ON upload_sessions(expires_at);
|
||||||
|
|
||||||
|
-- Insert demo organization and user for development/testing
|
||||||
|
INSERT INTO organizations (id, name, slug, settings) VALUES
|
||||||
|
('00000000-0000-0000-0000-000000000001', 'Demo Organization', 'demo', '{"description": "Default demo organization for testing"}');
|
||||||
|
|
||||||
|
INSERT INTO users (id, organization_id, username, email, role, settings) VALUES
|
||||||
|
('00000000-0000-0000-0000-000000000001', '00000000-0000-0000-0000-000000000001', 'guest', 'guest@demo.banatie.app', 'user', '{"description": "Default guest user for testing"}');
|
||||||
|
|
||||||
|
-- Create a function to update updated_at timestamp
|
||||||
|
CREATE OR REPLACE FUNCTION update_updated_at_column()
|
||||||
|
RETURNS TRIGGER AS $$
|
||||||
|
BEGIN
|
||||||
|
NEW.updated_at = NOW();
|
||||||
|
RETURN NEW;
|
||||||
|
END;
|
||||||
|
$$ language 'plpgsql';
|
||||||
|
|
||||||
|
-- Create triggers to automatically update updated_at
|
||||||
|
CREATE TRIGGER update_organizations_updated_at
|
||||||
|
BEFORE UPDATE ON organizations
|
||||||
|
FOR EACH ROW EXECUTE FUNCTION update_updated_at_column();
|
||||||
|
|
||||||
|
CREATE TRIGGER update_users_updated_at
|
||||||
|
BEFORE UPDATE ON users
|
||||||
|
FOR EACH ROW EXECUTE FUNCTION update_updated_at_column();
|
||||||
|
|
||||||
|
CREATE TRIGGER update_images_updated_at
|
||||||
|
BEFORE UPDATE ON images
|
||||||
|
FOR EACH ROW EXECUTE FUNCTION update_updated_at_column();
|
||||||
|
|
||||||
|
-- Display initialization completion message
|
||||||
|
DO $$
|
||||||
|
BEGIN
|
||||||
|
RAISE NOTICE 'Banatie database initialization completed successfully!';
|
||||||
|
RAISE NOTICE 'Created tables: organizations, users, images, upload_sessions';
|
||||||
|
RAISE NOTICE 'Created demo organization (id: 00000000-0000-0000-0000-000000000001) with guest user';
|
||||||
|
END $$;
|
||||||
Loading…
Reference in New Issue