django-connectwise


Namedjango-connectwise JSON
Version 1.6.11 PyPI version JSON
download
home_pagehttps://github.com/KerkhoffTechnologies/django-connectwise
SummaryDjango app for working with ConnectWise. Defines models (tickets, members, companies, etc.) and callbacks.
upload_time2025-01-17 00:31:00
maintainerNone
docs_urlNone
authorKerkhoff Technologies Inc.
requires_pythonNone
licenseMIT
keywords django connectwise rest api python
VCS
bugtrack_url
requirements pytz botocore boto3 django-storages Pillow
Travis-CI No Travis.
coveralls test coverage
            # django-connectwise

Django app for working with ConnectWise. Defines models (tickets,
members, companies, etc.) and callbacks.

## Requirements

-  Python 3.5
-  Django 2.0

Other versions may work; we haven't tried.

## Installation

From PyPI:

    pip install django-connectwise

From source:

    git clone git@github.com:KerkhoffTechnologies/django-connectwise.git
    cd django-connectwise
    python setup.py install

## Usage

1. Add to INSTALLED_APPS

    ```
    INSTALLED_APPS = [
        ...
        'djconnectwise',
        ...
    ]
    ```

1. Add to `urls.py`:

    ```
    re_path(
        r'^callback/',  # This can be whatever you want.
        include('djconnectwise.urls', namespace='connectwise')
    ),
    ```

1. Add to settings:

    ```
    CONNECTWISE_SERVER_URL = 'https://connectwise.example.com'
    CONNECTWISE_CREDENTIALS = {
        'company_id': 'your company ID',
        'api_public_key': 'your API user public key',
        'api_private_key': 'your API user private key',
    }
    CONNECTWISE_TICKET_PATH = 'v4_6_release/services/system_io/router/openrecord.rails'
    def djconnectwise_configuration():
        return {
            'timeout': 30.0,  # Network timeout in seconds
            'batch_size': 50,  # Number of records to fetch in each request
            'max_attempts': 3,  # Number of times to make a request before failing
            'callback_url': '{}?id='.format(
                reverse('connectwise:callback')
            ),
            'callback_host': '{}://{}'.format(
                'http' if DEBUG else 'https',
                'djconnectwise-host.example.com'
            ),
        }
    DJCONNECTWISE_CONF_CALLABLE = djconnectwise_configuration
    ```

    For ConnectWise Cloud users, `CONNECTWISE_SERVER_URL` can be just i.e. `https://na.myconnectwise.net`- the library changes to the `api-region` domain automatically.
      
    The `DJCONNECTWISE_CONF_CALLABLE` function should return a dictionary with the fields shown above. It's a callable so that it can fetch settings at runtime- for example from [Constance](https://github.com/jazzband/django-constance) settings.
1. Sync objects with this management command: `cwsync`. This will take a very long time if there are many objects to fetch.
1. Register your callbacks with the management command: `callbacks_registered`
1. Use standard Django model signals to see when objects change.
1. To control how user avatar thumbnails are stored, add settings from 
   [easy-thumbnails](https://easy-thumbnails.readthedocs.io/en/stable/ref/settings/).

To de-register your callbacks, use the `callbacks_deleted` management command.

## Testing

Prepare your environment:

```
pip install --upgrade -r requirements_test.txt
```

Try one of:

    ./runtests.py
    python setup.py test
    make test

## Contributing

- Fork this repo
- Make a branch
- Make your improvements

    Making migrations? Run:

    ```
    ./makemigrations.py
    ```

- Run the tests (see above)
- Make a pull request

## License

MIT

## Copyright

© 2017 Kerkhoff Technologies Inc.
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/KerkhoffTechnologies/django-connectwise",
    "name": "django-connectwise",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "django connectwise rest api python",
    "author": "Kerkhoff Technologies Inc.",
    "author_email": "matt@kerkhofftech.ca",
    "download_url": "https://files.pythonhosted.org/packages/c8/a0/361efa2f8a3500b6c580da89b4693ed9b11d4910877d9dd8fd0bc3a19d16/django-connectwise-1.6.11.tar.gz",
    "platform": null,
    "description": "# django-connectwise\n\nDjango app for working with ConnectWise. Defines models (tickets,\nmembers, companies, etc.) and callbacks.\n\n## Requirements\n\n-  Python 3.5\n-  Django 2.0\n\nOther versions may work; we haven't tried.\n\n## Installation\n\nFrom PyPI:\n\n    pip install django-connectwise\n\nFrom source:\n\n    git clone git@github.com:KerkhoffTechnologies/django-connectwise.git\n    cd django-connectwise\n    python setup.py install\n\n## Usage\n\n1. Add to INSTALLED_APPS\n\n    ```\n    INSTALLED_APPS = [\n        ...\n        'djconnectwise',\n        ...\n    ]\n    ```\n\n1. Add to `urls.py`:\n\n    ```\n    re_path(\n        r'^callback/',  # This can be whatever you want.\n        include('djconnectwise.urls', namespace='connectwise')\n    ),\n    ```\n\n1. Add to settings:\n\n    ```\n    CONNECTWISE_SERVER_URL = 'https://connectwise.example.com'\n    CONNECTWISE_CREDENTIALS = {\n        'company_id': 'your company ID',\n        'api_public_key': 'your API user public key',\n        'api_private_key': 'your API user private key',\n    }\n    CONNECTWISE_TICKET_PATH = 'v4_6_release/services/system_io/router/openrecord.rails'\n    def djconnectwise_configuration():\n        return {\n            'timeout': 30.0,  # Network timeout in seconds\n            'batch_size': 50,  # Number of records to fetch in each request\n            'max_attempts': 3,  # Number of times to make a request before failing\n            'callback_url': '{}?id='.format(\n                reverse('connectwise:callback')\n            ),\n            'callback_host': '{}://{}'.format(\n                'http' if DEBUG else 'https',\n                'djconnectwise-host.example.com'\n            ),\n        }\n    DJCONNECTWISE_CONF_CALLABLE = djconnectwise_configuration\n    ```\n\n    For ConnectWise Cloud users, `CONNECTWISE_SERVER_URL` can be just i.e. `https://na.myconnectwise.net`- the library changes to the `api-region` domain automatically.\n      \n    The `DJCONNECTWISE_CONF_CALLABLE` function should return a dictionary with the fields shown above. It's a callable so that it can fetch settings at runtime- for example from [Constance](https://github.com/jazzband/django-constance) settings.\n1. Sync objects with this management command: `cwsync`. This will take a very long time if there are many objects to fetch.\n1. Register your callbacks with the management command: `callbacks_registered`\n1. Use standard Django model signals to see when objects change.\n1. To control how user avatar thumbnails are stored, add settings from \n   [easy-thumbnails](https://easy-thumbnails.readthedocs.io/en/stable/ref/settings/).\n\nTo de-register your callbacks, use the `callbacks_deleted` management command.\n\n## Testing\n\nPrepare your environment:\n\n```\npip install --upgrade -r requirements_test.txt\n```\n\nTry one of:\n\n    ./runtests.py\n    python setup.py test\n    make test\n\n## Contributing\n\n- Fork this repo\n- Make a branch\n- Make your improvements\n\n    Making migrations? Run:\n\n    ```\n    ./makemigrations.py\n    ```\n\n- Run the tests (see above)\n- Make a pull request\n\n## License\n\nMIT\n\n## Copyright\n\n\u00a9 2017 Kerkhoff Technologies Inc.",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Django app for working with ConnectWise. Defines models (tickets, members, companies, etc.) and callbacks.",
    "version": "1.6.11",
    "project_urls": {
        "Homepage": "https://github.com/KerkhoffTechnologies/django-connectwise"
    },
    "split_keywords": [
        "django",
        "connectwise",
        "rest",
        "api",
        "python"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c8a0361efa2f8a3500b6c580da89b4693ed9b11d4910877d9dd8fd0bc3a19d16",
                "md5": "5b065f8c8ca4d0f769b0c6a051e5b653",
                "sha256": "2e07229693ff8bde1c9ce606290b61ede1ac3dbd66b39915ea78d7cc19ed8ccc"
            },
            "downloads": -1,
            "filename": "django-connectwise-1.6.11.tar.gz",
            "has_sig": false,
            "md5_digest": "5b065f8c8ca4d0f769b0c6a051e5b653",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 323436,
            "upload_time": "2025-01-17T00:31:00",
            "upload_time_iso_8601": "2025-01-17T00:31:00.494831Z",
            "url": "https://files.pythonhosted.org/packages/c8/a0/361efa2f8a3500b6c580da89b4693ed9b11d4910877d9dd8fd0bc3a19d16/django-connectwise-1.6.11.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-17 00:31:00",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "KerkhoffTechnologies",
    "github_project": "django-connectwise",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "requirements": [
        {
            "name": "pytz",
            "specs": [
                [
                    "==",
                    "2022.1"
                ]
            ]
        },
        {
            "name": "botocore",
            "specs": [
                [
                    "==",
                    "1.25.4"
                ]
            ]
        },
        {
            "name": "boto3",
            "specs": [
                [
                    "==",
                    "1.22.4"
                ]
            ]
        },
        {
            "name": "django-storages",
            "specs": [
                [
                    "==",
                    "1.12.3"
                ]
            ]
        },
        {
            "name": "Pillow",
            "specs": [
                [
                    "==",
                    "10.3.0"
                ]
            ]
        }
    ],
    "tox": true,
    "lcname": "django-connectwise"
}
        
Elapsed time: 3.40302s