Bitbucket API 2.0 client for PHP
We present a modern Bitbucket API 2.0 client for PHP.
- GitHub - knplabs/github-api by KnpLabs.
- GitLab - m4tthumphrey/php-gitlab-api by Matt Humphrey et al.
- Bitbucket - bitbucket/client which is this package!
This version supports PHP 7.1-7.4. To get started, simply require the project using Composer. You will also need to install packages that "provide"
$ composer require bitbucket/client:^3.1 php-http/guzzle6-adapter:^2.0.1 http-interop/http-factory-guzzle:^1.0
$ composer require bitbucket/client:^3.1 guzzlehttp/guzzle:^7.0.1 http-interop/http-factory-guzzle:^1.0
$ composer require graham-campbell/bitbucket:^7.1 guzzlehttp/guzzle:^7.0.1 http-interop/http-factory-guzzle:^1.0
We are decoupled from any HTTP messaging client by using PSR-7, PSR-17, PSR-18, and HTTPlug. You can visit HTTPlug for library users to get more information about installing HTTPlug related packages. The framework integration
graham-campbell/bitbucket is by Graham Campbell.
The main point of entry is the
Bitbucket\Client class. Simply create a new instance of that, authenticate, and you're good to go! As of time of writing (Tuesday 29th June 2020), every endpoint (excluding issue export and import, and various deprecated endpoints) available on the Bitbucket API 2.0 is also available through this PHP client. We'd recommend looking through the Bitbucket documentation, and also the source code to get a full picture of what is available to use.
There are three ways to authenticate our client:
The most common way to authenticate is using an OAuth 2 token. You will need to generate this by some means outside of the library, and then provide it as below:
$client = new Bitbucket\Client(); $client->authenticate( Bitbucket\Client::AUTH_OAUTH_TOKEN, 'your-token-here' );
It is possible to login using a username and password combination. This method is not recommended for production use, however you may find it useful never the less:
$client = new Bitbucket\Client(); $client->authenticate( Bitbucket\Client::AUTH_HTTP_PASSWORD, 'your-username-here', 'your-password-here' );
Finally, we support logging in using JSON web tokens (JWTs). This method is exclusively required by some of Bitbucket's API endpoints, such as the addons API. Generate your JWT, perahps using lcobucci/jwt, then provide it as below:
$client = new Bitbucket\Client(); $client->authenticate( Bitbucket\Client::AUTH_JWT, 'your-jwt-here' );
In the following examples,
$client will be an authenticated client, as above.
It is possible to show basic information about the currently logged in user:
$currentUser = $client->currentUser()->show();
It is possible to grab a repository as follows:
$repository = $client->repositories() ->workspaces('atlassian') ->show('stash-example-plugin');
We support automatic pagination without you having to lift a finger. The following example gets all branches of a repository:
$paginator = new Bitbucket\ResultPager($client); $branchesClient = $client->repositories() ->workspaces('atlassianlabs') ->refs('stash-log-parser']) ->branches(); $branches = $paginator->fetchAll($branchesClient, 'list');
$ make install $ make test
If you discover a security vulnerability within this package, please send an email to Graham Campbell at firstname.lastname@example.org. All security vulnerabilities will be promptly addressed. You may view our full security policy here.
Bitbucket PHP API Client is licensed under The MIT License (MIT).
Available as part of the Tidelift Subscription
The maintainers of
bitbucket/client and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more.