- Docker
- Docker Compose
- Clone this repo
git clone https://github.com/warslett/team-registration-system.git && cd team-registration-system
- Create your environment file
cp .env.dist .env
. If you are setting up a production environment, update the values in .env - Create a pair of SSL keys for the API. For development you can copy the distributed keys by running
cp ssl/jwt.dist/* ssl/jwt
. If you are setting up a production environment you should generate your own keys. - Run
bin/build
- Visit in your browser (with default port the address would be
http://127.0.0.1:39876
)
All features are tested by behat scenarios. To run behat use this command
docker-compose exec php vendor/bin/behat
Low level functionality is unit tested with PHPUnit. To run phpunit use this command
docker-compose exec php vendor/bin/phpunit
For development, you can populate the database with fake data by running this command
bin/console hautelook:fixtures:load
All users created have the password "development"
For testing the API, use the email address "[email protected]"
Roles on the system are managed with User Groups. The following roles have elevated privileges:
ROLE_ADMIN should be granted to any user that needs to perform administrative tasks on the application including managing events and users.
ROLE_API_USER should be granted to any user that needs access to the API
To add the user "[email protected]" to the User Group with the role ROLE_ADMIN
bin/console app:user:grant [email protected] ROLE_ADMIN
In order for the api to run from your environment you must first generate some SSL keys so that the user's access tokens
can be securely encrypted. If you do not carry out this step the API will not work at all. In a development environment
it is acceptable to use the distributed keys by just running cp ssl/jwt.dist/* ssl/jwt
. In a production environment
you should create your own keys by running the following commands.
docker-compose exec php openssl genrsa -out ssl/jwt/private.enc.pem -aes256 4096
docker-compose exec php openssl rsa -pubout -in ssl/jwt/private.enc.pem -out ssl/jwt/public.pem
docker-compose exec php openssl rsa -in ssl/jwt/private.enc.pem -out ssl/jwt/private.pem
First authenticate with the API by sending a POST request to /api/login with the email and password of a user with the role ROLE_API_USER (see Dev Fixtures section above for out the box access in dev) included in the form data. You can do this with curl like this:
curl -X POST http://127.0.0.1:39876/api/login -d _username="[email protected]" -d _password="development"
This will return you a JSON Web Token (JWT) that you can pass to every subsequent request in the Authorization header to prove who you are. So for example, to get a list of events from the system you can do this:
curl http://127.0.0.1:39876/api/events/1 -H "Authorization: Bearer YOUR_TOKEN_GOES_HERE"
which will return something that looks like this:
{
"@context": "/api/contexts/Event",
"@id": "/api/events/1",
"@type": "Event",
"id": 1,
"name": "Three Towers 2017",
"date": "2017-04-30T00:00:00+00:00",
"registrationOpens": "2016-10-30T00:00:00+00:00",
"registrationCloses": "2017-03-30T00:00:00+00:00",
"hikes": [
"/api/hikes/1",
"/api/hikes/2",
"/api/hikes/3",
"/api/hikes/4"
]
}
Collections like these paginate up to 30 items in a single response. Pagination information is specified in the property
hydra:view
. For example:
curl http://127.0.0.1:39876/api/teams -H "Authorization: Bearer YOUR_TOKEN_GOES_HERE"
{
"@context":"/api/contexts/Team",
"@id":"/api/teams",
"@type":"hydra:Collection",
"hydra:member":[
{
"@id":"/api/teams/1",
"@type":"Team",
"name":"Nihil repellat ut.",
"hike":"/api/hikes/18",
"id":1
},
{
"@id":"/api/teams/2",
"@type":"Team",
"name":"Est est alias.",
"hike":"/api/hikes/18",
"id":2
},
...
],
"hydra:totalItems":147,
"hydra:view":{
"@id":"/api/teams?page=1",
"@type":"hydra:PartialCollectionView",
"hydra:first":"/api/teams?page=1",
"hydra:last":"/api/teams?page=5",
"hydra:next":"/api/teams?page=2"
}
}
Accessing the subsequent page can be achieved using the the page parameter in the query string eg.
curl http://127.0.0.1:39876/api/teams?page=2 -H "Authorization: Bearer YOUR_TOKEN_GOES_HERE"