PHPackages                             playtini/keitaro-client - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [API Development](/categories/api)
4. /
5. playtini/keitaro-client

ActiveLibrary[API Development](/categories/api)

playtini/keitaro-client
=======================

Keitaro Client: Click API, Admin API

2.15.0(1y ago)416.1k↓42.4%4GPL-3.0-onlyPHPPHP ^8.1CI passing

Since Aug 6Pushed 4mo ago2 watchersCompare

[ Source](https://github.com/playtini/keitaro-client)[ Packagist](https://packagist.org/packages/playtini/keitaro-client)[ RSS](/packages/playtini-keitaro-client/feed)WikiDiscussions main Synced 1mo ago

READMEChangelogDependencies (6)Versions (48)Used By (0)

Keitaro PHP Client
==================

[](#keitaro-php-client)

[![](https://camo.githubusercontent.com/842fd473a89cd4d0550e485d639df1d6db6322c6e0aaf1a44cb5eedb8d707d31/687474703a2f2f706f7365722e707567782e6f72672f706c617974696e692f6b65697461726f2d636c69656e742f76657273696f6e)](https://packagist.org/packages/playtini/keitaro-client)[![](https://camo.githubusercontent.com/d0ded8cdd1a4b14c45c0e6ea0ecca3664ed6ad17bd20d7c8f18fddf0aebbc0e6/687474703a2f2f706f7365722e707567782e6f72672f706c617974696e692f6b65697461726f2d636c69656e742f726571756972652f706870)](https://packagist.org/packages/playtini/keitaro-client)[![](https://camo.githubusercontent.com/ce0384c5040905ebd8ed14f7ef38f07668460eb509ff7a3ab4fcde9fda7b4d6c/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f706c617974696e692f6b65697461726f2d636c69656e74)](https://packagist.org/packages/playtini/keitaro-client)[![](https://camo.githubusercontent.com/1011cc6d00a738ace18f1e4963435cf6135bcbdf2acd0e4256aaf373b9fb962c/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6173742d636f6d6d69742f706c617974696e692f6b65697461726f2d636c69656e742f6d61696e)](https://camo.githubusercontent.com/1011cc6d00a738ace18f1e4963435cf6135bcbdf2acd0e4256aaf373b9fb962c/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f6c6173742d636f6d6d69742f706c617974696e692f6b65697461726f2d636c69656e742f6d61696e)[![](https://camo.githubusercontent.com/1c6b179168f0a16ae24e872978c7021fc0080b000febc7a92da676b7784873da/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f616374696f6e732f776f726b666c6f772f7374617475732f706c617974696e692f6b65697461726f2d636c69656e742f746573742e79616d6c3f6272616e63683d6d61696e)](https://camo.githubusercontent.com/1c6b179168f0a16ae24e872978c7021fc0080b000febc7a92da676b7784873da/68747470733a2f2f696d672e736869656c64732e696f2f6769746875622f616374696f6e732f776f726b666c6f772f7374617475732f706c617974696e692f6b65697461726f2d636c69656e742f746573742e79616d6c3f6272616e63683d6d61696e)

[Keitaro](https://keitaro.io) is a tool for affiliate and performance marketing.

It has 2 APIs: Click API, Admin API.

Maintainer
----------

[](#maintainer)

This library is created and supported by [Playtini](https://playtini.ua).

We're hiring marketers (FB, Tiktok, UAC, in-app, Google) and developers (PHP, JS): [playtini.ua/jobs](https://playtini.ua/jobs)

Install
-------

[](#install)

```
composer require playtini/keitaro-client
```

Click API
---------

[](#click-api)

Accept traffic at your server, let Keitaro track and route your traffic.

Click API is available in Pro and Business Keitaro editions.

Click API docs:

-
-
-

Usage:

```
use Playtini\KeitaroClient\ClickApi\KeitaroClickApiClient;
use Playtini\KeitaroClient\ClickApi\KeitaroParams;
use Playtini\KeitaroClient\ClickApi\KeitaroRequest;
use Playtini\KeitaroClient\Http\KeitaroHttpClient;
use Symfony\Component\HttpClient\CurlHttpClient;
use Symfony\Component\HttpFoundation\Request;

require_once(__DIR__ . '/vendor/autoload.php');

$keitaroHttpClient = new KeitaroHttpClient(new CurlHttpClient(), 'https://keitaro.example.com'); // change to your TDS domain
$keitaroRequest = KeitaroRequest::create(Request::createFromGlobals()),
$keitaroParams = KeitaroParams::createFromKeitaroRequest($keitaroRequest, 'CAMPAIGN_TOKEN_HERE'); // change campaign token
$clickApiClient = new KeitaroClickApiClient($keitaroHttpClient, $keitaroRequest, $keitaroParams);
$response = $clickApiClient->createResponse($clickApiClient->getResult());
$response->send();
```

If you don't know campaign token but know campaign alias (unique URL part in TDS link - like [https://keitaro.example.com/THIS\_IS\_ALIAS](https://keitaro.example.com/THIS_IS_ALIAS) ) then use `KeitaroClickApiTokenResolver` to get token via Admin API.

```
use Playtini\KeitaroClient\AdminApi\KeitaroAdminApiClient;
use Playtini\KeitaroClient\ClickApi\KeitaroClickApiTokenResolver;
use Playtini\KeitaroClient\Http\KeitaroHttpClient;
use Symfony\Component\HttpClient\CurlHttpClient;

$keitaroHttpClient = new KeitaroHttpClient(new CurlHttpClient(), 'https://keitaro.example.com'); // change to your TDS domain
$adminClient = new KeitaroAdminApiClient($keitaroHttpClient, 'ADMIN_API_KEY_HERE'); // change api key
$resolver = new KeitaroClickApiTokenResolver($adminClient);
$resolver->getCampaignToken('test-tds')
```

For dependency injection you can use `KeitaroClickApiClientFactory`.

Admin API
---------

[](#admin-api)

View, edit data at Keitaro without using UI.

Admin API is available only in Business Keitaro edition.

Admin API docs:

-
-

Usage:

```
use Playtini\KeitaroClient\AdminApi\KeitaroAdminApiClient;
use Playtini\KeitaroClient\Http\KeitaroHttpClient;
use Symfony\Component\HttpClient\CurlHttpClient;

require_once(__DIR__ . '/vendor/autoload.php');

$keitaroHttpClient = new KeitaroHttpClient(new CurlHttpClient(), 'https://keitaro.example.com'); // change to your TDS domain
$adminClient = new KeitaroAdminApiClient($keitaroHttpClient, 'ADMIN_API_KEY_HERE'); // change api key

print_r($adminClient->campaigns());
```

Warning! Only several endpoints are implemented. If you need more please add an issue, we'll make them sooner.

Symfony config example
----------------------

[](#symfony-config-example)

`config/services.yaml`

```
    Playtini\KeitaroClient\Http\KeitaroHttpClient:
        bind:
            $trackerUrl: '%env(KEITARO_TRACKER_URL)%'

    Playtini\KeitaroClient\AdminApi\KeitaroAdminApiClient:
        bind:
            $adminApiKey: '%env(KEITARO_ADMIN_API_KEY)%'

    Playtini\KeitaroClient\ClickApi\KeitaroClickApiClientFactory: {public: true}
    Playtini\KeitaroClient\ClickApi\KeitaroClickApiTokenResolver: {public: true}
```

```
KEITARO_TRACKER_URL=https://keitaro.example.com
KEITARO_ADMIN_API_KEY=aaa111bbb222aaa111bbb222
```

Don't forget to set real values in environment variables.

Click API controller method

```
public function __invoke(
    string $slug,
    Request $request,
    KeitaroClickApiClientFactory $clientFactory,
    KeitaroClickApiTokenResolver $apiTokenResolver,
): Response
{
    $client = $clientFactory->create(
        request: $request,
        campaignToken: $apiTokenResolver->getCampaignToken($slug), // it's cached
    );
    $client->params->set('log', 1);

    return $client->createResponse($client->getResult());
}
```

Admin API controller method

```
public function __invoke(KeitaroAdminApiClient $keitaroAdminApiClient): JsonResponse
{
    $campaigns = $keitaroAdminApiClient->campaigns();

    $tokens = [];
    foreach ($campaigns as $campaign) {
        $tokens[$campaign->alias] = $campaign->token;
    }

    return new JsonResponse($tokens);
}
```

###  Health Score

46

—

FairBetter than 93% of packages

Maintenance56

Moderate activity, may be stable

Popularity31

Limited adoption so far

Community10

Small or concentrated contributor base

Maturity69

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~15 days

Recently: every ~139 days

Total

47

Last Release

691d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/df3e7060fb5777768e7bb133e98b1e7dfcc788f25fe6dc445acf7036da5c0c3e?d=identicon)[luchaninov](/maintainers/luchaninov)

---

Top Contributors

[![luchaninov](https://avatars.githubusercontent.com/u/3829796?v=4)](https://github.com/luchaninov "luchaninov (71 commits)")

---

Tags

apitdskeitaro

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/playtini-keitaro-client/health.svg)

```
[![Health](https://phpackages.com/badges/playtini-keitaro-client/health.svg)](https://phpackages.com/packages/playtini-keitaro-client)
```

###  Alternatives

[sylius/sylius

E-Commerce platform for PHP, based on Symfony framework.

8.4k5.6M651](/packages/sylius-sylius)[temporal/sdk

Temporal SDK

4002.2M18](/packages/temporal-sdk)[mjaschen/collmex

Collmex PHP SDK

2080.7k](/packages/mjaschen-collmex)[smnandre/pagespeed-api

PageSpeed Insight PHP Api Client 🚀 Analyse web pages for performances metrics, core web vitals...

1511.5k](/packages/smnandre-pagespeed-api)[dragon-code/laravel-json-response

Automatically always return a response in JSON format

1118.6k1](/packages/dragon-code-laravel-json-response)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
