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 - Полный список типов операций и установка пакета.