Skip to main content

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

Project description

# 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',
'easy_thumbnails' # Used for managing user pictures
...
]
```

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
```

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 these management commands:
1. `create_callback ticket`
2. `create_callback project`
3. `create_callback company`
4. `create_callback opportunity`
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 `delete_callback` management command.

## Testing

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.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

django-connectwise-0.1.2a0.tar.gz (164.2 kB view details)

Uploaded Source

File details

Details for the file django-connectwise-0.1.2a0.tar.gz.

File metadata

File hashes

Hashes for django-connectwise-0.1.2a0.tar.gz
Algorithm Hash digest
SHA256 f16fe2b5445f42cea5048bb2c1b1e3adcb38dc8121a672706eee9703c415877d
MD5 ff7212106dc3e90f6e8f5ee39e5b7cd1
BLAKE2b-256 7c03b6c59fdb96568850c020452c19eb621cbf7db848ce79cbd88bea9a147338

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