Amazon Product Advertising API Request Builder

Additional

Language
Java
Version
N/A
Created
Oct 8, 2016
Updated
Sep 7, 2019 (Retired)
Owner
Ingo Schwarz (ISchwarz23)
Contributor
Ingo Schwarz (ISchwarz23)
1
Activity
Badge
Generate
Download
Source code

Advertisement

The Amazon-Product-Advertising-API URL Builder

Simple builder in plain Java to create requests to the Amazon Product Advertising API.


Amazon challenges all developers that want to use their Advertising API. Especially the creation of the request URL is pretty complex. Therefor I've created this URL Builder, which allows you to create the request URL without having to read the Product Advertisement API documentation or study the used hashing algorithms.

Setup

To use this library in your Java or Android project you can download it from jCenter (GroupId: de.codecrafters.apaarb, ArtifactId: apaarb) in the latest version. If you use gradle add jCenter() to your repositories (if not done yet) and specify the dependency.

dependencies {
    ...
    compile 'de.codecrafters.apaarb:apaarb:0.9.1'
    ...
}

This library is written in plain java and does not depend on any other library.

Item Identification

There are multiple types of ID representations handled by Amazon. Namely they are ASIN, ISBN, UPX and EAN. So especially if you want to look up a specific item you have to give its ID.
Theses IDs are represented inside this library by the ItemId class. To create them you simply call the matching create- method.

ItemId myAsin = ItemId.createAsin("AsinValue");
ItemId myEan  = ItemId.createEan("EanValue");
ItemId myIsbn = ItemId.createIsbn("IsbnValue");
ItemId myUpx  = ItemId.createUpx("UpxValue");

After the creation you are able to get the ID value and type from the object.

String value = myId.getValue();
Type type = myId.getType();

The Type is an enumeration inside the ItemId class listing all the available ID types.

Authentication

If you do any request to the Amazon Product Advertising API you have to authenticate yourself. This authentication consists of an "Associate Tag", an "AWS Access Key" and an "AWS Secret Key". In this library they are grouped inside a data class called AmazonWebServiceAuthentication. This class can easily created using the factory method.

AmazonWebServiceAuthentication myAuthentication = AmazonWebServiceAuthentication create("myAssociateTag", "myAwsAccessKey", "myAwsSecretKey");

These user authentication can be used in multiple requests.

Service Location

Amazon distinguishes its services by location (countries). So you will get different responses for different locations (e.g. the currency, the available products, ...). You also have to set up your account for every location. To simplify the selection of the service this library contains an enumeration called AmazonWebServiceLocation, which contains all available service locations.

// America
AmazonWebServiceLocation.COM
// Germany
AmazonWebServiceLocation.DE
// ...

Item Lookup

Basic Request

If you want to lookup specific item information from Amazon you can do so by creating an Request using the AmazonProductAdvertisingApiRequestBuilder. You create a request builder for an item lookup by giving the ItemId of the item to search for. To create the request url you have to give the AmazonWebServiceLocation that shall be requested and the AmazonWebServiceAuthentication that shall be used.

final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

The result is a request URL as String, that can be used to do the request with your favourite http request library. The result of the createRequestUrlFor() method will create a http link. If you prefer the https protocol in your url, simply call the createSecureRequestUrlFor().

final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .createSecureRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

Specify the included Item Information

You also have the possibility to specify which item information will be returned by the amazon service when calling the request URL. This can be done using the ItemInformation enumeration, which lists all available item information categories. If you don't pass anything the request builder will add information about the item attributes to the request.

// static import was used for ItemInformation
final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .includeInformationAbout(ATTRIBUTES)
                .includeInformationAbout(OFFERS)
                .includeInformationAbout(IMAGES)
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

Filter the Result

If you want to specify the result set, there is the possibility to do so by filtering the results by the condition of the products. All available conditions are listed inside the ItemCondition enumeration. An example usage is shown below.

// static import was used for ItemInformation and ItemCondition
final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .includeInformationAbout(ATTRIBUTES)
                .includeInformationAbout(OFFERS)
                .includeInformationAbout(IMAGES)
                .filterByCondition(NEW)
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

Item Search

Basic Request

To do a basic item search request by keywords to Amazon you can do so by creating an Request using the AmazonProductAdvertisingApiRequestBuilder. You create a request builder for an item lookup by giving the keywords that shall be searched for as string (spaces are allowed). To create the request url you have to give the again the AmazonWebServiceLocation that shall be requested and the AmazonWebServiceAuthentication that shall be used.

final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemSearch("Deadpool Movie")
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

The result is a request URL as String, that can be used to do the request with your favourite http request library. The result of the createRequestUrlFor() method will create a http link. If you prefer the https protocol in your url, simply call the createSecureRequestUrlFor().

final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .createSecureRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

Specify the included Item Information

You also have the possibility to specify which item information will be returned by the amazon service when calling the request URL. This can be done using the ItemInformation enumeration, which lists all available item information categories. If you don't pass anything the request builder will add information about the item attributes to the request.

// static import was used for ItemInformation
final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemSearch("Deadpool Movie")
                .includeInformationAbout(ATTRIBUTES)
                .includeInformationAbout(OFFERS)
                .includeInformationAbout(IMAGES)
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);

Filter the Result

If you want to specify the result set, there is the possibility to do so by filtering the results by the condition, the category, the minimum, as well as the maximum price of the items/products. All available conditions are listed inside the ItemCondition enumeration. The available categories are inside the enumeration called ItemCategory. To filter by minimum and maximum price you have to give an integer representing the price in the smallest currency unit of the given location. An example usage is shown below. This filters can be used separately as well as in combination.

// static import was used for ItemInformation and ItemCondition
final String requestUrl = AmazonProductAdvertisingApiRequestBuilder.forItemLookup(ITEM_ID)
                .includeInformationAbout(ATTRIBUTES)
                .includeInformationAbout(OFFERS)
                .includeInformationAbout(IMAGES)
                .filterByCondition(NEW)
                .filterByCategroy(DVD)
                .filterByMinimumPrice(10000)
                .filterByMaximumPrice(30000)
                .createRequestUrlFor(AmazonWebServiceLocation.COM, authentication);