zokirov/api-starter-kit

API starter kit for Symfony projects


README

[//]: <> ( todo udpate image and add new docker commands, tell about interfaces )

Starter kit for API with Symfony, Doctrine, Maker Bundle, Migration Bundle, Api-Platform and JWT-auth.

Kit has also already created a User entity with all crud routes

Kit has 3 docker containers: php, nginx and mysql

poster

Installation

Download the project

composer create-project zokirov/api-starter-kit --ignore-platform-reqs --no-scripts

Go to the project directory

cd api-starter-kit

Run docker containers

docker compose up -d

Install composer scripts:

docker compose exec php composer install

To install project run command:

docker compose exec php bin/console ask:install

Done! You can open http://localhost:8508/api via browser. By the way, you can change this port by changing `DOCKER_NGINX_PORT` variable in .env file.

Docker

For enter to php container run

docker compose exec php bash

For enter to mysql container run

docker compose exec mysql bash

For enter to nginx container run

docker compose exec nginx bash

You can change containers prefix by changing `DOCKER_PROJECT_NAME` variable in .env file.

Also, you can change public ports of nginx and mysql by changing `DOCKER_NGINX_PORTandDOCKER_DATABASE_PORT`

Database allows connections only from localhost. Because of this, when you use the project in production and want to connect to a database from your computer, you should connect via ssh bridge.

Cron

You can use docker/php/cron-file for cron jobs. After you must re-build php container by running command:

docker compose up -d --build

Swagger

You can change the project name and description on swagger by editing file config/packages/api_platform.yaml

Git Hook

If you don't use any deploying system, you can do


In this way git always executes command ```bin/console ask:deploy```. 
You can change this command in the file [src/Command/AskDeployCommand.php](src/Command/AskDeployCommand.php).
This command will install requirements via composer, 
clear caches, change an owner of ./var and ./public/media folders to www-data, will run migrations. 

## JWT keys
To use the JSON Web Token system, you must create private and public keys. 
They have already created when you install a project. You can re-create them with:<br>  
```bin/console ask:generate:jwtKeys```