Code Monkey home page Code Monkey logo

amazon-mws-laravel's Introduction

Build Status StyleCI

Amazon MWS for Laravel

============

Planning to migrate to the new Selling Partner API? Have a look at our PHP SDK for Amazon's Selling Partner API, as well as our Laravel wrapper.

A Laravel package to connect to Amazon's Merchant Web Services (MWS).

If you are using Laravel 6 or lower, use version 5.0. On Laravel 7, use version 7.0+.

This is NOT for Amazon Web Services (AWS) - Cloud Computing Services.

Installation

Install the package using composer require keithbrink/amazon-mws-laravel.

For Laravel 5.5 and up, the package will be automatically discovered. For other versions, you can add KeithBrink\AmazonMws\MwsServiceProvider to your config/app.php file.

Run php artisan vendor:publish --provider="KeithBrink\AmazonMws\MwsServiceProvider" --tag="config" to add the amazon-mws.php config file to your config directory.

Usage

The general work flow for using one of the objects is this:

  1. Create an object for the task you need to perform.
  2. Load it up with parameters, depending on the object, using set____ methods.
  3. Submit the request to Amazon. The methods to do this are usually named fetch____ or submit____ and have no parameters.
  4. Reference the returned data, whether as single values or in bulk, using get____ methods.
  5. Monitor the performance of the library using the built-in logging system.

Note that if you want to act on more than one Amazon store, you will need a separate object for each store.

Also note that the objects perform best when they are not treated as reusable. Otherwise, you may end up grabbing old response data if a new request fails.

If you want to learn how to use a specific function, the best way is to read the comments above the function; they are detailed and helpful.

Dynamic Config

If you would like to change the configuration info used in an Amazon call to something other than the info in the config file, you can add the setConfig($config) function to any call. The $config parameter should be an array following this template:

$config = [
    'merchantId' => '',
    'marketplaceId' => '',
    'keyId' => '',
    'secretKey' => '',
    'amazonServiceUrl' => '',
];

Example Usage

Here are a couple of examples of the library in use.

Here is an example of a function used to get all warehouse-fulfilled orders from Amazon updated in the past 24 hours:

use KeithBrink\AmazonMws\AmazonOrderList;

function getAmazonOrders() {
    $amz = new AmazonOrderList("myStore"); //store name matches the array key in the config file
    $amz->setLimits('Modified', "- 24 hours");
    $amz->setFulfillmentChannelFilter("MFN"); //no Amazon-fulfilled orders
    $amz->setOrderStatusFilter(
        array("Unshipped", "PartiallyShipped", "Canceled", "Unfulfillable")
        ); //no shipped or pending
    $amz->setUseToken(); //Amazon sends orders 100 at a time, but we want them all
    $amz->fetchOrders();
    
    $orders = [];
    foreach($amz->getList() as $order) {
        $orders = $order->getData();
    }
    return $orders;
}

This example shows a function used to send a previously-created XML feed to Amazon to update Inventory numbers, and includes an example of a dynamic config:

use KeithBrink\AmazonMws\AmazonFeed;

function sendInventoryFeed($feed) {
    $config = [
        'merchantId' => '',
        'marketplaceId' => '',
        'keyId' => '',
        'secretKey' => '',
        'amazonServiceUrl' => '',
    ];

    $amz = new AmazonFeed("myStore"); //store name matches the array key in the config file
    $amz->setConfig($config);
    $amz->setFeedType("_POST_INVENTORY_AVAILABILITY_DATA_"); //feed types listed in documentation
    $amz->setFeedContent($feed);
    $amz->submitFeed();
    return $amz->getResponse();
}

Credits

This package was forked from: https://github.com/sonnenglas/amazon-mws-laravel

which was forked from: https://github.com/creacoon/amazon-mws-laravel

which was forked from: https://github.com/CPIGroup/phpAmazonMWS

who is the original creator of this package.

amazon-mws-laravel's People

Contributors

a349944418 avatar carl689 avatar eliaskotlyar avatar ennnnny avatar erayalakese avatar forgueam avatar fromthecove avatar gitmastro avatar jeyasithar avatar keithbrink avatar mikevrind avatar mohamedziada avatar mondstaubug avatar pdbreen avatar peardian avatar przemekperon avatar ruskiyos avatar spire-mike avatar stylecibot avatar tgrantmartin-fcs avatar tomcoonen avatar vaneavasco avatar zjbarg avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.