File size: 1,620 Bytes
952467c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
"""
Configuration settings for the video translator application.
"""
import os
from pathlib import Path
from dotenv import load_dotenv

# Load environment variables from .env file
load_dotenv()

# Base directory
BASE_DIR = Path(__file__).resolve().parent

# API Keys
ASSEMBLYAI_API_KEY = os.getenv("ASSEMBLYAI_API_KEY")
if not ASSEMBLYAI_API_KEY:
    raise ValueError("ASSEMBLYAI_API_KEY is not set in environment variables or .env file")

# Output directory
OUTPUT_DIR = Path(os.getenv("OUTPUT_DIR", BASE_DIR / "outputs"))
OUTPUT_DIR.mkdir(exist_ok=True)

# Temp directory for processing
TEMP_DIR = OUTPUT_DIR / "temp"
TEMP_DIR.mkdir(exist_ok=True)

# Debug mode
DEBUG = os.getenv("DEBUG", "False").lower() == "true"

# Supported languages
LANGUAGES = {
    "English": "en",
    "Spanish": "es", 
    "French": "fr",
    "German": "de",
    "Japanese": "ja",
    "Hindi": "hi",
    "Chinese (Simplified)": "zh-CN",
    "Russian": "ru",
    "Italian": "it",
    "Portuguese": "pt",
    "Arabic": "ar",
    "Korean": "ko"
}

# TTS voice mapping for different languages
TTS_VOICES = {
    "en": "en-US",
    "es": "es-ES",
    "fr": "fr-FR",
    "de": "de-DE",
    "ja": "ja-JP",
    "hi": "hi-IN",
    "zh-CN": "zh-CN",
    "ru": "ru-RU",
    "it": "it-IT",
    "pt": "pt-BR",
    "ar": "ar",
    "ko": "ko"
}

# FFmpeg configurations
FFMPEG_AUDIO_PARAMS = {
    "format": "wav",
    "codec": "pcm_s16le",
    "sample_rate": 44100,
    "channels": 2
}

# Application settings
MAX_VIDEO_DURATION = 600  # in seconds (10 minutes)
MAX_UPLOAD_SIZE = 500 * 1024 * 1024  # 500 MB
SUBTITLE_FONT_SIZE = 24
MAX_RETRY_ATTEMPTS = 3