refunds

Возвраты покупателям.


Ресурсы

https://selena-online.ru/rest/v1/refunds/<orderids> [GET]

https://selena-online.ru/rest/v1/refunds [POST, PUT, DELETE]

string:orderids - список уникальных идентификаторов заказов, разделённых запятой, для которых запрашивается информация о возвратах.

Параметры URL

date(yyyy-mm-dd):begindate - дата начала периода запроса. Опциональный. Если не указан - принимается равным текущей дате. Игнорируется, если указан orderids.

date(yyyy-mm-dd):enddate - дата окончания периода запроса. Опциональный. Игнорируется, если указан orderids.

string:currency - валюта платежа. Опциональный, по умолчанию - валюта системы "по умолчанию".

Методы и структуры данных

GET - возвращает информацию о платёжных документах.

POST - добавляет новые платёжные документы.

PUT - вносит изменения в платёжные докумены.

DELETE - удаляет платёжные документы.

Входные данные в операциях POST, PUT и DELETE передаются в теле http-запроса. Они могут быть представлены в двух форматах: XML или JSON. Передаваемый сервису http-запрос должен содержать заголовок Content-Type, соответствующий формату входных данных: application/xml или application/json.

Допускается пакетная обработка запроса, когда входные данные включают информацию сразу о нескольких платёжных документах. Пакет обрабатывается как транзакция: commit выполняется только при полном отсутствии ошибок во всех документах. Операция POST перед записью не выполняет проверку базы данных на предмет наличия платежей с аналогичными параметрами.

В следующей таблице приведены поля структуры входных данных для методов POST, PUT и DELETE.

Поле Описание Методы
OrderID Уникальный ID заказа. POST, PUT, DELETE
Date Дата платёжного документа. POST, PUT
Number Номер платёжного документа. POST, PUT
Sum Сумма платежа в валюте счёта. POST, PUT
Rate Курс валюты: если валюта платежа = валюта заказа (счёта) - 1, если нет - курс валюты платежа по отношению к валюте заказа. POST, PUT
CarrySum Сумма платежа в валюте платежа. Например, если счёт на сумму $100, а клиент (например, по закону) должен платить рублями и платит ₽1000 при курсе ₽70 за $1, то Sum = 14.29, CarrySum = 1000, Rate = 70. POST, PUT
Way Способ платежа: 0 - платеж наличными, 1 - платеж банковским переводом, 2 - взаимозачет, 3 - платеж он-лайн. POST, PUT
Currency Валюта платежа. POST, PUT
Note Примечание, особые заметки к платежу. Необязательный параметр. POST, PUT
RecID Уникальный ID платёжного документа. PUT, DELETE


Шаблон структуры входных данных в формате JSON для методов POST, PUT и DELETE:

[
    {
        "OrderID" : 721,
        "Date" : "2015-01-17",
        "Number" : "63/342231",
        "Sum" : 30560.20,
        "Way" : 1,
        "Currency": "RUB",
        "Rate": 1,
        "CarrySum": 30560.20
    },
    {
        "OrderID" : 714,
        "Date" : "2014-12-23",
        "Number" : "452",
        "Sum" : 10000,
        "Way" : 0,
        "Currency": "RUB",
        "Rate": 1,
        "CarrySum": 10000,
        "Note" : "Аванс"
    }
]
    


Шаблон структуры входных данных в формате XML для методов POST, PUT и DELETE:

<?xml version="1.0" encoding="utf-8"?>
<Refunds>
    <Refund>
        <OrderID>714</OrderID>
        <Date>2014-12-23</Date>
        <Number>452</Number>
        <Sum>10000</Sum>
        <Way>0</Way>
        <Currency>RUB</Currency>
        <Rate>1</Rate>
        <CarrySum>10000</CarrySum>
        <Note>Аванс</Note>
    </Refund>
</Refunds>
    

Ответ

Формат ответа, возвращаемого методом GET, аналогичен формату входных данных для PUT.

Методы PUT и DELETE возвращают статус выполненной операции - успех или неудача.

Метод POST возвращает список уникальных идентификаторов (RecID) платежей, добавленных в базу данных после успешного выполнения запроса. Порядок следования элементов списка соответствует порядку платёжных документов, переданных на вход методу. Ответ в формате JSON:

[ 290311,290312,290313 ]
    

... и XML:

<Inserted>290311,290312,290313</Inserted>
    

Index DocAPI