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.
- dropped support for PHP versions <7.3
- removed method
setHttpUpgradeInsecureRequests(false)
#17 - removed methods
setVerifyHost()
andgetVerifyHost()
due to use of Guzzle instead of curl directly
- more unit tests
- added parameter
state
to methodsignOut
to allow maintaining state between redirects
- added method
requestTokenExchange()
implementing RFC 8693
- algorithm to determine if
client_secret_basic
orclient_secret_post
will be used for authentication inrefreshToken()
andrequestClientCredentialsToken()
is now the same like inrequestTokens()
- fixed automatic PKCE
- Added scope parameter to refresh token request, this can be disabled by setting second parameter of
refreshToken()
to false - automatic use of PKCE if OpenID provider signals support for this #9
- PKCE and nonce can be optional disabled, if really needed
- added experimental protection against mix-up attacks #14
- PKCE can be used with confidential clients #15
- id token validation is more compliant to the OIDC standard, part of #12
- improved README and documentation inside code
- fixed typo in variable (this resulted in an PHP notice Undefined property)
- it is now possible to disable upgrading from HTTP to HTTPS for development purposes by calling
setHttpUpgradeInsecureRequests(false)
getRedirectURL()
will not log a warning for PHP 7.1+
- Support for PKCE. Currently the supported methods are 'plain' and 'S256'.
- Add support for MS Azure Active Directory B2C user flows
- Fix at_hash verification #200
- Getters for public parameters #204
- Removed client ID query parameter when making a token request using Basic Auth
- Use of
random_bytes()
for token generation instead ofuniqid()
; polyfill for PHP < 7.0 provided.
- Removed explicit content-length header - caused issues with proxy servers
- php 7.4 deprecates array_key_exists on objects, use property_exists in getVerifiedClaims and requestUserInfo
- Adding a header to indicate JSON as the return type for userinfo endpoint #151
Updated OpenIDConnectClient to conditionally verify nonce #146- Add possibility to change enc_type parameter for http_build_query #155
- Adding OAuth 2.0 Token Introspection #156
- Add optional parameters clientId/clientSecret for introspection #157 & #158
- Adding OAuth 2.0 Token Revocation #160
- Adding issuer validator #145
- Adding signing algorithm PS256 #180
- Check http status of request user info #186
- URL encode clientId and clientSecret when using basic authentication, according to https://tools.ietf.org/html/rfc6749#section-2.3.1 #192
- Adjust PHPDoc to state that null is also allowed #193
- Bugfix/code cleanup #152
- Cleanup PHPDoc #46e5b59
- Replace unnecessary double quotes with single quotes #2a76b57
- Use original function names instead of aliases #1f37892
- Remove unnecessary default values #5ab801e
- Explicit declare field $redirectURL #9187c0b
- Remove unused code #1e65384
- Fix indent #e9cdf56
- Cleanup conditional code flow for better readability #107f3fb
- Added strict type comparisons #167
- Bugfix: required
openid
scope was omitted when additional scopes were registered usingaddScope
method. This resulted in failing OpenID process.
- Fix
verifyJWTsignature()
: verify JWT to prevent php errors and warnings on invalid token
- Decouple session manipulation, it's allow use of other session libraries #134
- Broaden version requirements of the phpseclib/phpseclib package. #144
- Add "license" field to composer.json #138
- Ensure key_alg is set when getting key #139
- Add option to send additional registration parameters like post_logout_redirect_uris. #140
- disabled autoload for Crypt_RSA + makre refreshToken() method tolerant for errors #137
- Added five minutes leeway due to clock skew between openidconnect server and client.
- Fix save access_token from request in implicit flow authentication #129
- verifyJWTsignature() method private -> public #126
- Support for providers where provider/login URL is not the same as the issuer URL. #125
- Support for providers that has a different login URL from the issuer URL, for instance Azure Active Directory. Here, the provider URL is on the format: https://login.windows.net/(tenant-id), while the issuer claim actually is on the format: https://sts.windows.net/(tenant-id).
- refreshToken method update #124
- Implement Azure AD B2C Implicit Workflow
- Documentation updates for include path.
- Timeout is configurable via setTimeout method. This addresses issue #94.
- Add the ability to authenticate using the Resource Owner flow (with or without the Client ID and ClientSecret). This addresses issue #98
- Add support for HS256, HS512 and HS384 signatures
- Removed unused calls to $this->getProviderConfigValue("token_endpoint_…