oauth2-server/README.md

114 lines
5.8 KiB
Markdown
Raw Normal View History

2016-04-10 16:31:05 +01:00
# PHP OAuth 2.0 Server
2013-12-05 21:32:29 +00:00
2014-09-30 23:12:43 +01:00
[![Latest Version](http://img.shields.io/packagist/v/league/oauth2-server.svg?style=flat-square)](https://github.com/thephpleague/oauth2-server/releases)
2014-10-03 14:42:01 +01:00
[![Software License](https://img.shields.io/badge/license-MIT-brightgreen.svg?style=flat-square)](LICENSE.md)
2014-09-30 23:12:43 +01:00
[![Build Status](https://img.shields.io/travis/thephpleague/oauth2-server/master.svg?style=flat-square)](https://travis-ci.org/thephpleague/oauth2-server)
[![Coverage Status](https://img.shields.io/scrutinizer/coverage/g/thephpleague/oauth2-server.svg?style=flat-square)](https://scrutinizer-ci.com/g/thephpleague/oauth2-server/code-structure)
[![Quality Score](https://img.shields.io/scrutinizer/g/thephpleague/oauth2-server.svg?style=flat-square)](https://scrutinizer-ci.com/g/thephpleague/oauth2-server)
2016-02-22 11:04:03 +00:00
[![Total Downloads](https://img.shields.io/packagist/dt/league/oauth2-server.svg?style=flat-square)](https://packagist.org/packages/league/oauth2-server)
2018-02-18 14:20:37 +00:00
[![PHPStan](https://img.shields.io/badge/PHPStan-enabled-brightgreen.svg?style=flat-square)](https://github.com/phpstan/phpstan)
2013-12-05 21:32:29 +00:00
2016-12-23 00:30:54 +02:00
`league/oauth2-server` is a standards compliant implementation of an [OAuth 2.0](https://tools.ietf.org/html/rfc6749) authorization server written in PHP which makes working with OAuth 2.0 trivial. You can easily configure an OAuth 2.0 server to protect your API with access tokens, or allow clients to request new access tokens and refresh them.
2018-02-18 15:28:28 +00:00
Out of the box it supports the following grants:
2014-09-30 23:12:43 +01:00
* Authorization code grant
2016-02-22 11:04:03 +00:00
* Implicit grant
2014-09-30 23:12:43 +01:00
* Client credentials grant
* Resource owner password credentials grant
* Refresh grant
2012-08-27 15:43:17 +01:00
2016-05-06 15:23:25 +01:00
The following RFCs are implemented:
* [RFC6749 "OAuth 2.0"](https://tools.ietf.org/html/rfc6749)
* [RFC6750 " The OAuth 2.0 Authorization Framework: Bearer Token Usage"](https://tools.ietf.org/html/rfc6750)
* [RFC7519 "JSON Web Token (JWT)"](https://tools.ietf.org/html/rfc7519)
* [RFC7636 "Proof Key for Code Exchange by OAuth Public Clients"](https://tools.ietf.org/html/rfc7636)
2016-04-10 16:31:05 +01:00
This library was created by Alex Bilbie. Find him on Twitter at [@alexbilbie](https://twitter.com/alexbilbie).
2012-08-27 15:43:17 +01:00
2014-09-30 23:12:43 +01:00
## Requirements
2013-12-19 12:33:39 +00:00
2014-09-30 23:12:43 +01:00
The following versions of PHP are supported:
2013-12-19 12:33:39 +00:00
2016-01-13 00:46:08 +00:00
* PHP 7.0
2017-02-02 17:29:06 +00:00
* PHP 7.1
* PHP 7.2
2018-12-06 23:46:28 +00:00
* PHP 7.3
2013-12-19 12:33:39 +00:00
2016-04-10 16:28:54 +01:00
The `openssl` extension is also required.
2012-08-27 15:43:17 +01:00
2018-06-08 11:19:27 +01:00
All HTTP messages passed to the server should be [PSR-7 compliant](https://www.php-fig.org/psr/psr-7/). This ensures interoperability with other packages and frameworks.
2018-02-18 14:20:37 +00:00
## Installation
```
composer require league/oauth2-server
```
2014-09-30 23:12:43 +01:00
## Documentation
2012-08-27 15:43:17 +01:00
2018-02-18 14:20:37 +00:00
The library documentation can be found at [https://oauth2.thephpleague.com](https://oauth2.thephpleague.com).
2016-04-10 16:31:55 +01:00
You can contribute to the documentation in the [gh-pages branch](https://github.com/thephpleague/oauth2-server/tree/gh-pages/).
2013-02-22 13:31:05 +00:00
2018-02-18 14:20:37 +00:00
## Testing
The library uses [PHPUnit](https://phpunit.de/) for unit tests and [PHPStan](https://github.com/phpstan/phpstan) for static analysis of the code.
```
vendor/bin/phpunit
2018-02-18 21:17:32 +01:00
vendor/bin/phpstan analyse -l 7 -c phpstan.neon src tests
2018-02-18 14:20:37 +00:00
```
## Continous Integration
We use [Travis CI](https://travis-ci.org/), [Scrutinizer](https://scrutinizer-ci.com/), and [StyleCI](https://styleci.io/) for continuous integration. Check out [our](https://github.com/thephpleague/oauth2-server/blob/master/.travis.yml) [configuration](https://github.com/thephpleague/oauth2-server/blob/master/.scrutinizer.yml) [files](https://github.com/thephpleague/oauth2-server/blob/master/.styleci.yml) if you'd like to know more.
## Community Integrations
2018-05-03 17:06:27 +01:00
* [Drupal](https://www.drupal.org/project/simple_oauth)
2018-02-18 14:20:37 +00:00
* [Laravel Passport](https://github.com/laravel/passport)
* [OAuth 2 Server for CakePHP 3](https://github.com/uafrica/oauth-server)
* [OAuth 2 Server for Expressive](https://github.com/zendframework/zend-expressive-authentication-oauth2)
* [Trikoder OAuth 2 Bundle (Symfony)](https://github.com/trikoder/oauth2-bundle)
2018-02-18 14:20:37 +00:00
## Changelog
2012-08-27 15:43:17 +01:00
2018-02-18 15:29:59 +00:00
See the [project changelog](https://github.com/thephpleague/oauth2-server/blob/master/CHANGELOG.md)
2012-08-27 15:43:17 +01:00
## Contributing
2012-08-27 15:43:17 +01:00
Contributions are always welcome. Please see [CONTRIBUTING.md](https://github.com/thephpleague/oauth2-server/blob/master/CONTRIBUTING.md) and [CODE_OF_CONDUCT.md](https://github.com/thephpleague/oauth2-server/blob/master/CODE_OF_CONDUCT.md) for details.
2013-07-24 13:14:48 -04:00
## Support
2013-07-24 13:14:48 -04:00
2016-02-22 11:04:03 +00:00
Bugs and feature request are tracked on [GitHub](https://github.com/thephpleague/oauth2-server/issues).
If you have any questions about OAuth _please_ open a ticket here; please **don't** email the address below.
2013-07-24 13:14:48 -04:00
## Commercial Support
2016-05-10 13:23:56 +01:00
If you would like help implementing this library into your existing platform, or would be interested in OAuth advice or training for you and your team please get in touch with [Glynde Labs](https://glyndelabs.com).
2015-02-05 16:14:59 +00:00
## Security
2016-04-17 13:32:20 +01:00
If you discover any security related issues, please email `hello@alexbilbie.com` instead of using the issue tracker.
2015-02-05 16:14:59 +00:00
## License
2013-07-24 13:14:48 -04:00
2014-10-01 00:16:26 +01:00
This package is released under the MIT License. See the bundled [LICENSE](https://github.com/thephpleague/oauth2-server/blob/master/LICENSE) file for details.
2013-07-24 13:14:48 -04:00
## Credits
2013-07-24 13:14:48 -04:00
2018-02-18 14:20:37 +00:00
This code is principally developed and maintained by [Andy Millington](https://twitter.com/Sephster) and [Simon Hamp](https://twitter.com/simonhamp).
2012-09-07 12:59:41 +02:00
2017-10-28 18:29:55 +07:00
Between 2012 and 2017 this library was developed and maintained by [Alex Bilbie](https://alexbilbie.com/).
2018-02-18 14:20:37 +00:00
PHP OAuth 2.0 Server is one of many packages provided by The PHP League. To find out more, please visit [our website](https://thephpleague.com).
2017-07-01 17:17:55 +01:00
Special thanks to [all of these awesome contributors](https://github.com/thephpleague/oauth2-server/contributors).
Additional thanks go to the [Mozilla Secure Open Source Fund](https://wiki.mozilla.org/MOSS/Secure_Open_Source) for funding a security audit of this library.
2013-12-05 21:20:48 +00:00
2014-08-06 18:16:16 +01:00
The initial code was developed as part of the [Linkey](http://linkey.blogs.lincoln.ac.uk) project which was funded by [JISC](http://jisc.ac.uk) under the Access and Identity Management programme.