playtini / keitaro-client
Keitaro 客户端:点击 API,管理 API
2.15.0
2024-06-26 16:11 UTC
Requires
- php: ^8.1
- gupalo/dateutils: ^1.13
- gupalo/json: ^1.0
- psr/cache: ^3.0
- symfony/http-client: ^6.1|^7.0
- symfony/http-foundation: ^6.1|^7.0
Requires (Dev)
- phpunit/phpunit: ^10.5
- dev-main
- 2.15.0
- 2.14.0
- 2.13.3
- 2.13.2
- 2.13.1
- 2.13.0
- 2.12.0
- 2.11.1
- 2.11.0
- 2.10.0
- 2.9.0
- 2.8.0
- 2.7.6
- 2.7.5
- 2.7.4
- 2.7.3
- 2.7.2
- 2.7.1
- 2.7.0
- 2.6.10
- 2.6.9
- 2.6.8
- 2.6.7
- 2.6.6
- 2.6.5
- 2.6.4
- 2.6.3
- 2.6.2
- 2.6.1
- 2.6.0
- 2.5.0
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- 2.3.6
- 2.3.5
- 2.3.4
- 2.3.3
- 2.3.2
- 2.3.1
- 2.3.0
- 2.2.0
- 2.1.1
- 2.1.0
- 2.0.0
This package is auto-updated.
Last update: 2024-09-26 16:36:07 UTC
README
Keitaro 是一个用于联盟和效果营销的工具。
它有 2 个 API:点击 API,管理 API。
维护者
该库由 Playtini 创建和支持。
我们正在招聘市场营销人员(FB、Tiktok、UAC、应用内、Google)和开发者(PHP、JS):playtini.ua/jobs
安装
composer require playtini/keitaro-client
点击 API
在您的服务器上接受流量,让 Keitaro 跟踪和路由您的流量。
点击 API 在 Pro 和 Business Keitaro 版本中可用。
点击 API 文档
- https://docs.keitaro.io/en/development/click-api.html
- https://docs.keitaro.io/en/campaign-integrations/kclient-php.html
- https://blog.keitaro.io/en/kclient-php-an-in-depth-article/
使用方法
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();
如果您不知道活动令牌但知道活动别名(TDS 链接中的唯一 URL 部分 - 例如 https://keitaro.example.com/THIS_IS_ALIAS )则可以使用 KeitaroClickApiTokenResolver
通过管理 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')
对于依赖注入,您可以使用 KeitaroClickApiClientFactory
。
管理 API
在不使用 UI 的情况下查看和编辑 Keitaro 的数据。
管理 API 仅在 Business Keitaro 版本中可用。
管理 API 文档
使用方法
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());
警告!仅实现了几个端点。如果您需要更多,请提交问题,我们将尽快实现。
Symfony 配置示例
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
请勿忘记在环境变量中设置实际值。
点击 API 控制器方法
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()); }
管理 API 控制器方法
public function __invoke(KeitaroAdminApiClient $keitaroAdminApiClient): JsonResponse { $campaigns = $keitaroAdminApiClient->campaigns(); $tokens = []; foreach ($campaigns as $campaign) { $tokens[$campaign->alias] = $campaign->token; } return new JsonResponse($tokens); }