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
<?php namespace dtos;

use DateTime;
use Exception;
use DateInterval;
use JsonSerializable;
use ServiceStack\{IReturn,IReturnVoid,IGet,IPost,IPut,IDelete,IPatch,IMeta,IHasSessionId,IHasBearerToken,IHasVersion};
use ServiceStack\{ICrud,ICreateDb,IUpdateDb,IPatchDb,IDeleteDb,ISaveDb,AuditBase,QueryDb,QueryDb2,QueryData,QueryData2,QueryResponse};
use ServiceStack\{ResponseStatus,ResponseError,EmptyResponse,IdResponse,ArrayList,KeyValuePair2,StringResponse,StringsResponse,Tuple2,Tuple3,ByteArray};
use ServiceStack\{JsonConverters,Returns,TypeContext};


class ExportSellOutResponse implements JsonSerializable
{
    public function __construct(
        /** @description Unique Identifier of the Export Request created */
        // @ApiMember(Description="Unique Identifier of the Export Request created", IsRequired=true)
        /** @var string */
        public string $asyncTaskId=''
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['asyncTaskId'])) $this->asyncTaskId = $o['asyncTaskId'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->asyncTaskId)) $o['asyncTaskId'] = $this->asyncTaskId;
        return empty($o) ? new class(){} : $o;
    }
}

class ProductCategory implements JsonSerializable
{
    public function __construct(
        /** @description Brand Category ID */
        // @ApiMember(Description="Brand Category ID")
        /** @var string|null */
        public ?string $brandCategoryId=null,

        /** @description Grand Category ID */
        // @ApiMember(Description="Grand Category ID", IsRequired=true)
        /** @var string */
        public string $grandCategoryId='',

        /** @description Master Category ID */
        // @ApiMember(Description="Master Category ID")
        /** @var string|null */
        public ?string $masterCategoryId=null,

        /** @description Category ID */
        // @ApiMember(Description="Category ID")
        /** @var string|null */
        public ?string $categoryId=null,

        /** @description Sub Category ID */
        // @ApiMember(Description="Sub Category ID")
        /** @var string|null */
        public ?string $subCategoryId=null
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['brandCategoryId'])) $this->brandCategoryId = $o['brandCategoryId'];
        if (isset($o['grandCategoryId'])) $this->grandCategoryId = $o['grandCategoryId'];
        if (isset($o['masterCategoryId'])) $this->masterCategoryId = $o['masterCategoryId'];
        if (isset($o['categoryId'])) $this->categoryId = $o['categoryId'];
        if (isset($o['subCategoryId'])) $this->subCategoryId = $o['subCategoryId'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->brandCategoryId)) $o['brandCategoryId'] = $this->brandCategoryId;
        if (isset($this->grandCategoryId)) $o['grandCategoryId'] = $this->grandCategoryId;
        if (isset($this->masterCategoryId)) $o['masterCategoryId'] = $this->masterCategoryId;
        if (isset($this->categoryId)) $o['categoryId'] = $this->categoryId;
        if (isset($this->subCategoryId)) $o['subCategoryId'] = $this->subCategoryId;
        return empty($o) ? new class(){} : $o;
    }
}

class ExportSellOut implements JsonSerializable
{
    public function __construct(
        /** @description Brand Trigram, e.g. CAR, IWC */
        // @ApiMember(Description="Brand Trigram, e.g. CAR, IWC", IsRequired=true)
        /** @var string */
        public string $brand='',

        /** @description Pos Legacy IDs / Codes */
        // @ApiMember(Description="Pos Legacy IDs / Codes", IsRequired=true)
        /** @var array<string>|null */
        public ?array $posCodes=null,

        /** @description Date To */
        // @ApiMember(Description="Date To")
        /** @var DateTime|null */
        public ?DateTime $dateTo=null,

        /** @description Date From */
        // @ApiMember(Description="Date From")
        /** @var DateTime|null */
        public ?DateTime $dateFrom=null,

        /** @description Item Article Codes, both Global and Local */
        // @ApiMember(Description="Item Article Codes, both Global and Local")
        /** @var array<string>|null */
        public ?array $articleCodes=null,

        /** @description Product Categories */
        // @ApiMember(Description="Product Categories")
        /** @var array<ProductCategory>|null */
        public ?array $productCategories=null,

        /** @description Sale Representative Email */
        // @ApiMember(Description="Sale Representative Email")
        /** @var array<string>|null */
        public ?array $saleRepresentativeEmails=null,

        /** @description 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 string|null */
        public ?string $selloutType=null,

        /** @description Type: 'consigned' or 'standard', null for both */
        // @ApiMember(Description="Type: 'consigned' or 'standard', null for both")
        /** @var string|null */
        public ?string $type=null,

        /** @description 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 array<int>|null */
        public ?array $warrantyExtensionStatusIds=null,

        /** @description Export Request ID of the API Consumers */
        // @ApiMember(Description="Export Request ID of the API Consumers", IsRequired=true)
        /** @var string */
        public string $downloadRequestId=''
    ) {
    }

    /** @throws Exception */
    public function fromMap($o): void {
        if (isset($o['brand'])) $this->brand = $o['brand'];
        if (isset($o['posCodes'])) $this->posCodes = JsonConverters::fromArray('string', $o['posCodes']);
        if (isset($o['dateTo'])) $this->dateTo = JsonConverters::from('DateTime', $o['dateTo']);
        if (isset($o['dateFrom'])) $this->dateFrom = JsonConverters::from('DateTime', $o['dateFrom']);
        if (isset($o['articleCodes'])) $this->articleCodes = JsonConverters::fromArray('string', $o['articleCodes']);
        if (isset($o['productCategories'])) $this->productCategories = JsonConverters::fromArray('ProductCategory', $o['productCategories']);
        if (isset($o['saleRepresentativeEmails'])) $this->saleRepresentativeEmails = JsonConverters::fromArray('string', $o['saleRepresentativeEmails']);
        if (isset($o['selloutType'])) $this->selloutType = $o['selloutType'];
        if (isset($o['type'])) $this->type = $o['type'];
        if (isset($o['warrantyExtensionStatusIds'])) $this->warrantyExtensionStatusIds = JsonConverters::fromArray('int', $o['warrantyExtensionStatusIds']);
        if (isset($o['downloadRequestId'])) $this->downloadRequestId = $o['downloadRequestId'];
    }
    
    /** @throws Exception */
    public function jsonSerialize(): mixed
    {
        $o = [];
        if (isset($this->brand)) $o['brand'] = $this->brand;
        if (isset($this->posCodes)) $o['posCodes'] = JsonConverters::toArray('string', $this->posCodes);
        if (isset($this->dateTo)) $o['dateTo'] = JsonConverters::to('DateTime', $this->dateTo);
        if (isset($this->dateFrom)) $o['dateFrom'] = JsonConverters::to('DateTime', $this->dateFrom);
        if (isset($this->articleCodes)) $o['articleCodes'] = JsonConverters::toArray('string', $this->articleCodes);
        if (isset($this->productCategories)) $o['productCategories'] = JsonConverters::toArray('ProductCategory', $this->productCategories);
        if (isset($this->saleRepresentativeEmails)) $o['saleRepresentativeEmails'] = JsonConverters::toArray('string', $this->saleRepresentativeEmails);
        if (isset($this->selloutType)) $o['selloutType'] = $this->selloutType;
        if (isset($this->type)) $o['type'] = $this->type;
        if (isset($this->warrantyExtensionStatusIds)) $o['warrantyExtensionStatusIds'] = JsonConverters::toArray('int', $this->warrantyExtensionStatusIds);
        if (isset($this->downloadRequestId)) $o['downloadRequestId'] = $this->downloadRequestId;
        return empty($o) ? new class(){} : $o;
    }
}

PHP ExportSellOut DTOs

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

HTTP + CSV

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/csv
Content-Type: text/csv
Content-Length: length

{"brand":"String","posCodes":["String"],"dateTo":"\/Date(-62135596800000-0000)\/","dateFrom":"\/Date(-62135596800000-0000)\/","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/csv
Content-Length: length

{"asyncTaskId":"00000000000000000000000000000000"}