| POST | /stock/{brand}/export | Export Stock Data |
|---|
using System;
using System.Collections;
using System.Collections.Generic;
using System.Runtime.Serialization;
using ServiceStack;
using ServiceStack.DataAnnotations;
using Richemont.Booster2.PublicApi.Stock.ServiceModel;
using Richemont.Booster2.PublicApi.Common.ServiceModel;
namespace Richemont.Booster2.PublicApi.Common.ServiceModel
{
public partial class ProductCategory
{
///<summary>
///Brand Category ID
///</summary>
[ApiMember(Description="Brand Category ID")]
public virtual string brandCategoryId { get; set; }
///<summary>
///Grand Category ID
///</summary>
[ApiMember(Description="Grand Category ID", IsRequired=true)]
public virtual string grandCategoryId { get; set; }
///<summary>
///Master Category ID
///</summary>
[ApiMember(Description="Master Category ID")]
public virtual string masterCategoryId { get; set; }
///<summary>
///Category ID
///</summary>
[ApiMember(Description="Category ID")]
public virtual string categoryId { get; set; }
///<summary>
///Sub Category ID
///</summary>
[ApiMember(Description="Sub Category ID")]
public virtual string subCategoryId { get; set; }
}
}
namespace Richemont.Booster2.PublicApi.Stock.ServiceModel
{
public partial class ExportStock
: StockRequest
{
public ExportStock()
{
productCategories = new List<ProductCategory>{};
}
///<summary>
///Product Categories
///</summary>
[ApiMember(Description="Product Categories")]
public virtual List<ProductCategory> productCategories { get; set; }
///<summary>
///Export Request ID of the API Consumers
///</summary>
[ApiMember(Description="Export Request ID of the API Consumers", IsRequired=true)]
public virtual string downloadRequestId { get; set; }
}
public partial class ExportStockResponse
{
///<summary>
///Unique Identifier of the Export Request created
///</summary>
[ApiMember(Description="Unique Identifier of the Export Request created", IsRequired=true)]
public virtual Guid asyncTaskId { get; set; }
}
public partial class StockRequest
{
public StockRequest()
{
posCodes = new List<string>{};
articleCodes = new List<string>{};
clusterIds = new List<string>{};
}
///<summary>
///Brand
///</summary>
[ApiMember(Description="Brand", IsRequired=true)]
public virtual string brand { get; set; }
///<summary>
///POS Legacy
///</summary>
[ApiMember(Description="POS Legacy")]
public virtual List<string> posCodes { get; set; }
///<summary>
///Article Codes
///</summary>
[ApiMember(Description="Article Codes")]
public virtual List<string> articleCodes { get; set; }
///<summary>
///Include Extra Info
///</summary>
[ApiMember(Description="Include Extra Info")]
public virtual bool includeExtraInfo { get; set; }
///<summary>
///Cluster Id
///</summary>
[ApiMember(Description="Cluster Id")]
public virtual List<string> clusterIds { get; set; }
///<summary>
///Include Consignment NotAuthorized POS
///</summary>
[ApiMember(Description="Include Consignment NotAuthorized POS")]
public virtual bool includeConsignmentNotAuthorizedPOS { get; set; }
///<summary>
///Include Retail Sales Price in the Output, by default: false
///</summary>
[ApiMember(Description="Include Retail Sales Price in the Output, by default: false")]
public virtual bool includeRSP { get; set; }
///<summary>
///In Stock Since date from
///</summary>
[ApiMember(Description="In Stock Since date from ")]
public virtual DateTime? dateFrom { get; set; }
///<summary>
///In Stock Since date to
///</summary>
[ApiMember(Description="In Stock Since date to")]
public virtual DateTime? dateTo { get; set; }
///<summary>
///Item type, 'standard' OR 'consigned'. By default, all are coming
///</summary>
[ApiMember(Description="Item type, 'standard' OR 'consigned'. By default, all are coming")]
public virtual string type { get; set; }
}
}
To override the Content-type in your clients, use the HTTP Accept Header, append the .jsv suffix or ?format=jsv
The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.
POST /stock/{brand}/export HTTP/1.1
Host: dev-api-booster.richemont.com
Accept: text/jsv
Content-Type: text/jsv
Content-Length: length
{
productCategories:
[
{
brandCategoryId: String,
grandCategoryId: String,
masterCategoryId: String,
categoryId: String,
subCategoryId: String
}
],
downloadRequestId: String,
brand: String,
posCodes:
[
String
],
articleCodes:
[
String
],
includeExtraInfo: False,
clusterIds:
[
String
],
includeConsignmentNotAuthorizedPOS: False,
includeRSP: False,
dateFrom: 0001-01-01,
dateTo: 0001-01-01,
type: String
}
HTTP/1.1 200 OK
Content-Type: text/jsv
Content-Length: length
{
asyncTaskId: 00000000000000000000000000000000
}