Russian Post SOAP API client class
License: LGPL v3
- python == 2.7.*
- suds >= 0.4
settings.py
содержит все необходимые настройки для работы класса.
Обязательные: RPOST_LOGIN
и RPOST_PASSWORD
. Также эти параметры
можно передавать напрямую в конструктор класса:
RuPostClient(login='', password='', url='', tracks_per_ticket=100)
Объект клиента принимает в метод make_ticket
список трекинг-номеров,
разбивает по группам согласно настроек и создаёт на WSDL сервисе
Почты России (далее сервис) тикеты на каждую группу.
Возвращает ответ в формате:
{ ticket_number: [track_list_part], }
Где:
ticket_number
- номера тикетов (по-одному на ключ словаря) возвращаемые сервисом;track_list_part
- часть трекинг номеров (согласно настройкам) из переданного в метод списка, относящаяся к данному тикету.
Если запрос на создание тикета возвращает ошибку - выбрасывается
исключение MakeTicketException
.
Если запрос на создание тикета не возвращает ни номер тикета ни ошибку -
выбрасывается исключение UnrecognizedAnswer
(потомок
MakeTicketException
).
Объект клиента принимает в метод get_tracks
список номеров тикетов
(для их получения воспользуйтесь методом make_ticket
), запрашивает
по ним состояние у сервиса и возвращает ответ в формате:
{ ticket_number: { 'error': (error_number, error_text), track_number: { 'error': (error_number, error_text), 'data': [ { 'oper_type': OperTypeID, 'oper_ctg': OperCtgID, 'operation': OperName, 'date': DateOper, 'zipcode': IndexOper, 'attribute': text_version_OperCtgId }, ] }, } }
где:
ticket_number
- номера тикетов (по-одному на ключ словаря), возвращаемыеmake_ticket
;'error'
(в словареticket_number
) - указывается, если произошла ошибка в запросе тикета (тикет не готов, не существует и т.д.), содержит кортеж с номером и текстовым значением ошибки;track_number
- указывается, если не произошло ошибки. Содержит номера треков (по-одному на ключ словаря), запрошенные в этом тикете;'error'
(в словареtrack_number
) - указывается, если произошла ошибка в обработке состояния конкретного отправления с этим номером трека (не найден такой номер), содержит кортеж с номером и текстовым значением ошибки;'data'
- указывается, если не произошло ошибки. Содержит список словарей с данными по поперациям над отправлением;'oper_type'
- цифровой код операции;'oper_ctg'
- цифровой код аттрибута операции;'operation'
- текстовое наименование операции;'date'
- дата и время операции как объект datetime;'zipcode'
- почтовый индекс отделения где происходила операция;'attribute'
- текстовое наименование аттрибута операции (какие удалось расшифровать).
- Заполните авторизационные данные в файле
settings.py
. - Добавьте пару трекинг-номеров в список
TRACKS
файлаtest_data.py
. - Первый прогон тестов выполнит 2 из 3х тестов и, в случае удачи,
выведет в консоль номер тикета, который нужно будет внести в список
TICKETS
файлаtest_data.py
(списокTRACKS
теперь можно очистить, чтоб не создавать лишних тикетов) - Через 15 минут (регламент сервиса - запросы результатов по тикету можно делать не чаще раза в 15 минут и не ранее 15 минут после создания самого тикета) можно повторять тестирование уже с полученным тикетом.
- 2 - Формат данных запроса не соответствует установленному в регламенте обмена
- 3 - Неуспешная авторизация ФК для передачи запроса компоненту получения запросов и выдачи ответов
- 6 - Ответ для ФК ещё не готов
- 12 - Сообщение не найдено
- 16 - Внутренняя ошибка работы сервиса обмена данными
- 17 - Время хранения ответа истекло, ответ был удален с сервера
- 18 - Превышено максимально допустимое количество отправлений в запросе
- Atorich - Полный список типов операций и установка пакета.