- 
                Notifications
    You must be signed in to change notification settings 
- Fork 3
Setup (Manual)
        github-actions[bot] edited this page Jan 7, 2025 
        ·
        6 revisions
      
    While the Docker containers are generally easier to setup and use, manual setup of Tracker isn't terribly complex either. This gives you the most control over every aspect of the setup and lets you interact directly with the system without any layers of abstraction that some may find undesireable. You'll also be able to run Tracker on a traditional shared web host this way.
- A web server, such as Nginx or Apache
- PostgreSQL, MariaDB, or MySQL (8.0+) server as a database
- (recommended) Redis, Memcached, or another Laravel-compatible key/value store for caching data
- PHP 8.2+ with the following extensions:
- PDO + your database extension of choice
- openssl
- ctype
- filter
- hash
- mbstring
- session
- tokenizer
- ZIP
- GD
 
- Composer to install backend dependencies
- Node.js & NPM to install frontend dependencies
- Your event's instance of ConCat to allow volunteers and staff to authenticate with the system
- All users log in to the application using ConCat with OAuth.
- You will need Developer access to your event's ConCat instance to create the OAuth app.
Specifically, you will need the oauth:managepermission to set everything up. Alternatively, have someone else create an OAuth app in ConCat for you and have them provide you with the client ID and secret.
- The OAuth app will require the volunteer:readandregistration:readapplication permissions for OAuth Bearer tokens, which are used for generating the Volunteer Applications reports and retrieving badge details inside Tracker.
 
- Clone this repository in your web server's document root (or download a tarball and extract it to it).
- Run composer install --no-dev --classmap-authoritativeto download all production backend dependencies and optimize the autoloader automatically.
- Run npm installto download all frontend dependencies.
- Run npm run buildto bundle and optimize the frontend assets.
- Copy .env.exampleto.envand update the values appropriately.
- Run php artisan key:generateto generate an encryption key and automatically fill in theAPP_KEYvalue in.env. This key should be kept the same between all instances of Tracker connected to the same environment (production, QA, etc.) and should only be regenerated when absolutely necessary (compromise, improved algorithm). Regenerating or using a different key will result in any encrypted (not hashed!) values in the database or cache becoming unreadable.
- Run php artisan migrateto run all migrations on the database.
- Log in to the application in your web browser via the OAuth flow to make sure a user gets created for you.
- Run php artisan auth:set-roleto set your user's role to admin.
- Run php artisan telegram:set-commandsto send the list of bot commands to Telegram.
- Run php artisan telegram:set-webhookto inform Telegram of the bot's webhook URL.
- Add a cron entry to run php artisan schedule:runevery minute so that reward notifications can be triggered and ongoing shifts automatically stopped at the configured day boundary.- Example crontab entry: * * * * * cd /var/www/html && /usr/local/bin/php artisan schedule:run >> /dev/null 2>&1'
 
- Example crontab entry: 
- Run php artisan queue:workin a separate process (using supervisor or something similar) to process queue entries as they come in. You can have multiple of these running at once if the queue becomes backed up.
- To greatly improve boot performance of the application on each hit, run the following:
- 
php artisan config:cacheto cache the fully-resolved configuration to a file
- 
php artisan route:cacheto cache the routes to a file
- 
php artisan event:cacheto cache the auto-discovered event listeners to a file
- 
php artisan view:cacheto pre-compile and cache all of the Blade templates
 
- 
- Run php artisan downto put the application in maintenance mode.
- Pull or upload the current version of the code from this repository.
- Run composer install --no-dev --classmap-authoritativeto download any new production backend dependencies and optimize the autoloader automatically.
- Run npm installto download any new frontend dependencies.
- Run npm run buildto bundle and optimize the frontend assets.
- Run php artisan migrateto run any new migrations on the database.
- Run php artisan telegram:set-commandsto send the list of bot commands to Telegram.
- Run php artisan telegram:set-webhookto inform Telegram of the bot's webhook URL.
- Restart any queue workers you have running (php artisan queue:work) in separate processes to ensure they're using the latest code.
- To greatly improve boot performance of the application on each hit, run the following:
- 
php artisan config:cacheto cache the fully-resolved configuration to a file
- 
php artisan route:cacheto cache the routes to a file
- 
php artisan event:cacheto cache the auto-discovered event listeners to a file
- 
php artisan view:cacheto pre-compile and cache all of the Blade templates
 
- 
- Run php artisan upto pull the application out of maintenance mode.