Richemont.Booster2.PublicApi

<back to all web services

ExportSellOut

Requires Authentication
The following routes are available for this service:
POST/warranty/{brand}/exportExport Sell-Out DataCreate a sell-out in a POS you are authorised for
import java.math.*
import java.util.*
import net.servicestack.client.*
import com.google.gson.annotations.*
import com.google.gson.reflect.*


open class ExportSellOut
{
    /**
    * Brand Trigram, e.g. CAR, IWC
    */
    @ApiMember(Description="Brand Trigram, e.g. CAR, IWC", IsRequired=true)
    var brand:String? = null

    /**
    * Pos Legacy IDs / Codes
    */
    @ApiMember(Description="Pos Legacy IDs / Codes", IsRequired=true)
    var posCodes:ArrayList<String> = ArrayList<String>()

    /**
    * Date To
    */
    @ApiMember(Description="Date To")
    var dateTo:Date? = null

    /**
    * Date From
    */
    @ApiMember(Description="Date From")
    var dateFrom:Date? = null

    /**
    * Item Article Codes, both Global and Local
    */
    @ApiMember(Description="Item Article Codes, both Global and Local")
    var articleCodes:ArrayList<String> = ArrayList<String>()

    /**
    * Product Categories
    */
    @ApiMember(Description="Product Categories")
    var productCategories:ArrayList<ProductCategory> = ArrayList<ProductCategory>()

    /**
    * Sale Representative Email
    */
    @ApiMember(Description="Sale Representative Email")
    var saleRepresentativeEmails:ArrayList<String> = ArrayList<String>()

    /**
    * Sellout Type: 'sellout' for sales, 'return' for returns, null for both
    */
    @ApiMember(Description="Sellout Type: 'sellout' for sales, 'return' for returns, null for both")
    var selloutType:String? = null

    /**
    * Type: 'consigned' or 'standard', null for both
    */
    @ApiMember(Description="Type: 'consigned' or 'standard', null for both")
    @SerializedName("type") var Type:String? = null

    /**
    * Possible warranty extention status IDs, 1 (Activated), 2 (Requested), 3 (Refused), 4 (Error)
    */
    @ApiMember(Description="Possible warranty extention status IDs, 1 (Activated), 2 (Requested), 3 (Refused), 4 (Error)")
    var warrantyExtensionStatusIds:ArrayList<Int> = ArrayList<Int>()

    /**
    * Export Request ID of the API Consumers
    */
    @ApiMember(Description="Export Request ID of the API Consumers", IsRequired=true)
    var downloadRequestId:String? = null
}

open class ProductCategory
{
    /**
    * Brand Category ID
    */
    @ApiMember(Description="Brand Category ID")
    var brandCategoryId:String? = null

    /**
    * Grand Category ID
    */
    @ApiMember(Description="Grand Category ID", IsRequired=true)
    var grandCategoryId:String? = null

    /**
    * Master Category ID
    */
    @ApiMember(Description="Master Category ID")
    var masterCategoryId:String? = null

    /**
    * Category ID
    */
    @ApiMember(Description="Category ID")
    var categoryId:String? = null

    /**
    * Sub Category ID
    */
    @ApiMember(Description="Sub Category ID")
    var subCategoryId:String? = null
}

open class ExportSellOutResponse
{
    /**
    * Unique Identifier of the Export Request created
    */
    @ApiMember(Description="Unique Identifier of the Export Request created", IsRequired=true)
    var asyncTaskId:UUID? = null
}

Kotlin ExportSellOut DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv

HTTP + JSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /warranty/{brand}/export HTTP/1.1 
Host: dev-api-booster.richemont.com 
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length

{
	brand: String,
	posCodes: 
	[
		String
	],
	dateTo: 0001-01-01,
	dateFrom: 0001-01-01,
	articleCodes: 
	[
		String
	],
	productCategories: 
	[
		{
			brandCategoryId: String,
			grandCategoryId: String,
			masterCategoryId: String,
			categoryId: String,
			subCategoryId: String
		}
	],
	saleRepresentativeEmails: 
	[
		String
	],
	selloutType: String,
	type: String,
	warrantyExtensionStatusIds: 
	[
		0
	],
	downloadRequestId: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length

{
	asyncTaskId: 00000000000000000000000000000000
}