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
|
||||
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