This is a port of the ebay-oauth-java-client
eBay OAuth client library is a simple and easy-to-use library for integrating with eBay OAuth and designed to be used for OAuth 2.0 specification supported by eBay. There are multiple standard clients that can be used with eBay OAuth, such as OpenID Connect client. However, this library in addition to functioning as a simple eBay OAuth client, helps with additional features such as cached App tokens. There are also future enhancements planned to add id_token support, 'login with eBay' support etc.,
OAuth 2.0 is the most widely used standard for authentication and authorization for API based access. The complete end to end documentation on how eBay OAuth functions is available at developer.ebay.com.
This library is created as a PHP project and can be used as a dependency in a PHP based application
Install in your project by downloading the repo and extracting in your project or using composer
Add the library to your composer.json
{
"require": {
"eaglexboy/ebay-oauth-php-client": "^1.0"
}
}
or via command line
composer require eaglexboy/ebay-oauth-php-client
All interactions with this library can be performed using oauth2Api = new OAuth2Api();
- Ensure you have a config file in your source code of type YAML. Refer to ebay-config-sample.yaml.
- This file would hold all your application credentials such as AppId, DevId, and CertId. Refer to Creating eBay Developer Account for details on how to get these credentials.
- Once the file is created, call
CredentialUtil.loadFile(<your-config-location>);
to load the credentials. - It is recommended to load the credentials during startup time (initialization) to prevent runtime delays.
- Once the credentials are loaded, call any operation on
OAuth2Api
There are mainly two types of tokens in usage.
An application token contains an application identity which is generated using client_credentials
grant type. These application tokens are useful for interaction with application specific APIs such as usage statistics etc.,
A user token (access token or refresh token) contains a user identity and the application's identity. This is usually generated using the authorization_code
grant type or the refresh_token
grant type.
All of the regular OAuth 2.0 specifications such as client_credentials
, authorization_code
, and refresh_token
are all supported. Refer to eBay Developer Portal
This grant type can be performed by simply using OAuth2Api.getApplicationToken()
. Read more about this grant type at oauth-client-credentials-grant
This grant type can be performed by a two step process. Call OAuth2Api.generateUserAuthorizationUrl()
to get the Authorization URL to redirect the user to. Once the user authenticates and approves the consent, the callback need to be captured by the redirect URL setup by the app and then call OAuth2Api.exchangeCodeForAccessToken()
to get the refresh and access tokens.
Read more about this grant type at oauth-authorization-code-grant
and oauth-auth-code-grant-request
This grant type can be performed by simply using OAuth2Api.getAccessToken()
. Usually access tokens are short lived and if the access token is expired, the caller can use the refresh token to generate a new access token. Read more about it at Using a refresh token to update a user access token
Contributions in terms of patches, features, or comments are always welcome. Refer to CONTRIBUTING for guidelines. Submit Github issues for any feature enhancements, bugs, or documentation problems as well as questions and comments.
- monolog
- symfony
- https://developer.ebay.com/api-docs/static/oauth-token-types.html
- https://developer.ebay.com/api-docs/static/oauth-tokens.html
- https://developer.ebay.com/my/keys
Copyright (c) 2024 EC Systems Design.
Use of this source code is governed by a Apache-2.0 license that can be found in the LICENSE file or at https://opensource.org/licenses/Apache-2.0.