wb-api-client
Version:
Typescript API для Wildberries, сгенерированное из Swagger. Без внешних зависимостей.
822 lines (766 loc) • 27.3 kB
text/typescript
/* eslint-disable */
/* tslint:disable */
/*
* ---------------------------------------------------------------
* ## THIS FILE WAS GENERATED VIA SWAGGER-TYPESCRIPT-API ##
* ## ##
* ## AUTHOR: acacode ##
* ## SOURCE: https://github.com/acacode/swagger-typescript-api ##
* ---------------------------------------------------------------
*/
import { ResponseBodyContentError400, ResponseBodyContentError403 } from "./content";
export interface PromotionsGoodsList {
/**
* ID номенклатуры
* @example 162579635
*/
id?: number;
/**
* Участвует в акции:
* - `true` — да
* - `false` — нет
* @example true
*/
inAction?: boolean;
/**
* Текущая розничная цена
* @format float
* @example 1500
*/
price?: number;
/**
* Валюта в формате ISO 4217
* @example "RUB"
*/
currencyCode?: string;
/**
* Плановая цена (цена во время акции)
* @format float
* @example 1000
*/
planPrice?: number;
/**
* Текущая скидка
* @example 15
*/
discount?: number;
/**
* Рекомендуемая скидка для участия в акции
* @example 34
*/
planDiscount?: number;
}
export interface ResponseError {
data?: object | null;
error?: boolean;
errorText?: string;
}
export interface TaskAlreadyExistsError {
data?: {
/** ID загрузки */
id?: number;
/** Флаг дублирования загрузки: `true` — такая загрузка уже есть */
alreadyExists?: boolean;
};
/** Флаг ошибки */
error?: boolean;
/** Текст ошибки */
errorText?: string;
}
export interface TaskCreated {
data?: {
/** ID загрузки */
id?: number;
/**
* Флаг дублирования загрузки: `true` — такая загрузка уже есть
* @example false
*/
alreadyExists?: boolean;
};
/**
* Флаг ошибки
* @example false
*/
error?: boolean;
/**
* Текст ошибки
* @example ""
*/
errorText?: string;
}
/**
* Товары, цены и скидки для них. Максимум 1 000 товаров. Цена и скидка не могут быть пустыми одновременно.
* <br><br>
* Если новая цена со скидкой будет хотя бы в 3 раза меньше старой, она попадёт [в карантин](https://seller.wildberries.ru/discount-and-prices/quarantine) и товар будет продаваться по старой цене. Ошибка об этом будет в ответах методов [Состояния загрузок](./#tag/Sostoyaniya-zagruzok)
* <br><br>
* Вы можете изменить цену или скидку с помощью API либо вывести товар из карантина [в личном кабинете](https://seller.wildberries.ru/discount-and-prices/quarantine)
*/
export type Goods = Good[];
export interface Good {
/**
* Артикул Wildberries
* @example 123
*/
nmID: number;
/**
* Цена. Валюту можно получить с помощью метода [Получение списка товаров по артикулам](./#tag/Spiski-tovarov/paths/~1api~1v2~1list~1goods~1filter/get), поле `currencyIsoCode4217`
* @example 999
*/
price?: number;
/**
* Скидка, %
* @example 30
*/
discount?: number;
}
/**
* Размеры и цены для них. Максимум 1 000 размеров
* <br><br>
* Для товаров с поразмерной установкой цен карантин не применяется
*/
export type SizeGoodsBody = SizeGoodReq[];
export interface SizeGoodReq {
/**
* Артикул Wildberries
* @example 123
*/
nmID: number;
/**
* ID размера. Можно получить с помощью метода [Получение списка товаров по артикулам](./#tag/Spiski-tovarov/paths/~1api~1v2~1list~1goods~1filter/get), поле `sizeID`. В методах контента это поле `chrtID`
* @example 98989887
*/
sizeID: number;
/**
* Цена. Валюту можно получить с помощью метода [Получение списка товаров по артикулам](./#tag/Spiski-tovarov/paths/~1api~1v2~1list~1goods~1filter/get), поле `currencyIsoCode4217`
* @example 999
*/
price: number;
}
/** Товары и скидки WB Клуба для них. Максимум 1 000 товаров. */
export type ClubDisc = ClubDiscReq[];
export interface ClubDiscReq {
/**
* Артикул WB
* @example 123
*/
nmID: number;
/**
* Скидка WB Клуба, %
* @example 5
*/
clubDiscount: number;
}
/** Размеры товара */
export interface GoodsList {
/**
* Артикул Wildberries
* @example 98486
*/
nmID?: number;
/**
* Артикул продавца
* @example "07326060"
*/
vendorCode?: string;
/** Размер */
sizes?: {
/**
* ID размера. В методах контента это поле `chrtID`
* @format int64
* @example 3123515574
*/
sizeID?: number;
/**
* Цена
* @example 500
*/
price?: number;
/**
* Цена со скидкой
* @example 350
*/
discountedPrice?: number;
/**
* Цена со скидкой, включая скидку WB Клуба
* @example 332.5
*/
clubDiscountedPrice?: number;
/**
* Размер товара
* @example "42"
*/
techSizeName?: string;
}[];
/**
* Валюта, по стандарту ISO 4217
* @example "RUB"
*/
currencyIsoCode4217?: string;
/**
* Скидка, %
* @example 30
*/
discount?: number;
/**
* Скидка WB Клуба, %
* @example 5
*/
clubDiscount?: number;
/**
* Можно ли устанавливать цены отдельно для разных размеров: `true` — можно, `false` — нельзя. Эта возможность зависит от категории товара
* @example true
*/
editableSizePrice?: boolean;
}
/** Информация о размере */
export interface SizeGood {
/**
* Артикул Wildberries
* @example 123
*/
nmID?: number;
/**
* ID размера. Можно получить с помощью метода [Получение списка товаров по артикулам](./#tag/Spiski-tovarov/paths/~1api~1v2~1list~1goods~1filter/get), поле `sizeID`. В методах контента это поле `chrtID`
* @example 98989887
*/
sizeID?: number;
/**
* Артикул продавца
* @example "34552332"
*/
vendorCode?: string;
/**
* Цена
* @example 1000
*/
price?: number;
/**
* Валюта, по стандарту ISO 4217
* @example "RUB"
*/
currencyIsoCode4217?: string;
/**
* Цена со скидкой
* @example 700
*/
discountedPrice?: number;
/**
* Цена со скидкой, включая скидку WB Клуба
* @example 665
*/
clubDiscountedPrice?: number;
/**
* Скидка, %
* @example 30
*/
discount?: number;
/**
* Скидка WB Клуба, %
* @example 5
*/
clubDiscount?: number;
/**
* Размер товара
* @example "42"
*/
techSizeName?: string;
/**
* Можно ли устанавливать цены отдельно для разных размеров: `true` — можно, `false` — нельзя. Эта возможность зависит от категории товара
* @example true
*/
editableSizePrice?: boolean;
}
export interface GoodBufferHistory {
/**
* Артикул Wildberries
* @example 544833232
*/
nmID?: number;
/**
* Артикул продавца
* @example "34552332"
*/
vendorCode?: string;
/**
* ID размера. В методах контента это поле `chrtID`
* @example 54483342
*/
sizeID?: number;
/**
* Размер
* @example "XXL"
*/
techSizeName?: string;
/**
* Цена
* @example 1500
*/
price?: number;
/**
* Валюта, по стандарту ISO 4217
* @example "RUB"
*/
currencyIsoCode4217?: string;
/**
* Скидка, %
* @example 25
*/
discount?: number;
/**
* Скидка WB Клуба, %
* @example 5
*/
clubDiscount?: number;
/** Статус товара: `1` — в обработке */
status?: GoodStatusBuffer;
/**
* Текст ошибки
* @example null
*/
errorText?: string;
}
export interface GoodHistory {
/**
* Артикул Wildberries
* @example 544833232
*/
nmID?: number;
/**
* Артикул продавца
* @example "34552332"
*/
vendorCode?: string;
/**
* ID размера. В методах контента это поле `chrtID`
* @example 54483342
*/
sizeID?: number;
/**
* Размер
* @example "42"
*/
techSizeName?: string;
/**
* Цена
* @example 1500
*/
price?: number;
/**
* Валюта, по стандарту ISO 4217
* @example "RUB"
*/
currencyIsoCode4217?: string;
/**
* Скидка, %
* @example 25
*/
discount?: number;
/**
* Скидка WB Клуба, %
* @example 5
*/
clubDiscount?: number;
/**
* Статус товара:
* * `2` — товар без ошибок, цена и/или скидка обновилась
* * `3` — есть ошибки, данные не обновились
*/
status?: GoodStatus;
/**
* Текст ошибки
*
* <blockquote class="spoiler">
* <p class="descr">Ошибка <code>The product is in quarantine</code> возникает, если новая цена со скидкой хотя бы в 3 раза меньше старой. Вы можете изменить цену или скидку с помощью API либо вывести товар из карантина <a href="https://seller.wildberries.ru/discount-and-prices/quarantine">в личном кабинете</a></p>
* </blockquote>
* @example "The product is in quarantine"
*/
errorText?: string;
}
export interface SupplierTaskMetadata {
/**
* ID загрузки
* @example 395643565
*/
uploadID?: number;
/**
* Статус загрузки:
* * `3` — обработана, в товарах нет ошибок, цены и скидки обновились
* * `4` — отменена
* * `5` — обработана, но в товарах есть ошибки. Для товаров без ошибок цены и скидки обновились, а ошибки в остальных товарах можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
* * `6` — обработана, но во всех товарах есть ошибки. Их тоже можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
*/
status?: TaskStatus;
/** Дата и время, когда загрузка создана */
uploadDate?: Date;
/** Дата и время, когда загрузка отправляется в обработку */
activationDate?: Date1;
/** Всего товаров */
overAllGoodsNumber?: number;
/** Товаров без ошибок */
successGoodsNumber?: number;
}
export interface SellerInfo {
/**
* ID загрузки
* @example 395643565
*/
name?: string;
/**
* Статус загрузки:
* * `3` — обработана, в товарах нет ошибок, цены и скидки обновились
* * `4` — отменена
* * `5` — обработана, но в товарах есть ошибки. Для товаров без ошибок цены и скидки обновились, а ошибки в остальных товарах можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
* * `6` — обработана, но во всех товарах есть ошибки. Их тоже можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
**/
sid: string;
tradeMark: string
}
export interface SupplierTaskMetadataBuffer {
/**
* ID загрузки
* @example 395643565
*/
uploadID?: number;
/** Статус загрузки: `1` — в обработке */
status?: TaskStatusBuffer;
/** Дата и время, когда загрузка создана */
uploadDate?: Date;
/** Дата и время, когда загрузка отправляется в обработку */
activationDate?: Date1;
/**
* Всего товаров
* @example 100
*/
overAllGoodsNumber?: number;
/**
* Товаров без ошибок (0, потому что загрузка в обработке)
* @example 0
*/
successGoodsNumber?: number;
}
/**
* Дата и время, когда загрузка создана
* @format date
* @pattern YYYY-MM-DDTHH:MM:SSZ
* @example "2022-08-21T22:00:13+02:00"
*/
export type Date = string;
/**
* Дата и время, когда загрузка отправляется в обработку
* @format date
* @pattern YYYY-MM-DDTHH:MM:SSZ
* @example "2022-08-21T22:00:13+02:00"
*/
export type Date1 = string;
/**
* Статус загрузки:
* * `3` — обработана, в товарах нет ошибок, цены и скидки обновились
* * `4` — отменена
* * `5` — обработана, но в товарах есть ошибки. Для товаров без ошибок цены и скидки обновились, а ошибки в остальных товарах можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
* * `6` — обработана, но во всех товарах есть ошибки. Их тоже можно получить с помощью метода [Детализация обработанной загрузки](#tag/Istoriya-zagruzok/paths/~1api~1v2~1history~1goods~1task/get)
* @example 3
*/
export type TaskStatus = number;
/**
* Статус загрузки: `1` — в обработке
* @example 1
*/
export type TaskStatusBuffer = number;
/**
* Статус товара:
* * `2` — товар без ошибок, цена и/или скидка обновилась
* * `3` — есть ошибки, данные не обновились
* @example 1
*/
export type GoodStatus = number;
/**
* Статус товара: `1` — в обработке
* @example 1
*/
export type GoodStatusBuffer = number;
export interface QuarantineGoods {
/**
* Артикул WB
* @example 206025152
*/
nmID?: number;
/**
* Не используется
* @example null
*/
sizeID?: number;
/**
* Не используется
* @example ""
*/
techSizeName?: string;
/**
* Валюта по стандарту ISO 4217
* @example "RUB"
*/
currencyIsoCode4217?: string;
/**
* Новая цена продавца до скидки
* @format float
* @example 134
*/
newPrice?: number;
/**
* Текущая цена продавца до скидки
* @format float
* @example 4000
*/
oldPrice?: number;
/**
* Новая скидка продавца, %
* @example 25
*/
newDiscount?: number;
/**
* Текущая скидка продавца, %
* @example 25
*/
oldDiscount?: number;
/**
* Разница: `newPrice` * (1 - `newDiscount` / 100) - `oldPrice` * (1 - `oldDiscount` / 100)
* @format float
* @example -2899.5
*/
priceDiff?: number;
}
export type QueryParamsType = Record<string | number, any>;
export type ResponseFormat = keyof Omit<Body, "body" | "bodyUsed">;
export interface FullRequestParams extends Omit<RequestInit, "body"> {
/** set parameter to `true` for call `securityWorker` for this request */
secure?: boolean;
/** request path */
path: string;
/** content type of request body */
type?: ContentType;
/** query params */
query?: QueryParamsType;
/** format of response (i.e. response.json() -> format: "json") */
format?: ResponseFormat;
/** request body */
body?: unknown;
/** base url */
baseUrl?: string;
/** request cancellation token */
cancelToken?: CancelToken;
}
export type RequestParams = Omit<FullRequestParams, "body" | "method" | "query" | "path">;
export interface ApiConfig<SecurityDataType = unknown> {
baseUrl?: string;
baseApiParams?: Omit<RequestParams, "baseUrl" | "cancelToken" | "signal">;
securityWorker?: (securityData: SecurityDataType | null) => Promise<RequestParams | void> | RequestParams | void;
customFetch?: typeof fetch;
}
export interface HttpResponse<D extends unknown, E extends unknown = unknown> extends Response {
data: D;
error: E;
}
type CancelToken = Symbol | string | number;
export enum ContentType {
Json = "application/json",
FormData = "multipart/form-data",
UrlEncoded = "application/x-www-form-urlencoded",
Text = "text/plain",
}
export interface SellerInfo {
/** ID продавца */
sellerId?: number;
/** Название продавца */
name?: string;
/** ИНН продавца */
inn?: string;
/** ОГРН продавца */
ogrn?: string;
/** Телефон продавца */
phone?: string;
/** Email продавца */
email?: string;
/** Адрес юридического лица */
legalAddress?: string;
/** Фактический адрес */
actualAddress?: string;
/** Рейтинг продавца */
rating?: number;
/** Дата регистрации продавца */
registrationDate?: string;
}
export class HttpClient<SecurityDataType = unknown> {
public baseUrl: string = "";
private securityData: SecurityDataType | null = null;
private securityWorker?: ApiConfig<SecurityDataType>["securityWorker"];
private abortControllers = new Map<CancelToken, AbortController>();
private customFetch = (...fetchParams: Parameters<typeof fetch>) => fetch(...fetchParams);
private baseApiParams: RequestParams = {
credentials: "same-origin",
headers: {},
redirect: "follow",
referrerPolicy: "no-referrer",
};
constructor(apiConfig: ApiConfig<SecurityDataType> = {}) {
Object.assign(this, apiConfig);
}
public setSecurityData = (data: SecurityDataType | null) => {
this.securityData = data;
};
protected encodeQueryParam(key: string, value: any) {
const encodedKey = encodeURIComponent(key);
return `${encodedKey}=${encodeURIComponent(typeof value === "number" ? value : `${value}`)}`;
}
protected addQueryParam(query: QueryParamsType, key: string) {
return this.encodeQueryParam(key, query[key]);
}
protected addArrayQueryParam(query: QueryParamsType, key: string) {
const value = query[key];
return value.map((v: any) => this.encodeQueryParam(key, v)).join("&");
}
protected toQueryString(rawQuery?: QueryParamsType): string {
const query = rawQuery || {};
const keys = Object.keys(query).filter((key) => "undefined" !== typeof query[key]);
return keys
.map((key) => (Array.isArray(query[key]) ? this.addArrayQueryParam(query, key) : this.addQueryParam(query, key)))
.join("&");
}
protected addQueryParams(rawQuery?: QueryParamsType): string {
const queryString = this.toQueryString(rawQuery);
return queryString ? `?${queryString}` : "";
}
private contentFormatters: Record<ContentType, (input: any) => any> = {
[ContentType.Json]: (input: any) =>
input !== null && (typeof input === "object" || typeof input === "string") ? JSON.stringify(input) : input,
[ContentType.Text]: (input: any) => (input !== null && typeof input !== "string" ? JSON.stringify(input) : input),
[ContentType.FormData]: (input: any) =>
Object.keys(input || {}).reduce((formData, key) => {
const property = input[key];
formData.append(
key,
property instanceof Blob
? property
: typeof property === "object" && property !== null
? JSON.stringify(property)
: `${property}`,
);
return formData;
}, new FormData()),
[ContentType.UrlEncoded]: (input: any) => this.toQueryString(input),
};
protected mergeRequestParams(params1: RequestParams, params2?: RequestParams): RequestParams {
return {
...this.baseApiParams,
...params1,
...(params2 || {}),
headers: {
...(this.baseApiParams.headers || {}),
...(params1.headers || {}),
...((params2 && params2.headers) || {}),
},
};
}
protected createAbortSignal = (cancelToken: CancelToken): AbortSignal | undefined => {
if (this.abortControllers.has(cancelToken)) {
const abortController = this.abortControllers.get(cancelToken);
if (abortController) {
return abortController.signal;
}
return void 0;
}
const abortController = new AbortController();
this.abortControllers.set(cancelToken, abortController);
return abortController.signal;
};
public abortRequest = (cancelToken: CancelToken) => {
const abortController = this.abortControllers.get(cancelToken);
if (abortController) {
abortController.abort();
this.abortControllers.delete(cancelToken);
}
};
public request = async <T = any, E = any>({
body,
secure,
path,
type,
query,
format,
baseUrl,
cancelToken,
...params
}: FullRequestParams): Promise<HttpResponse<T, E>> => {
const secureParams =
((typeof secure === "boolean" ? secure : this.baseApiParams.secure) &&
this.securityWorker &&
(await this.securityWorker(this.securityData))) ||
{};
const requestParams = this.mergeRequestParams(params, secureParams);
const queryString = query && this.toQueryString(query);
const payloadFormatter = this.contentFormatters[type || ContentType.Json];
const responseFormat = format || requestParams.format;
return this.customFetch(`${baseUrl || this.baseUrl || ""}${path}${queryString ? `?${queryString}` : ""}`, {
...requestParams,
headers: {
...(requestParams.headers || {}),
...(type && type !== ContentType.FormData ? { "Content-Type": type } : {}),
},
signal: (cancelToken ? this.createAbortSignal(cancelToken) : requestParams.signal) || null,
body: typeof body === "undefined" || body === null ? null : payloadFormatter(body),
}).then(async (response) => {
const r = response.clone() as HttpResponse<T, E>;
r.data = null as unknown as T;
r.error = null as unknown as E;
const data = !responseFormat
? r
: await response[responseFormat]()
.then((data) => {
if (r.ok) {
r.data = data;
} else {
r.error = data;
}
return r;
})
.catch((e) => {
r.error = e;
return r;
});
if (cancelToken) {
this.abortControllers.delete(cancelToken);
}
if (!response.ok) throw data;
return data;
});
};
}
export class Api<SecurityDataType = unknown> extends HttpClient<SecurityDataType> {
api = {
/**
* @description Возвращает информацию про обработанную загрузку
*
* @tags Состояния загрузок
* @name V2HistoryTasksList
* @summary Состояние обработанной загрузки
* @request GET:/api/v2/history/tasks
* @secure
*/
v1GetSellerInfo: (
query: {
/**
* ID загрузки
* @example 146567
*/
},
params: RequestParams = {},
) =>
this.request<
SellerInfo
>({
path: `/api/v1/seller-info`,
method: "GET",
// query: query,
secure: true,
...params,
}),
};
}