aqilix / zf3-apigilty-oauth2
Start API Development using ZF3, Apigility with OAuth2 support
Installs: 139
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 10
Forks: 21
Open Issues: 0
Requires
- php: ^5.6 || ^7.0
- aqilix/doctrine-data-fixture-module: ^0.0.6
- doctrine/doctrine-orm-module: ^1.1
- gedmo/doctrine-extensions: ^2.4.23
- psr/log: ^1.0
- symfony/process: ^3.1
- zendframework/zend-cache: ^2.7.1
- zendframework/zend-component-installer: ^1.0 || ^0.3 || ^1.0.0-dev@dev
- zendframework/zend-log: ^2.9
- zendframework/zend-mail: ^2.7.1
- zendframework/zend-mime: ^2.6.0
- zendframework/zend-mvc-console: ^1.1.10
- zendframework/zend-mvc-i18n: ^1.0
- zfcampus/zf-apigility: ^1.3
- zfcampus/zf-apigility-documentation: ^1.2.2
- zfcampus/zf-development-mode: ^3.0
- zfcampus/zf-http-cache: ^1.3
- zfr/zfr-cors: ^1.2
Requires (Dev)
Suggests
- zfcampus/zf-apigility-doctrine: zfcampus/zf-apigility-doctrine ^2.1 to create Doctrine-Connected REST services
- zfcampus/zf-http-cache: zfcampus/zf-http-cache ^1.3 to add HTTP caching to your API
- zfr/zfr-cors: zfr/zfr-cors ^1.2 to add CORS support to your API
This package is not auto-updated.
Last update: 2025-01-13 14:24:23 UTC
README
Requirements
Please see the composer.json file.
Installation
Via Composer (create-project)
You can use the create-project
command from Composer
to create the project in one go (you need to install composer):
$ curl -s https://getcomposer.org/installer | php -- --filename=composer
$ ./composer create-project -sdev aqilix/zf3-apigilty-oauth2 path/to/install
Via Git (clone)
First, clone the repository:
# git clone https://github.com/aqilix/zf3-apigilty-oauth2.git # optionally, specify the directory in which to clone $ cd path/to/install
I have prepare docker-compose.yml, so you can use docker-compose
to build this application.
docker-compose up -d
Install dependencies via the container:
docker-compose run api composer install
Manipulate dev mode from the container:
docker-compose run api composer development-enable
docker-compose run api composer development-status
Creating Database
docker-compose run api composer development-db-create
Importing Data Fixtures
docker-compose run api composer development-db-data-fixture-import
Or if you don't want to use Docker
, you need to use Composer to install
dependencies. Assuming you already have Composer:
$ ./composer install
Configuration
There are several configuration files in config/autoload/*.local.php.dist
need to be configured to use this application. And please remove .dist
extension on the files. Example:
mv config/autoload/local.php.dist config/autoload/local.php
Database Configuration
For database configuration, the related files need to be configured are:
- local.php.dist
- doctrine.local.php.dist
- oauth2.local.php.dist (this file also used to configure OAuth2)
Email Transport Configuration
To configure mail transport, please modify this file mailtransport.local.php.dist. For this example, I use Mailgun you can use another mail service by configure host
, username
and password
.
Email Configuration
At the moment, there are 3 events send emails from this application.
- Signup (Welcome Email)
- Account Activated
- Request Reset Password
You can configure the From, Sender Name, and Subject from this file user.local.php.dist
Project Configuration
For project configuration, there are 2 sections configuration. Those are sites
and php_process
. I think you just need to configure sites
section to adjust with url on your site. And php_process
is purposed to configure cli
.
CORS Configuration
You can configure zfr-cors on this file zfr_cors.local.php.dist
Run Application
After configure all configs, you can access this application from browser http://localhost:8080
(I configure this container using port 8080).
If you have set this as dev mode
you will see Apigility Admin on this url http://localhost:8080/apigility/ui#/
API Testing
I use Swagger for built in API Documentation. You can see it on dev mode
by access this URL http://localhost:8080/apigility/swagger
. You also can try the API Resources by using this Swagger