2018-03-20 20:32:43 +03:00
|
|
|
# coding=utf-8
|
|
|
|
|
|
|
|
"""
|
|
|
|
API Client version 3
|
|
|
|
"""
|
|
|
|
|
|
|
|
import json
|
|
|
|
|
|
|
|
from retailcrm.versions.base import Base
|
|
|
|
|
|
|
|
|
|
|
|
class Client(Base):
|
|
|
|
"""retailCRM API client"""
|
|
|
|
|
|
|
|
apiVersion = 'v3'
|
|
|
|
|
|
|
|
def __init__(self, crm_url, api_key):
|
|
|
|
Base.__init__(self, crm_url, api_key, self.apiVersion)
|
|
|
|
|
|
|
|
def customers(self, filters=None, limit=20, page=1):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param filters: object
|
|
|
|
:param limit: integer
|
|
|
|
:param page: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['filter'] = filters
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['page'] = page
|
|
|
|
|
|
|
|
return self.get('/customers')
|
|
|
|
|
|
|
|
def customer_create(self, customer, site=None):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param customer: object
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['customer'] = json.dumps(customer)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/customers/create')
|
|
|
|
|
|
|
|
def customers_fix_external_ids(self, customers, site=None):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param customers: object
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['customers'] = json.dumps(customers)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/customers/fix-external-ids')
|
|
|
|
|
|
|
|
def customers_upload(self, customers, site=None):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param customers: array of objects
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['customers'] = json.dumps(customers)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/customers/upload')
|
|
|
|
|
|
|
|
def customer(self, uid, uid_type='externalId', site=None):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param uid: string
|
|
|
|
:param uid_type: string
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
if uid_type != 'externalId':
|
|
|
|
self.parameters['by'] = uid_type
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.get('/customers/' + str(uid))
|
|
|
|
|
|
|
|
def customer_edit(self, customer, uid_type='externalId', site=None):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param customer: object
|
|
|
|
:param uid_type: string
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['customer'] = json.dumps(customer)
|
|
|
|
|
|
|
|
if uid_type != 'externalId':
|
|
|
|
self.parameters['by'] = uid_type
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/customers/' + customer[uid_type] + '/edit')
|
|
|
|
|
|
|
|
def orders(self, filters=None, limit=20, page=1):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param filters: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:param limit: integer
|
|
|
|
:param page: integer
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['filter'] = filters
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['page'] = page
|
|
|
|
|
|
|
|
return self.get('/orders')
|
|
|
|
|
|
|
|
def order_create(self, order, site=None):
|
|
|
|
"""
|
|
|
|
:param order: object
|
|
|
|
:param site: string
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['order'] = json.dumps(order)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/orders/create')
|
|
|
|
|
|
|
|
def orders_fix_external_ids(self, orders, site=None):
|
|
|
|
"""
|
|
|
|
:param orders: object
|
|
|
|
:param site: string
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['orders'] = json.dumps(orders)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/orders/fix-external-ids')
|
|
|
|
|
|
|
|
def orders_history(self, start=None, end=None, limit=100, offset=0, skip=True):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param start: DateTime
|
|
|
|
:param end: DateTime
|
|
|
|
:param limit: integer
|
|
|
|
:param offset: integer
|
|
|
|
:param skip: boolean
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['startDate'] = start
|
|
|
|
self.parameters['endDate'] = end
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['offset'] = offset
|
|
|
|
self.parameters['skipMyChanges'] = skip
|
|
|
|
|
|
|
|
return self.get('/orders/history')
|
|
|
|
|
|
|
|
def orders_statuses(self, ids, external_ids):
|
|
|
|
"""
|
|
|
|
:param ids: array
|
|
|
|
:param external_ids: array
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['ids'] = ids
|
|
|
|
self.parameters['externalIds'] = external_ids
|
|
|
|
|
|
|
|
return self.get('/orders/statuses')
|
|
|
|
|
|
|
|
def orders_upload(self, orders, site=None):
|
|
|
|
"""
|
|
|
|
:param orders: object
|
|
|
|
:param site: string
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['orders'] = json.dumps(orders)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
return self.post('/orders/upload')
|
|
|
|
|
|
|
|
def order(self, uid, uid_type='externalId', site=None):
|
|
|
|
"""
|
|
|
|
:param uid: string
|
|
|
|
:param uid_type: string
|
|
|
|
:param site: string
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
if uid_type != 'externalId':
|
|
|
|
self.parameters['by'] = uid_type
|
|
|
|
|
|
|
|
return self.get('/orders/' + str(uid))
|
|
|
|
|
|
|
|
def order_edit(self, order, uid_type='externalId', site=None):
|
|
|
|
"""
|
|
|
|
:param order: object
|
|
|
|
:param uid_type: string
|
|
|
|
:param site: string
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['order'] = json.dumps(order)
|
|
|
|
|
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
|
|
|
if uid_type != 'externalId':
|
|
|
|
self.parameters['by'] = uid_type
|
|
|
|
|
|
|
|
return self.post('/orders/' + str(order[uid_type]) + '/edit')
|
|
|
|
|
|
|
|
def packs(self, filters=None, limit=20, page=1):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param filters: object
|
|
|
|
:param limit: integer
|
|
|
|
:param page: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['filter'] = filters
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['page'] = page
|
|
|
|
|
|
|
|
return self.get('/orders/packs')
|
|
|
|
|
|
|
|
def pack_create(self, pack):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param pack: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['pack'] = json.dumps(pack)
|
|
|
|
|
|
|
|
return self.post('/orders/packs/create')
|
|
|
|
|
|
|
|
def packs_history(self, filters=None, limit=20, page=1):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param filters: object
|
|
|
|
:param limit: integer
|
|
|
|
:param page: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['filter'] = filters
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['page'] = page
|
|
|
|
|
|
|
|
return self.get('/orders/packs/history')
|
|
|
|
|
|
|
|
def pack(self, uid):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param uid: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/orders/packs/' + str(uid))
|
|
|
|
|
|
|
|
def pack_delete(self, uid):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param uid: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.post('/orders/packs/' + str(uid) + '/delete')
|
|
|
|
|
|
|
|
def pack_edit(self, pack):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param pack: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['pack'] = json.dumps(pack)
|
|
|
|
|
|
|
|
return self.post('/orders/packs/' + str(pack['id']) + '/edit')
|
|
|
|
|
|
|
|
def countries(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/countries')
|
|
|
|
|
|
|
|
def delivery_services(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/delivery-services')
|
|
|
|
|
|
|
|
def delivery_services_edit(self, delivery_service):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param delivery_service: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['deliveryService'] = json.dumps(delivery_service)
|
|
|
|
|
|
|
|
return self.post('/reference/delivery-services/' + delivery_service['code'] + '/edit')
|
|
|
|
|
|
|
|
def delivery_types(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/delivery-types')
|
|
|
|
|
|
|
|
def delivery_types_edit(self, delivery_type):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param delivery_type: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['deliveryType'] = json.dumps(delivery_type)
|
|
|
|
|
|
|
|
return self.post('/reference/delivery-types/' + delivery_type['code'] + '/edit')
|
|
|
|
|
|
|
|
def order_methods(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/order-methods')
|
|
|
|
|
|
|
|
def order_methods_edit(self, order_method):
|
|
|
|
"""
|
|
|
|
|
2020-08-20 14:44:41 +03:00
|
|
|
:param order_method: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['orderMethod'] = json.dumps(order_method)
|
|
|
|
|
|
|
|
return self.post('/reference/order-methods/' + order_method['code'] + '/edit')
|
|
|
|
|
|
|
|
def order_types(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/order-types')
|
|
|
|
|
|
|
|
def order_types_edit(self, order_type):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param order_type: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['orderType'] = json.dumps(order_type)
|
|
|
|
|
|
|
|
return self.post('/reference/order-types/' + order_type['code'] + '/edit')
|
|
|
|
|
|
|
|
def payment_statuses(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/payment-statuses')
|
|
|
|
|
|
|
|
def payment_statuses_edit(self, payment_status):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param payment_status: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['paymentStatus'] = json.dumps(payment_status)
|
|
|
|
|
|
|
|
return self.post('/reference/payment-statuses/' + payment_status['code'] + '/edit')
|
|
|
|
|
|
|
|
def payment_types(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/payment-types')
|
|
|
|
|
|
|
|
def payment_types_edit(self, payment_type):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param payment_type: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['paymentType'] = json.dumps(payment_type)
|
|
|
|
|
|
|
|
return self.post('/reference/payment-types/' + payment_type['code'] + '/edit')
|
|
|
|
|
|
|
|
def product_statuses(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/product-statuses')
|
|
|
|
|
|
|
|
def product_statuses_edit(self, product_status):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param product_status: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['productStatus'] = json.dumps(product_status)
|
|
|
|
|
|
|
|
return self.post('/reference/product-statuses/' + product_status['code'] + '/edit')
|
|
|
|
|
|
|
|
def sites(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/sites')
|
|
|
|
|
|
|
|
def sites_edit(self, site):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param site: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['site'] = json.dumps(site)
|
|
|
|
|
|
|
|
return self.post('/reference/sites/' + site['code'] + '/edit')
|
|
|
|
|
|
|
|
def status_groups(self):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:return: Response
|
2018-03-20 20:32:43 +03:00
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/status-groups')
|
|
|
|
|
|
|
|
def statuses(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/statuses')
|
|
|
|
|
|
|
|
def statuses_edit(self, status):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param status: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['status'] = json.dumps(status)
|
|
|
|
|
|
|
|
return self.post('/reference/statuses/' + status['code'] + '/edit')
|
|
|
|
|
|
|
|
def stores(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/reference/stores')
|
|
|
|
|
|
|
|
def stores_edit(self, store):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param store: object
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
self.parameters['store'] = json.dumps(store)
|
2018-03-20 20:32:43 +03:00
|
|
|
|
|
|
|
return self.post('/reference/stores/' + store['code'] + '/edit')
|
|
|
|
|
|
|
|
def inventories(self, filters=None, limit=20, page=1):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param filters: object
|
|
|
|
:param limit: integer
|
|
|
|
:param page: integer
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['filter'] = filters
|
|
|
|
self.parameters['limit'] = limit
|
|
|
|
self.parameters['page'] = page
|
|
|
|
|
|
|
|
return self.get('/store/inventories')
|
|
|
|
|
2019-08-15 11:52:15 +03:00
|
|
|
def inventories_upload(self, offers, site=None):
|
2018-03-20 20:32:43 +03:00
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param offers: array of objects
|
|
|
|
:param site: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
2019-08-15 11:52:15 +03:00
|
|
|
if site is not None:
|
|
|
|
self.parameters['site'] = site
|
|
|
|
|
2018-03-20 20:32:43 +03:00
|
|
|
self.parameters['offers'] = json.dumps(offers)
|
|
|
|
|
|
|
|
return self.post('/store/inventories/upload')
|
|
|
|
|
|
|
|
def telephony_call_event(self, phone, call_type, code, status):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param phone: string
|
|
|
|
:param call_type: string
|
|
|
|
:param code: string
|
|
|
|
:param status: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['hangupStatus'] = status
|
|
|
|
self.parameters['phone'] = phone
|
|
|
|
self.parameters['code'] = code
|
|
|
|
self.parameters['type'] = call_type
|
|
|
|
|
|
|
|
return self.post('/telephony/call/event')
|
|
|
|
|
|
|
|
def telephony_calls_upload(self, calls):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param calls: array of objects
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['calls'] = json.dumps(calls)
|
|
|
|
|
|
|
|
return self.post('/telephony/calls/upload')
|
|
|
|
|
|
|
|
def telephony_manager(self, phone, details=True):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param phone: string
|
|
|
|
:param details: string
|
|
|
|
:return: Response string
|
2018-03-20 20:32:43 +03:00
|
|
|
"""
|
|
|
|
self.parameters['phone'] = phone
|
|
|
|
self.parameters['details'] = details
|
|
|
|
|
|
|
|
return self.get('/telephony/manager')
|
|
|
|
|
|
|
|
def telephony_settings(self, code, client_id, make_call_url, active, name, image):
|
|
|
|
"""
|
2020-08-20 14:44:41 +03:00
|
|
|
:param code: string
|
|
|
|
:param client_id: string
|
|
|
|
:param make_call_url: string
|
|
|
|
:param active: string
|
|
|
|
:param name: string
|
|
|
|
:param image: string
|
2018-03-20 20:32:43 +03:00
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
self.parameters['code'] = code
|
|
|
|
self.parameters['clientId'] = client_id
|
|
|
|
self.parameters['makeCallUrl'] = make_call_url
|
|
|
|
self.parameters['active'] = active
|
|
|
|
self.parameters['name'] = name
|
|
|
|
self.parameters['image'] = image
|
|
|
|
|
|
|
|
return self.post('/telephony/settings/' + str(code))
|
2020-08-20 14:44:41 +03:00
|
|
|
|
|
|
|
def statistic_update(self):
|
|
|
|
"""
|
|
|
|
:return: Response
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.get('/statistic/update')
|