Magnetico Web is a simple web search interface for magneticod database.
Application setup is quite simple:
git clone https://[email protected]/skobkin/magnetico-web.git
cd magnetico-web
composer create-project skobkin/magnetico-web -s dev
cd magnetico-web
Set up appropriate write permissions for var/cache
and var/logs
.
# In developer environment:
composer install
# In production environment
# You should tell the app that it's running in the production environment.
# You can use environment variables or set it in the .env.local file like that:
echo 'APP_ENV=prod' > ./.env.local
composer install --no-dev --optimize-autoloader
After dependencies installation you may need to create .env.local
file (see .env
for reference)
or set appropriate environment variables
for production usage.
Check Symfony documentation for more details about .env
files.
You can also check this post about .env
changes in Symfony if you're updating from an
old version of the project.
See Symfony database configuration documentation for more details.
You must set environment variables for both databases: magneticod's and magnetico-web's PostgreSQL.
Make sure that magnetico-web
and magneticod
are using the same schema for storing torrents in the PostgreSQL database.
Check magneticod
docs here
and make sure that schema
parameter either not set or set to magneticod
(default value).
magnetico-web
uses magneticod
schema to search for torrents so if you set magenticod
to use another schema search will not work.
# Only for 'default' EntityManager (Application entities)
php bin/console doc:mig:mig --em=default
php bin/console assets:install public --symlink
# see --help for more info
# If you don't specify the password it'll be requested from you in the command line
php bin/console user:add <your_username> <your_email> [your_password] [--invites=10]
# see --help for more info
php bin/console invite:add <username> <number-of-invites>
echo 'APP_ENV=dev > .env.local'
Running using RoadRunner instead of PHP-FPM
# First time only:
./vendor/bin/rr get --location bin/
# Running the server:
./bin/rr serve
# Running the server in dev mode (watching enabled)
bin/rr serve -c .rr.dev.yaml
If you're running the app in RoadRunner and experiencing problems with proper URL generation (HTTP instead of HTTPS), check beginning of the section about running in Docker below.
When running in Docker DO NOT FORGET to use Nginx or other reverse-proxy server and properly set TRUSTED_PROXIES
environment variable. You can read more about it here.
version: '3.7'
services:
magnetico-web:
image: skobkin/magnetico-web
container_name: magnetico-web
hostname: magnetico-web
extra_hosts:
- 'host.docker.internal:host-gateway'
ports:
- "127.0.0.1:${EXT_HTTP_PORT:-8080}:8080/tcp"
restart: unless-stopped
user: "$UID"
volumes:
- "${LOG_PATH:-./var/log}:/app/var/log"
env_file: .env
logging:
driver: "json-file"
options:
max-size: "${LOG_MAX_SIZE:-5m}"
max-file: "${LOG_MAX_FILE:-5}"
Use dotenv file to configure this stack:
# Example with some useful parameters
APP_SECRET=qwerty
APP_DATABASE_URL=postgres://magnetico-web:[email protected]:5432/magnetico-web?application_name=magnetico_web
MAGNETICOD_DATABASE_URL=postgres://magneticod:[email protected]:5432/magneticod?application_name=magnetico_web
REDIS_DSN=redis://host.docker.internal:6379/0
# BE CAREFUL WITH 'REMOTE_ADDR'. Use ONLY with trusted reverse-proxy
TRUSTED_PROXIES=127.0.0.1,REMOTE_ADDR
###> sentry/sentry-symfony ###
SENTRY_DSN=https://[email protected]/123456
###< sentry/sentry-symfony ###
###> symfony/mailer ###
MAILER_DSN=smtp://[email protected]:[email protected]:587
MAILER_FROM=[email protected]
###< symfony/mailer ###
###> excelwebzone/recaptcha-bundle ###
EWZ_RECAPTCHA_SITE_KEY=key
EWZ_RECAPTCHA_SECRET=secret
###< excelwebzone/recaptcha-bundle ###