d
2025-10-12 23:40:33,603 - apscheduler.scheduler - INFO - Scheduler started
2025-10-12 23:40:33,605 - polling_service - INFO - Polling scheduler started
2025-10-12 23:40:33,605 - apscheduler.scheduler - INFO - Added job "Check and poll sources" to job store "default"
2025-10-12 23:40:33,606 - polling_service - INFO - Poll checker job scheduled
2025-10-12 23:40:33,610 - filter_pipeline.config - INFO - Loaded filter config from filter_config.json
2025-10-12 23:40:33,610 - filter_pipeline.config - INFO - Loaded 5 filtersets from filtersets.json
Traceback (most recent call last):
File "<frozen runpy>", line 198, in _run_module_as_main
File "<frozen runpy>", line 88, in _run_code
File "/usr/local/lib/python3.12/site-packages/flask/__main__.py", line 3, in <module>
main()
File "/usr/local/lib/python3.12/site-packages/flask/cli.py", line 1131, in main
cli.main()
File "/usr/local/lib/python3.12/site-packages/click/core.py", line 1383, in main
rv = self.invoke(ctx)
^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/click/core.py", line 1850, in invoke
return _process_result(sub_ctx.command.invoke(sub_ctx))
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/click/core.py", line 1246, in invoke
return ctx.invoke(self.callback, **ctx.params)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/click/core.py", line 814, in invoke
return callback(*args, **kwargs)
^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/click/decorators.py", line 93, in new_func
return ctx.invoke(f, obj, *args, **kwargs)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/click/core.py", line 814, in invoke
return callback(*args, **kwargs)
^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/flask/cli.py", line 979, in run_command
raise e from None
File "/usr/local/lib/python3.12/site-packages/flask/cli.py", line 963, in run_command
app: WSGIApplication = info.load_app() # pyright: ignore
^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/flask/cli.py", line 349, in load_app
app = locate_app(import_name, name)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/usr/local/lib/python3.12/site-packages/flask/cli.py", line 245, in locate_app
__import__(module_name)
File "/app/app.py", line 91, in <module>
✓ Database tables created
filter_engine = FilterEngine.get_instance()
^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/app/filter_pipeline/engine.py", line 55, in get_instance
cls._instance = cls()
^^^^^
File "/app/filter_pipeline/engine.py", line 43, in __init__
self.cache = FilterCache(self.config.get_cache_dir())
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/app/filter_pipeline/cache.py", line 28, in __init__
self.cache_dir.mkdir(parents=True, exist_ok=True)
File "/usr/local/lib/python3.12/pathlib.py", line 1311, in mkdir
os.mkdir(self, mode)
PermissionError: [Errno 13] Permission denied: 'data/filter_cach
76 lines
1.9 KiB
YAML
76 lines
1.9 KiB
YAML
version: '3.8'
|
|
|
|
services:
|
|
postgres:
|
|
image: postgres:15
|
|
container_name: balanceboard_postgres
|
|
environment:
|
|
POSTGRES_DB: balanceboard
|
|
POSTGRES_USER: balanceboard
|
|
POSTGRES_PASSWORD: balanceboard123
|
|
ports:
|
|
- "5433:5432"
|
|
volumes:
|
|
- postgres_data:/var/lib/postgresql/data
|
|
restart: unless-stopped
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U balanceboard -d balanceboard"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
networks:
|
|
- balanceboard-network
|
|
|
|
app:
|
|
build:
|
|
context: .
|
|
dockerfile: Dockerfile
|
|
container_name: balanceboard_app
|
|
ports:
|
|
- "5021:5021"
|
|
environment:
|
|
# Database configuration
|
|
POSTGRES_HOST: postgres
|
|
POSTGRES_PORT: 5432
|
|
POSTGRES_USER: balanceboard
|
|
POSTGRES_PASSWORD: balanceboard123
|
|
POSTGRES_DB: balanceboard
|
|
|
|
# Flask configuration
|
|
FLASK_ENV: production
|
|
DEBUG: "False"
|
|
SECRET_KEY: ${SECRET_KEY:-change-this-secret-key-in-production}
|
|
ALLOW_ANONYMOUS_ACCESS: ${ALLOW_ANONYMOUS_ACCESS:-true}
|
|
|
|
# Auth0 configuration (optional)
|
|
AUTH0_DOMAIN: ${AUTH0_DOMAIN:-}
|
|
AUTH0_CLIENT_ID: ${AUTH0_CLIENT_ID:-}
|
|
AUTH0_CLIENT_SECRET: ${AUTH0_CLIENT_SECRET:-}
|
|
AUTH0_AUDIENCE: ${AUTH0_AUDIENCE:-}
|
|
volumes:
|
|
# Application-managed data (using a named volume)
|
|
- app_data:/app/data
|
|
# User-editable content (using bind mounts)
|
|
- ./static:/app/static
|
|
- ./backups:/app/backups
|
|
- ./active_html:/app/active_html
|
|
depends_on:
|
|
postgres:
|
|
condition: service_healthy
|
|
restart: unless-stopped
|
|
networks:
|
|
- balanceboard-network
|
|
healthcheck:
|
|
test: ["CMD", "curl", "-f", "http://localhost:5021/"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
start_period: 40s
|
|
|
|
networks:
|
|
balanceboard-network:
|
|
driver: bridge
|
|
|
|
volumes:
|
|
postgres_data:
|
|
app_data: # <-- New named volume declared here |