shidatuo/amazon-sp-api

dev-master 2024-07-20 10:47 UTC

This package is auto-updated.

Last update: 2024-09-20 11:08:13 UTC


README

该项目不再维护。我们建议使用jlevers/selling-partner-api包。

Amazon Selling Partner API PHP

这是Amazon Selling Partner API的PHP API绑定。

这个库基于Amazon提供的OpenAPI文件,并通过贡献者进行了修改。

这个包的目的是通过简单的composer包轻松开始使用Amazon Selling Partner API。

要求

  • PHP >= 7.2
  • cURL扩展
  • JSON扩展
  • MBString扩展

安装

只需通过composer要求这个包

composer require shidatuo/amazon-sp-api

详细文档

您可以在docs/Api目录中找到此PHP库的详细文档(请注意:命名空间和其他类可能已更改)。

您可以在官方Amazon开发者网站上找到有关Amazon Selling Partner API的通用信息。

示例

这些是简单的示例,仅用于向您展示如何开始调用API。

IAM角色

当您在开发者配置文件中输入了IAM角色ARN时使用

<?php

require_once './vendor/autoload.php';

$options = [
    'refresh_token' => '', // Aztr|...
    'client_id' => '', // App ID from Seller Central, amzn1.sellerapps.app.cfbfac4a-......
    'client_secret' => '', // The corresponding Client Secret
    'region' => \Amazon\SpApi\SellingPartnerRegion::$EUROPE, // or NORTH_AMERICA / FAR_EAST
    'access_key' => '', // Access Key of AWS IAM User, for example AKIAABCDJKEHFJDS
    'secret_key' => '', // Secret Key of AWS IAM User
    'endpoint' => \Amazon\SpApi\SellingPartnerEndpoint::$EUROPE, // or NORTH_AMERICA / FAR_EAST
    'role_arn' => '', // AWS IAM Role ARN for example: arn:aws:iam::123456789:role/Your-Role-Name
];
$accessToken = \Amazon\SpApi\SellingPartnerOAuth::getAccessTokenFromRefreshToken(
    $options['refresh_token'],
    $options['client_id'],
    $options['client_secret']
);
$assumedRole = \Amazon\SpApi\AssumeRole::assume(
    $options['region'],
    $options['access_key'],
    $options['secret_key'],
    $options['role_arn'],
);
$config = \Amazon\SpApi\Configuration::getDefaultConfiguration();
$config->setHost($options['endpoint']);
$config->setAccessToken($accessToken);
$config->setAccessKey($assumedRole->getAccessKeyId());
$config->setSecretKey($assumedRole->getSecretAccessKey());
$config->setRegion($options['region']);
$config->setSecurityToken($assumedRole->getSessionToken());
$apiInstance = new \Amazon\SpApi\Api\CatalogApi($config);
$marketplace_id = 'A1PA6795UKMFR9';
$asin = 'B0002ZFTJA';

$result = $apiInstance->getCatalogItem($marketplace_id, $asin);
echo $result->getPayload()->getAttributeSets()[0]->getTitle(); // Never Gonna Give You Up [Vinyl Single]

IAM用户

当您输入了用户ARN而不是角色ARN时,请使用此示例

<?php

require_once './vendor/autoload.php';

$options = [
    'refresh_token' => '', // Aztr|...
    'client_id' => '', // App ID from Seller Central, amzn1.sellerapps.app.cfbfac4a-......
    'client_secret' => '', // The corresponding Client Secret
    'region' => \Amazon\SpApi\SellingPartnerRegion::$EUROPE, // or NORTH_AMERICA / FAR_EAST
    'access_key' => '', // Access Key of AWS IAM User, for example AKIAABCDJKEHFJDS
    'secret_key' => '', // Secret Key of AWS IAM User
    'endpoint' => \Amazon\SpApi\SellingPartnerEndpoint::$EUROPE, // or NORTH_AMERICA / FAR_EAST
];
$accessToken = \Amazon\SpApi\SellingPartnerOAuth::getAccessTokenFromRefreshToken(
    $options['refresh_token'],
    $options['client_id'],
    $options['client_secret']
);
$config = \Amazon\SpApi\Configuration::getDefaultConfiguration();
$config->setHost($options['endpoint']);
$config->setAccessToken($accessToken);
$config->setAccessKey($options['access_key']);
$config->setSecretKey($options['secret_key']);
$config->setRegion($options['region']);
$apiInstance = new \Amazon\SpApi\Api\CatalogApi($config);
$marketplace_id = 'A1PA6795UKMFR9';
$asin = 'B0002ZFTJA';

$result = $apiInstance->getCatalogItem($marketplace_id, $asin);
echo $result->getPayload()->getAttributeSets()[0]->getTitle(); // Never Gonna Give You Up [Vinyl Single]

待办事项

  • 实现测试
  • 改进文档

功能请求和拉取请求非常欢迎!

注意

如果您正在寻找一个完整的再定价和FBA报销解决方案,您可能想尝试ClouSale.com

感谢

感谢所有为这个包添加PR和工作的人。