API (англ. Application Program Interface) – это интерфейс программирования, который позволяет сайту клуба взаимодействовать с сервером и получать доступ к функционалу сервиса управления фитнес клубом.
Servitum API принимает запросы в формате URL-encoded GET методов. Ответ на запрос выдается в JSON или XML формате.
Для активации API для клуба необходимо в кабинете компании https://app.servitum.net/company/office на вкладке «Другие» сгенерировать API ключ, который надо будет использовать как один из параметров запроса.
https://app.servitum.net/api?api_key=<апи ключ компании>&format=<json|xml>&request=<имя операции>&<дополнительные параметры спецефические для запроса>
Список параметров:
api_key
- API Key компанииformat
- формат возвращаемых данных (необязательный параметр, может быть опущен; по умолчанию json)request
- команда запроса (на данный момент есть только одна команда - customer_memberships)дополнительные параметры
- параметры, специфичные для каждой командыИмя команды - customer_memberships
Эта команда возвращает список активных абонементов указанного клиента.
Список параметров специфических для этой команды:
last_name
- фамилия клиента. Параметр не чувтсвителен к регистру буквphone
- телефон клиента в том формате, в котором он хранится в базе (включая ведущий знак +)Команда ищет клиента по полному совпадению фамилии и номера телефона одновременно. Т.е. если указать только фамилию без телефона, то команда выведет, что клиент не найден. Это сделано, чтобы избежать перебора клиентов клуба по фамилии сторонними пользователями.
Пример запроса:
https://app.servitum.net/api?api_key=5ca5b3ff853afb7022a90c9ecaf19490&format=json&request=customer_memberships&last_name=Агипов&phone=%2B380663332211
здесь %2B380663332211
– номер телефона +380663332211, где знак + заменен на URL Encoded представление %2B
Привер ответа:
{"success":true, "data": [{"name":"Трен Зал 1 мес","status":"active", "start":"11.07.2014", "end":"10.08.2014", "freeze_days_left":"5", "services":[{"service_name":"Тренажерный зал", "service_left":"11","service_used":"1"}]}]}
здесь
success
- статус обработки командыdata
- список активных абонементов клиента{ "name":"Трен Зал 1 мес" - название абонемента "status":"active" - статус абонемента "start":"11.07.2014" - дата начала действия абонемента "end":"10.08.2014" - дата окончания действия "freeze_days_left":"5" - количество оставшихся дней заморозки "services": - список услуг, доступных в рамках абонемента [{ "service_name":"Тренажерный зал" - название доступной услуги "service_left":"11" - количество доступных занятий "service_used":"1" - количество использованных занятий }] }
Текст возвращается в кодировке utf-8.
В случае ошибки команда выдает статус false
и в поле error
выводится текст сообщения об ошибке.
Например:
{«success»:false, «error»:«Customer not found»}