creatissimo/amazon-ads-api 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

creatissimo/amazon-ads-api

最新稳定版本:1.0.13

Composer 安装命令:

composer require creatissimo/amazon-ads-api

包简介

Amazon Advertising API

README 文档

README

Lightweight PHP 8.3 HTTP client for the Amazon Advertising API. Covers OAuth 2.0 authentication, typed request/response models, automatic token refresh, retry with exponential backoff, and optional access-token caching.

Features

  • OAuth 2.0 — authorization code exchange, token refresh, pluggable token cache (FileTokenCache included)
  • Typed models — enums, DTOs with getters/setters, toArray() / fromArray() serialization
  • Full endpoint coverage — Campaigns, Ad Groups, Ads, Targets, Ad Associations, Ad Extensions, Advertising Deals, Brand Stores, Commitments, Recommendations, and more
  • Retry logic — automatic retry with exponential backoff on 429 / 504; token refresh and retry on 401
  • API exceptionsAmazonAdsApiException with HTTP status code, response error code, and message
  • Multi-region — NA, EU, FE base URLs

Requirements

  • PHP ≥ 8.3
  • ext-curl
  • ext-json

Installation

composer require creatissimo/amazon-ads-api

Quick start

use Creatissimo\AmazonAdsApi\Auth\FileTokenCache;
use Creatissimo\AmazonAdsApi\Auth\OAuthClient;
use Creatissimo\AmazonAdsApi\Http\HttpClient;
use Creatissimo\AmazonAdsApi\Api\CampaignsApi;
use Creatissimo\AmazonAdsApi\Model\AdProduct;
use Creatissimo\AmazonAdsApi\Model\CampaignAdProductFilter;
use Creatissimo\AmazonAdsApi\Model\QueryCampaignRequest;

$oauth = new OAuthClient(
    clientId: 'amzn1.application-oa2-client.xxx',
    clientSecret: 'your-secret',
    redirectUri: 'https://your-app.com/callback',
    tokenCache: new FileTokenCache('/tmp/amazon-ads-tokens'),
);

$oauth->setTokens(
    accessToken: 'placeholder',
    refreshToken: 'Atzr|...',
    expiresAt: 0,
);

$http = new HttpClient(
    oauthClient: $oauth,
    clientId: 'amzn1.application-oa2-client.xxx',
    baseUrl: HttpClient::REGION_EU,
    profileId: '123456789',
);

$campaigns = new CampaignsApi($http);

$response = $campaigns->query(new QueryCampaignRequest(
    adProductFilter: new CampaignAdProductFilter(
        include: [AdProduct::SPONSORED_PRODUCTS],
    ),
    maxResults: 10,
));

foreach ($response->getCampaigns() as $campaign) {
    echo $campaign->getName() . PHP_EOL;
}

Available API classes

Class Operations
CampaignsApi create, query, update, delete
AdGroupsApi create, query, update, delete
AdsApi create, query, update, delete
TargetsApi create, query, update, delete
AdAssociationsApi create, query, update, delete
AdExtensionsApi create, query, update
AdvertisingDealsApi create, query, update, delete
AdvertisingDealTargetsApi create, query, delete
BrandStoresApi queryStores, queryPages, queryEditionPublishVersions, updateEditionPublishVersions, listEditions
CommitmentsApi create, list, retrieve, update
CommitmentSpendsApi retrieve
CampaignForecastsApi retrieve
RecommendationsApi create, queryTypes
BrandedKeywordsPricingsApi create
KeywordReservationValidationsApi create

Token caching

Pass any TokenCacheInterface implementation to OAuthClient. A file-based cache is included:

$cache = new FileTokenCache(__DIR__ . '/var/cache/tokens');

$oauth = new OAuthClient(
    clientId: '...',
    clientSecret: '...',
    redirectUri: '...',
    tokenCache: $cache,
);

Implement TokenCacheInterface for Redis, Memcached, database, or PSR-16 adapters.

Error handling

All API methods throw AmazonAdsApiException on non-success responses:

use Creatissimo\AmazonAdsApi\Http\AmazonAdsApiException;

try {
    $campaigns->query($request);
} catch (AmazonAdsApiException $e) {
    $e->getHttpStatusCode();  // 400, 401, 403, ...
    $e->getResponseCode();    // "INVALID_ARGUMENT", ...
    $e->getResponseMessage(); // "Missing required field"
    $e->getResponseBody();    // full response array
}

Retry behaviour

The HTTP client automatically retries on 429 (Too Many Requests) and 504 (Gateway Timeout) with exponential backoff. On 401 (Unauthorized) it refreshes the access token once and retries. Both maxRetries and retryBaseDelay are configurable:

$http = new HttpClient(
    oauthClient: $oauth,
    clientId: '...',
    maxRetries: 5,
    retryBaseDelay: 2.0, // seconds; delays: 2, 4, 8, 16, 32
);

Project structure

src/
├── Api/            # one class per API resource
├── Auth/           # OAuth client, token cache interface + file impl
├── Http/           # HttpClient, ApiResponse, AmazonAdsApiException
├── Model/          # enums, DTOs, query/create/update request models
└── example.php     # runnable usage example

License

Unlicense

统计信息

  • 总下载量: 11
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 5
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: unlicense
  • 更新时间: 2026-02-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固