Skip to main content

Easy to use Django-styled API wrapper for Bitrix 24

Project description

bx24-orm

Обертка для Bitrix24 API.

С помощью нее вы можете вместо:

import requests

token = get_token_function()  # get your Bitrix24 token

# prepare your parameters
params = {
    'id': lead_id,
    'auth': token
}

reponse = requests.get(your_domain_url+'crm.lead.get', params)

# check if request is OK
if response.status_code < 300:
    result = response.json()['result']
else:
    handle_errors(response)

сделать так:

from bx24_orm.entity.crm import BxLead
from bx24_orm.exceptions.code_exceptions import BxException

try:
    result = BxLead.get(lead_id)
except BxException as ex:
    handle_error(ex)  # your handling code

Установка

Чтобы установить пакет:

pip install bx24-orm

Начало работы

  1. Для начала нужно создать файл конфигурации bx24_settings.py. Рекомендую создать его в корне проекта.

    TOKEN_STORAGE_FILE_PATH = 'bx24_tokens'  # путь до файла где хранятся токены приложения
    DEFAULT_DOMAIN = '{Ваш домен 3-го уровня}'
    DEFAULT_TRANSPORT = 'json' # xml пока не поддерживается
    BX24_DOMAIN_SETTINGS = {
        '{домен 3-го уровня}': {
            'client_id': '{ваш_client_id}',
            'client_secret': '{ваш_client_secret}'
        }
    }
    
  2. Далее добавьте путь до файла настроек в переменную окружения: BX24_SETTINGS_MODULE

  3. Получите токены для доступа к API. Для удобства можете воспользоваться скриптом командной строки:

    > bx24_cmd get_tokens -c {ваш client_id} -s {ваш client_secret} -d {ваш домен 3-го уровня в битрикс}

    Далее пройдите по ссылке, появившейся в скрипте. Если нужно авторизируйтесь в вашем Bitrix24. И скопируйте параметр code из url браузера и вставьте его в консоль.

  4. Используя python консоль в вашем проекте выполните следующий код:

    from bx24_orm.core import token_storage
    token_storage.save_token('ваш домен 3-го уровня', 'access_token', 'refresh_token')
    
  5. Готово! Пакет готов к использованию!

Кастомизация ваших моделей

from bx24_orm.enitiy.crm import BxDeal, BxLead, BxCompany, BxField


class Deal(BxDeal):
    custom_field = BxField('UF_CRM_1539088441')


class Lead(BxLead):
    custom_field = BxField('UF_CRM_1539088367')


class Company(BxCompany):
    custom_field = BxField('UF_CRM_1539088478')

Стоит помнить: Для экономии трафика при изменении моделей, они отслеживают какие поля изменились. Следовательно, чтобы изменить ссылочные типы данных модели, например телефон, нужно делать так:

  lead = Lead.get(1)
  new_phone = lead.phone()
  new_phone[0]['VALUE'] = 'NEW_VALUE'
  lead.phone = new_phone
  lead.save() 

Заключение

Если у вас возникнут вопросы, то не стесняйтесь написать мне на почту: dmitriilazukov@gmail.com

Также приветствуются Pull Request-ы.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bx24_orm-0.0.3.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

bx24_orm-0.0.3-py2-none-any.whl (25.3 kB view details)

Uploaded Python 2

File details

Details for the file bx24_orm-0.0.3.tar.gz.

File metadata

  • Download URL: bx24_orm-0.0.3.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.15

File hashes

Hashes for bx24_orm-0.0.3.tar.gz
Algorithm Hash digest
SHA256 84c787e515b9878353812bd5bbbaab864a091df01e64fd608ad1aa0c24275b3a
MD5 01f8887ae715d65fa47853a3b113e203
BLAKE2b-256 9c2df4256a97c88554a3c00a6d4f5d9eca348e2f14665b4bb018c395e089a303

See more details on using hashes here.

File details

Details for the file bx24_orm-0.0.3-py2-none-any.whl.

File metadata

  • Download URL: bx24_orm-0.0.3-py2-none-any.whl
  • Upload date:
  • Size: 25.3 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.21.0 setuptools/40.6.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/2.7.15

File hashes

Hashes for bx24_orm-0.0.3-py2-none-any.whl
Algorithm Hash digest
SHA256 7932056b2b0ddece1d544f2138dbb6f44e8816014c8f657f61bedab93bcb9332
MD5 72a4d1db701f1e9c526c3dd88dd1cbf6
BLAKE2b-256 3af6c4d7d318d06bd62990e92fa519f4a389c1b091dcd6fb4dd8a7cb661aadc2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page