Compare commits

...

5 Commits

Author SHA1 Message Date
Oleg Proskurin 23c1d33adb fix: update port 2025-09-27 00:40:29 +07:00
Oleg Proskurin a8220921cb chore: upate git ignore 2025-09-27 00:34:05 +07:00
Oleg Proskurin ba85b076ad chore: add init script 2025-09-27 00:33:46 +07:00
Oleg Proskurin f938c63cf6 chore: env vars 2025-09-27 00:33:12 +07:00
Oleg Proskurin bf96452f1b feat: setup docker compose 2025-09-27 00:32:51 +07:00
4 changed files with 283 additions and 1 deletions

41
.env.docker Normal file
View File

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

9
.gitignore vendored
View File

@ -78,3 +78,12 @@ 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/

129
docker-compose.yml Normal file
View File

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

103
scripts/init-db.sql Normal file
View File

@ -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 $$;