All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Basic authorization is now case insensitive (PR #1403)
9.0.0-RC1 - released 2024-03-27
- Device Authorization Grant added (PR #1074)
- GrantTypeInterface has a new function,
revokeRefreshTokens()
for enabling or disabling refresh tokens after use (PR #1375) - A CryptKeyInterface to allow developers to change the CryptKey implementation with greater ease (PR #1044)
- The authorization server can now finalize scopes when a client uses a refresh token (PR #1094)
- An AuthorizationRequestInterface to make it easier to extend the AuthorizationRequest (PR #1110)
- Added function
getKeyContents()
to theCryptKeyInterface
(PR #1375)
- If a refresh token has expired, been revoked, cannot be decrypted, or does not belong to the correct client, the server will now issue an
invalid_grant
error and a HTTP 400 response. In previous versions the server incorrectly issued aninvalid_request
and HTTP 401 response (PR #1042) (PR #1082)
- Authorization Request objects are now created through the factory method,
createAuthorizationRequest()
(PR #1111) - Changed parameters for
finalizeScopes()
to allow a reference to an auth code ID (PR #1112) - AccessTokenEntityInterface now requires the implementation of
toString()
instead of the magic method__toString()
(PR #1395)
- Removed message property from OAuthException HTTP response. Now just use error_description as per the OAuth 2 spec (PR #1375)
8.5.4 - released 2023-08-25
- Support for league/uri ^7.0 (PR #1367)
8.5.3 - released 2023-07-06
- If a key string is provided to the CryptKey constructor with an invalid passphrase, the LogicException message generated will expose the given key. The key is no longer leaked via this exception (PR #1353)
8.5.2 - released 2023-06-16
- Bumped the versions for laminas/diactoros and psr/http-message to support PSR-7 v2.0 (PR #1339)
8.5.1 - released 2023-04-04
- Fixed PHP version constraints and lcobucci/clock version constraint to support PHP 8.1 (PR #1336)
8.5.0 - released 2023-04-03
- Support for PHP 8.1 and 8.2 (PR #1333)
- Support PHP 7.2, 7.3, and 7.4 (PR #1333)
8.4.1 - released 2023-03-22
- Fix deprecation notices for PHP 8.x (PR #1329)
8.4.0 - released 2023-02-15
- You can now set a leeway for time drift between servers when validating a JWT (PR #1304)
- Access token requests that contain a code_verifier but are not bound to a code_challenge will be rejected to prevent a PKCE downgrade attack (PR #1326)
8.3.6 - released 2022-11-14
- Use LooseValidAt instead of StrictValidAt so that users aren't forced to use claims such as NBF in their JWT tokens (PR #1312)
8.3.5 - released 2022-05-12
- Use InMemory::plainText('empty', 'empty') instead of InMemory::plainText('') to avoid new empty string exception thrown by lcobucci/jwt (PR #1282)
8.3.4 - released 2022-04-07
- Server previously rejected valid uris with custom schemes. Now use league/uri for parsing to accept all valid uris (PR #1274)
8.3.3 - released 2021-10-11
- Removed the use of
LocalFileReference()
in lcobucci/jwt. Function deprecated as per GHSA-7322-jrq4-x5hf (PR #1249)
8.3.2 - released 2021-07-27
- Conditionally support the
StrictValidAt()
method in lcobucci/jwt so we can use version 4.1.x or greater of the library (PR #1236) - When providing invalid credentials, the library now responds with the error message The user credentials were incorrect (PR #1230)
- Keys are always stored in memory now and are not written to a file in the /tmp directory (PR #1180)
- The regex for matching the bearer token has been simplified (PR #1238)
8.3.1 - released 2021-06-04
- Revert check on clientID. We will no longer require this to be a string (PR #1233)
8.3.0 - released 2021-06-03
- The server will now validate redirect uris according to rfc8252 (PR #1203)
- Events emitted now include the refresh token and access token payloads (PR #1211)
- Use the
revokeRefreshTokens()
function to decide whether refresh tokens are revoked or not upon use (PR #1189)
- Keys are now validated using
openssl_pkey_get_private()
andopenssl_pkey_get_public()
instead of regex matching (PR #1215)
- The server will now only recognise and handle an authorization header if the value of the header is non-empty. This is to circumvent issues where some common frameworks set this header even if no value is present (PR #1170)
- Added type validation for redirect uri, client ID, client secret, scopes, auth code, state, username, and password inputs (PR #1210)
- Allow scope "0" to be used. Previously this was removed from a request because it failed an
empty()
check (PR #1181)
8.2.4 - released 2020-12-10
- Reverted the enforcement of at least one redirect_uri for a client. This change has instead been moved to version 9 (PR #1169)
8.2.3 - released 2020-12-02
- Re-added support for PHP 7.2 (PR #1165, #1167)
8.2.2 - released 2020-11-30
- Fix issue where the private key passphrase isn't correctly passed to JWT library (PR #1164)
8.2.1 - released 2020-11-26
- If you have a password on your private key, it is now passed correctly to the JWT configuration object. (PR #1159)
8.2.0 - released 2020-11-25
- Add a
getRedirectUri
function to theOAuthServerException
class (PR #1123) - Support for PHP 8.0 (PR #1146)
- Removed support for PHP 7.2 (PR #1146)
- Fix typo in parameter hint.
code_challenged
changed tocode_challenge
. Thrown by Auth Code Grant when the code challenge does not match the regex. (PR #1130) - Undefined offset was returned when no client redirect URI was set. Now throw an invalidClient exception if no redirect URI is set against a client (PR #1140)
8.1.1 - released 2020-07-01
- If you provide a valid redirect_uri with the auth code grant and an invalid scope, the server will use the given redirect_uri instead of the default client redirect uri (PR #1126)
8.1.0 - released 2020-04-29
- Added support for PHP 7.4 (PR #1075)
- If an error is encountered when running
preg_match()
to validate an RSA key, the server will now throw a RuntimeException (PR #1047) - Replaced deprecated methods with recommended ones when using
Lcobucci\JWT\Builder
to build a JWT token. (PR #1060) - When storing a key, we no longer touch the file before writing it as this is an unnecessary step (PR #1064)
- Prefix native PHP functions in namespaces with backslashes for micro-optimisations (PR #1071)
- Support for PHP 7.1 (PR #1075)
- Clients are now explicitly prevented from using the Client Credentials grant unless they are confidential to conform with the OAuth2 spec (PR #1035)
- Abstract method
getIdentifier()
added to AccessTokenTrait. The trait cannot be used without thegetIdentifier()
method being defined (PR #1051) - An exception is now thrown if a refresh token is accidentally sent in place of an authorization code when using the Auth Code Grant (PR #1057)
- Can now send access token request without being forced to specify a redirect URI (PR #1096)
- In the BearerTokenValidator, if an implementation is using PDO, there is a possibility that a RuntimeException will be thrown when checking if an access token is revoked. This scenario no longer incorrectly issues an exception with a hint mentioning an issue with JSON decoding. (PR #1107)
8.0.0 - released 2019-07-13
- Flag,
requireCodeChallengeForPublicClients
, used to reject public clients that do not provide a code challenge for the Auth Code Grant; use AuthCodeGrant::disableRequireCodeCallengeForPublicClients() to turn off this requirement (PR #938) - Public clients can now use the Auth Code Grant (PR #938)
isConfidential
getter added toClientEntity
to identify type of client (PR #938)- Function
validateClient()
added to validate clients which was previously performed by thegetClientEntity()
function (PR #938) - Add a new function to the AbstractGrant class called
getClientEntityOrFail()
. This is a wrapper around thegetClientEntity()
function that ensures we emit and throw an exception if the repo doesn't return a client entity. (PR #1010)
- Replace
convertToJWT()
interface with a more generic__toString()
to improve extensibility; AccessTokenEntityInterface now requiressetPrivateKey(CryptKey $privateKey)
so__toString()
has everything it needs to work (PR #874) - The
invalidClient()
function accepts a PSR-7 compliant$serverRequest
argument to avoid accessing the$_SERVER
global variable and improve testing (PR #899) issueAccessToken()
in the Abstract Grant no longer sets access token client, user ID or scopes. These values should already have been set when callinggetNewToken()
(PR #919)- No longer need to enable PKCE with
enableCodeExchangeProof
flag. Any client sending a code challenge will initiate PKCE checks. (PR #938) - Function
getClientEntity()
no longer performs client validation (PR #938) - Password Grant now returns an invalid_grant error instead of invalid_credentials if a user cannot be validated (PR #967)
- Use
DateTimeImmutable()
instead ofDateTime()
,time()
instead of(new DateTime())->getTimeStamp()
, andDateTime::getTimeStamp()
instead ofDateTime::format('U')
(PR #963)
enableCodeExchangeProof
flag (PR #938)- Support for PHP 7.0 (PR #1014)
- Remove JTI claim from JWT header (PR #1031)
7.4.0 - released 2019-05-05
- RefreshTokenRepository can now return null, allowing refresh tokens to be optional. (PR #649)
7.3.3 - released 2019-03-29
- Added
error_description
to the error payload to improve standards compliance. The contents of this are copied from the existingmessage
value. (PR #1006)
- Error payload will not issue
message
value in the next major release (PR #1006)
7.3.2 - released 2018-11-21
- Revert setting keys on response type to be inside
getResponseType()
function instead of AuthorizationServer constructor (PR #969)
7.3.1 - released 2018-11-15
- Fix issue with previous release where interface had changed for the AuthorizationServer. Reverted to the previous interface while maintaining functionality changes (PR #970)
7.3.0 - released 2018-11-13
- Moved the
finalizeScopes()
call fromvalidateAuthorizationRequest
method to thecompleteAuthorizationRequest
method so it is called just before the access token is issued (PR #923)
- Added a ScopeTrait to provide an implementation for jsonSerialize (PR #952)
- Ability to nest exceptions (PR #965)
- Fix issue where AuthorizationServer is not stateless as ResponseType could store state of a previous request (PR #960)
7.2.0 - released 2018-06-23
- Added new
validateRedirectUri
method AbstractGrant to remove three instances of code duplication (PR #912) - Allow 640 as a crypt key file permission (PR #917)
- Function
hasRedirect()
added toOAuthServerException
(PR #703)
- Catch and handle
BadMethodCallException
from theverify()
method of the JWT token in thevalidateAuthorization
method (PR #904)
4.1.7 - released 2018-06-23
- Ensure
empty()
function call only contains variable to be compatible with PHP 5.4 (PR #918)
7.1.1 - released 2018-05-21
- No longer set a WWW-Authenticate header for invalid clients if the client did not send an Authorization header in the original request (PR #902)
7.1.0 - released 2018-04-22
- Changed hint for unsupportedGrantType exception so it no longer references the grant type parameter which isn't always expected (PR #893)
- Upgrade PHPStan checks to level 7 (PR #856)
- Added event emitters for issued access and refresh tokens (PR #860)
- Can now use Defuse\Crypto\Key for encryption/decryption of keys which is faster than the Cryto class (PR #812)
- Remove paragone/random_compat from dependencies
7.0.0 - released 2018-02-18
- Use PHPStan for static analysis of code (PR #848)
- Enforce stricter static analysis checks and upgrade library dependencies (PR #852)
- Provide PHPStan coverage for tests and update PHPUnit (PR #849)
- Get and set methods for OAuth Server Exception payloads. Allow implementer to specify the JSON encode options (PR #719)
- ClientRepository interface will now accept null for the Grant type to improve extensibility options (PR #607)
- Do not issue an error if key file permissions are 400 or 440 (PR #839)
- Skip key file creation if the file already exists (PR #845)
- Change changelog format and update readme
- Support for PHP 5.6
- Support for version 5.x and 6.x of the library
- PKCE implementation (PR #744)
- Set correct redirect URI when validating scopes (PR #840)
- S256 code challenege method (PR #842)
- Accept RSA key with CRLF line endings (PR #805)
6.1.1 - 2017-12-23
- Removed check on empty scopes
6.1.0 - 2017-12-23
- Changed the token type issued by the Implicit Grant to be Bearer instead of bearer. (PR #724)
- Replaced call to array_key_exists() with the faster isset() on the Implicit Grant. (PR #749)
- Allow specification of query delimiter character in the Password Grant (PR #801)
- Add Zend Diactoros library dependency to examples (PR #678)
- Can set default scope for the authorization endpoint. If no scope is passed during an authorization request, the default scope will be used if set. If not, the server will issue an invalid scope exception (PR #811)
- Added validation for redirect URIs on the authorization end point to ensure exactly one redirection URI has been passed (PR #573)
6.0.2 - 2017-08-03
- An invalid refresh token that can't be decrypted now returns a HTTP 401 error instead of HTTP 400 (Issue #759)
- Removed chmod from CryptKey and add toggle to disable checking (Issue #776)
- Fixes invalid code challenge method payload key name (Issue #777)
6.0.1 - 2017-07-19
To address feedback from the security release the following change has been made:
- If an RSA key cannot be chmod'ed to 600 then it will now throw a E_USER_NOTICE instead of an exception.
6.0.0 - 2017-07-01
- Breaking change: The
AuthorizationServer
constructor now expects an encryption key string instead of a public key - Remove support for HHVM
- Remove support for PHP 5.5
5.1.4 - 2017-07-01
- Fixed multiple security vulnerabilities as a result of a security audit paid for by the Mozilla Secure Open Source Fund. All users of this library are encouraged to update as soon as possible to this version or version 6.0 or greater.
- It is recommended on each
AuthorizationServer
instance you set thesetEncryptionKey()
. This will result in stronger encryption being used. If this method is not set messages will be sent to the defined error handling routines (usingerror_log
). Please see the examples and documentation for examples.
- It is recommended on each
- TravisCI now tests PHP 7.1 (Issue #671)
- Fix middleware example fatal error (Issue #682)
- Fix typo in the first README sentence (Issue #690)
- Corrected DateInterval from 1 min to 1 month (Issue #709)
5.1.3 - 2016-10-12
- Fixed WWW-Authenticate header (Issue #669)
- Increase the recommended RSA key length from 1024 to 2048 bits (Issue #668)
5.1.2 - 2016-09-19
- Fixed
finalizeScopes
call (Issue #650)
4.1.6 - 2016-09-13
- Less restrictive on Authorization header check (Issue #652)
5.1.1 - 2016-07-26
- Improved test suite (Issue #614)
- Updated docblocks (Issue #616)
- Replace
array_shift
withforeach
loop (Issue #621) - Allow easy addition of custom fields to Bearer token response (Issue #624)
- Key file auto-generation from string (Issue #625)
5.1.0 - 2016-06-28
- Implemented RFC7636 (Issue #574)
- Unify middleware exception responses (Issue #578)
- Updated examples (Issue #589)
- Ensure state is in access denied redirect (Issue #597)
- Remove redundant
isExpired()
method from entity interfaces and traits (Issue #600) - Added a check for unique access token constraint violation (Issue #601)
- Look at Authorization header directly for HTTP Basic auth checks (Issue #604)
- Added catch Runtime exception when parsing JWT string (Issue #605)
- Allow
paragonie/random_compat
2.x (Issue #606) - Added
indigophp/hash-compat
to Composer suggestions andrequire-dev
for PHP 5.5 support
5.0.3 - 2016-05-04
- Fix hints in PasswordGrant (Issue #560)
- Add meaning of
Resource owner
to terminology.md (Issue #561) - Use constant for event name instead of explicit string (Issue #563)
- Remove unused request property (Issue #564)
- Correct wrong phpdoc (Issue #569)
- Fixed typo in exception string (Issue #570)
5.0.2 - 2016-04-18
state
parameter is now correctly returned after implicit grant authorization- Small code and docblock improvements
5.0.1 - 2016-04-18
- Fixes an issue (#550) whereby it was unclear whether or not to validate a client's secret during a request.
5.0.0 - 2016-04-17
Version 5 is a complete code rewrite.
- Renamed Server class to AuthorizationServer
- Added ResourceServer class
- Run unit tests again PHP 5.5.9 as it's the minimum supported version
- Enable PHPUnit 5.0 support
- Improved examples and documentation
- Make it clearer that the implicit grant doesn't support refresh tokens
- Improved refresh token validation errors
- Fixed refresh token expiry date
5.0.0-RC2 - 2016-04-10
- Allow multiple client redirect URIs (Issue #511)
- Remove unused mac token interface (Issue #503)
- Handle RSA key passphrase (Issue #502)
- Remove access token repository from response types (Issue #501)
- Remove unnecessary methods from entity interfaces (Issue #490)
- Ensure incoming JWT hasn't expired (Issue #509)
- Fix client identifier passed where user identifier is expected (Issue #498)
- Removed built-in entities; added traits to for quick re-use (Issue #504)
- Redirect uri is required only if the "redirect_uri" parameter was included in the authorization request (Issue #514)
- Removed templating for auth code and implicit grants (Issue #499)
5.0.0-RC1 - 2016-03-24
Version 5 is a complete code rewrite.
- JWT support
- PSR-7 support
- Improved exception errors
- Replace all occurrences of the term "Storage" with "Repository"
- Simplify repositories
- Entities conform to interfaces and use traits
- Auth code grant updated
- Allow support for public clients
- Add support for #439
- Client credentials grant updated
- Password grant updated
- Allow support for public clients
- Refresh token grant updated
- Implement Implicit grant
- Bearer token output type
- Remove MAC token output type
- Authorization server rewrite
- Resource server class moved to PSR-7 middleware
- Tests
- Much much better documentation
4.1.5 - 2016-01-04
- Enable Symfony 3.0 support (#412)
4.1.4 - 2015-11-13
- Fix for determining access token in header (Issue #328)
- Refresh tokens are now returned for MAC responses (Issue #356)
- Added integration list to readme (Issue #341)
- Expose parameter passed to exceptions (Issue #345)
- Removed duplicate routing setup code (Issue #346)
- Docs fix (Issues #347, #360, #380)
- Examples fix (Issues #348, #358)
- Fix typo in docblock (Issue #352)
- Improved timeouts for MAC tokens (Issue #364)
hash_hmac()
should output raw binary data, not hexits (Issue #370)- Improved regex for matching all Base64 characters (Issue #371)
- Fix incorrect signature parameter (Issue #372)
- AuthCodeGrant and RefreshTokenGrant don't require client_secret (Issue #377)
- Added priority argument to event listener (Issue #388)
4.1.3 - 2015-03-22
- Docblock, namespace and inconsistency fixes (Issue #303)
- Docblock type fix (Issue #310)
- Example bug fix (Issue #300)
- Updated league/event to ~2.1 (Issue #311)
- Fixed missing session scope (Issue #319)
- Updated interface docs (Issue #323)
.travis.yml
updates
4.1.2 - 2015-01-01
- Remove side-effects in hash_equals() implementation (Issue #290)
4.1.1 - 2014-12-31
- Changed
symfony/http-foundation
dependency version to~2.4
so package can be installed in Laravel4.1.*
4.1.0 - 2014-12-27
- Added MAC token support (Issue #158)
- Fixed example init code (Issue #280)
- Toggle refresh token rotation (Issue #286)
- Docblock fixes
4.0.5 - 2014-12-15
- Prevent duplicate session in auth code grant (Issue #282)
4.0.4 - 2014-12-03
- Ensure refresh token hasn't expired (Issue #270)
4.0.3 - 2014-12-02
- Fix bad type hintings (Issue #267)
- Do not forget to set the expire time (Issue #268)
4.0.2 - 2014-11-21
- Improved interfaces (Issue #255)
- Learnt how to spell delimiter and so
getScopeDelimiter()
andsetScopeDelimiter()
methods have been renamed - Docblock improvements (Issue #254)
4.0.1 - 2014-11-09
- Alias the master branch in composer.json (Issue #243)
- Numerous PHP CodeSniffer fixes (Issue #244)
- .travis.yml update (Issue #245)
- The getAccessToken method should return an AccessTokenEntity object instead of a string in ResourceServer.php (#246)
4.0.0 - 2014-11-08
- Complete rewrite
- Check out the documentation - http://oauth2.thephpleague.com
3.2.0 - 2014-04-16
- Added the ability to change the algorithm that is used to generate the token strings (Issue #151)
3.1.2 - 2014-02-26
- Support Authorization being an environment variable. See more
3.1.1 - 2013-12-05
- Normalize headers when
getallheaders()
is available (Issues #108 and #114)
3.1.0 - 2013-12-05
- No longer necessary to inject the authorisation server into a grant, the server will inject itself
- Added test for 1419ba8cdcf18dd034c8db9f7de86a2594b68605
3.0.1 - 2013-12-02
- Forgot to tell TravisCI from testing PHP 5.3
3.0.0 - 2013-12-02
- Fixed spelling of Implicit grant class (Issue #84)
- Travis CI now tests for PHP 5.5
- Fixes for checking headers for resource server (Issues #79 and #)
- The word "bearer" now has a capital "B" in JSON output to match OAuth 2.0 spec
- All grants no longer remove old sessions by default
- All grants now support custom access token TTL (Issue #92)
- All methods which didn't before return a value now return
$this
to support method chaining - Removed the build in DB providers - these will be put in their own repos to remove baggage in the main repository
- Removed support for PHP 5.3 because this library now uses traits and will use other modern PHP features going forward
- Moved some grant related functions into a trait to reduce duplicate code
2.1.1 - 2013-06-02
- Added conditional
isValid()
flag to check for Authorization header only (thanks @alexmcroberts) - Fixed semantic meaning of
requireScopeParam()
andrequireStateParam()
by changing their default value to true - Updated some duff docblocks
- Corrected array key call in Resource.php (Issue #63)
2.1.0 - 2013-05-10
- Moved zetacomponents/database to "suggest" in composer.json. If you rely on this feature you now need to include " zetacomponents/database" into "require" key in your own composer.json. (Issue #51)
- New method in Refresh grant called
rotateRefreshTokens()
. Pass intrue
to issue a new refresh token each time an access token is refreshed. This parameter needs to be set to true in order to request reduced scopes with the new access token. (Issue #47) - Rename
key
column in oauth_scopes table toscope
askey
is a reserved SQL word. (Issue #45) - The
scope
parameter is no longer required by default as per the RFC. (Issue #43) - You can now set multiple default scopes by passing an array into
setDefaultScope()
. (Issue #42) - The password and client credentials grants now allow for multiple sessions per user. (Issue #32)
- Scopes associated to authorization codes are not held in their own table (Issue #44)
- Database schema updates.
2.0.5 - 2013-05-09
- Fixed
oauth_session_token_scopes
table primary key - Removed
DEFAULT ''
that has slipped into some tables - Fixed docblock for
SessionInterface::associateRefreshToken()
2.0.4 - 2013-05-09
- Renamed primary key in oauth_client_endpoints table
- Adding missing column to oauth_session_authcodes
- A refresh token should be bound to a client ID
2.0.3 - 2013-05-08
- Fixed a link to code in composer.json
2.0.2 - 2013-05-08
- Updated README with wiki guides
- Removed
null
as default parameters in some methods in the storage interfaces - Fixed license copyright
2.0.0 - 2013-05-08
If you're upgrading from v1.0.8 there are lots of breaking changes
- Rewrote the session storage interface from scratch so methods are more obvious
- Included a PDO driver which implements the storage interfaces so the library is more "get up and go"
- Further normalised the database structure so all sessions no longer contain infomation related to authorization grant (which may or may not be enabled)
- A session can have multiple associated access tokens
- Individual grants can have custom expire times for access tokens
- Authorization codes now have a TTL of 10 minutes by default (can be manually set)
- Refresh tokens now have a TTL of one week by default (can be manually set)
- The client credentials grant will no longer gives out refresh tokens as per the specification
1.0.8 - 2013-03-18
- Fixed check for required state parameter
- Fixed check that user's credentials are correct in Password grant
1.0.7 - 2013-03-04
- Added method
requireStateParam()
- Added method
requireScopeParam()
1.0.6 - 2013-02-22
- Added links to tutorials in the README
- Added missing
state
parameter request to thecheckAuthoriseParams()
method.
1.0.5 - 2013-02-21
- Fixed the SQL example for SessionInterface::getScopes()
1.0.3 - 2013-02-20
- Changed all instances of the "authentication server" to "authorization server"
1.0.2 - 2013-02-20
- Fixed MySQL create table order
- Fixed version number in composer.json
1.0.1 - 2013-02-19
- Updated AuthServer.php to use
self::getParam()
- First major release