This is a Laravel-powered API source for tracking COVID-19 cases in a region. It is currently used by the COVID-19 Tracker Canada project.
See it in action at https://api.covid19tracker.ca
A hosting environment configured for Laravel 8.x should have no issues. Please see Laravel's Server Requirements for up-to-date information.
Data is stored in a MySQL database. You will need to create one for this project to use.
A few routes use caching and has been tested with file
and redis
cache drivers.
Laravel Homestead is also supported out of box for local development.
Important In order to use the CSV Seeders, you must have PHP 7.4 installed. Most deployments typically install version 7.2.
git clone git@github.com:andrewthong/covid19tracker-api.git
cd covid19tracker-api
composer install
cp .env.example .env
Update the .env with database credentials.
php artisan key:generate
php artisan migrate
Required if you plan to run the C19T-Manager companion as well.
php artisan passport:install
From the resulting output, copy personal access to PERSONAL_CLIENT_SECRET
and password grant to PASSWORD_CLIENT_SECRET
in your .env file.
Update MANAGE_URL
in your .env file with the URL where C19T-Manager is deployed.
Then create your first admin user:
php artisan tinker
$user = new \App\User
$user->name = 'Fname';
$user->email = 'fnamelname@example.net';
$user->password = Hash::make('some_password_123');
$user->assignRole('admin');
$user->save();
Roles are currently simplified to admin and editor. This project uses laravel-permission to manage roles.
You can now launch. Instructions vary depending on your setup (LEMP server, Homestead...). When ready, browse to the URL as configured and you should see the API documentation.
The database seeders are specific to Canada, but can be tweaked for another region as needed.
Running this seed inserts all 13 provinces and territories of Canada.
php artisan db:seed --class=ProvinceSeeder
Running this seed inserts health regions in Canada.
php artisan db:seed --class=HealthRegionsSeeder
This is a sample of report data. Be sure to adjust the province to match the province data accordingly.
php artisan db:seed --class=ReportSeeder
These do not have a sample CSV, but the seeder classes are available.
php artisan db:seed --class=CaseSeeder
php artisan db:seed --class=FatalitySeeder
Used to determine province from rapid test submissions.
php artisan db:seed --class=PostalDistrictSeeder
C19T-Manager is a companion app to facilitate reporting.
The URL where C19T-Manager is hosted will need to be whitelisted for CORS. Update MANAGE_URL
in .env
accordingly. Use a comma for multiple URLs.
MANAGE_URL=http://localhost:1234,http://localhost:5678
Currently only rapid tests are supported.
All open submissions can use reCAPTCHA to minimize abuse. To enable this, sign-up and add your secret key to the .env
for RECAPTCHA_SECRET_KEY
.
POST /collect/rapid-test
Example payload:
{
"test_result": "negative",
"test_date": "2022-01-23",
"postal_code": "V3A",
"age": "20-29",
"g-recaptcha-response": "{if enabled}"
}
Configure cron to run Task Scheduling for Laravel and report changes done via the C19T-Manager will trigger processing automatically.
Processing reports is accessible through the CLI. Not necessary if you have configured the task scheduler. This is needed if not using the C19T-Manager and updating report tables directly.
php artisan report:process
The prompt should be straightforward. Out-of-box, the processing function:
- Sums the daily case and fatality totals for each province
- Calculates the day-to-day change in tests, hospitalizations, criticals (intensive care), recoveries and vaccinations from the
reports
table. - Stores this summarized data, which is used by the reports API
Support for health regions was added in late 2020. Health regions have a separate reports table (hr_reports
) and can be processed from the CLI as well:
php artisan report:processhr
- unlike standard reports, health region reports calculates case and fatality from the
hr_reports
table.
A few select routes have caching enabled to minimize database load and speed performance of the API.
The cache is flushed when a report processing operation finishes. The cache can also be manually flushed from the C19T-Manager companion app.
By default, tests will use the APP_ENV defined in phpunit.xml
. Create .env.testing
with the following template and configure it as needed:
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=test
DB_USERNAME=test
DB_PASSWORD=secret
# used for partner-specific route
PARTNER01=
php artisan test
- Laravel - The web framework used
- Andrew Thong - Initial work
- Noah Little - Concept, data consultation
See also: COVID19Tracker.ca acknowledgements.
This project is licensed under the MIT License.
- COVID-19 Tracker Canada - the tracker that inspired this project
- Adminer - convenient single-line database administration
- DigitalOcean Hub for Good - infrastructure