/pyhatchbuck

Python library for Hatchbuck API

Primary LanguagePythonMIT LicenseMIT

pyhatchbuck

CircleCI

This library is intended to provide a full python wrapper for the Hatchbuck API. It provides access to all the Hatchbuck API functions:

  • search contacts
  • add contact
  • update contact
  • get tags
  • add tags
  • delete tags
  • get campaign
  • start campaign
  • stop campaign

The API version supported is v1. API documentation can be found here.

Installation

The easiest way to install pyhatchbuck is with pip:

$ pip install pyhatchbuck

Basic Usage

from hatchbuck.api import HatchbuckAPI

hatchbuck = HatchbuckAPI(api_key)

contacts = hatchbuck.search_contacts(emails=["jack@pyhatchbuck.net"])

>>> print contacts[0].firstName
"Jack"

Searching for Contacts

You can search by contactId, firstName, lastName and one or more emails. The emails must be in list form.

contacts = hatchbuck.search_contacts(
  contactId="ABCDEF123456",
  firstName="Jack",
  lastName="Spratt",
  emails=["jack@pyhatchbuck.net"]
)

Adding a Contact

When adding a contact at least one email and a status are required. Calling save on a new contact will return True if successful, and the contact data will be reloaded from the API response.

contact = hatchbuck.new_contact()
contact.add_email(address="alex@pyhatchbuck.net", type="Work")
contact.set_status(name="Customer")
contact.firstName = "Alex"
contact.lastName = "Smith"
contact.title = "Account Manager"
contact.company = "ACME Incorporated"
contact.add_address(
    street="123 Main Street",
    city="Anytown",
    state="AL",
    zip="55555",
    type="Work"
)
contact.timezone = "Central Standard Time"
contact.set_temperature(id="QzlHRFRCXzBNN2s3SlppdlBfT2ttVklsRWwzVTFOM3d6SWNJV0xzZkFHODE1")
contact.add_phone(number="555-555-5555", type="Work")
contact.add_social_network(address="@pyhatchbuck", type="twitter")
contact.add_instant_message_address(address="alex.pyhatchbuck", type="skype")
contact.add_website(websiteUrl="www.pyhatchbuck.net")
contact.sourceId = "UnVvT0c0dmxsVVdFYUR1MUZIOTVJeDFXSGxudTBaUG5uZ1QxdVo1aElUVTE1"
success = contact.save()

Updating a Contact

Calling save to update an existing contact will return True if successful, and the contact data will be reloaded from the API response.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
contact.emails[0].address = "alex@pyhatchbuck.net"
contact.phones[0].number = "555-555-5555"
#...ETC...
success = contact.save()

Add custom fields

You can append custom fields using the add_custom_field method:

contact.add_custom_field(name='Company Size', value=42)
contact.add_custom_field(name='Gender', value='Female')
#...ETC...
success = contact.save()

Getting Tags

You can get tags by email or by contact id.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
tags = contact.get_tags()
# or
tags = hatchbuck.get_tags("alex@pyhatchbuck.net")

>>> print tags[0].name
"Tag Name"
>>> print tags[0].id
"ABCDEF123456"

Adding Tags

You can add tags by email or by contact id. You must give a list of tags to add with each tag's name or id. The add_tags method will return True if the tags are added successfully, False otherwise.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
success = contact.add_tags([{'name': "New Tag"}])
# or
success = hatchbuck.add_tags("alex@pyhatchbuck.net", [{'name': "New Tag"}])
# or
success = hatchbuck.add_tags("alex@pyhatchbuck.net", [{'id': "ABCDEF123456"}])

Deleting Tags

You can delete tags by email or by contact id. You must give a list of tags to delete with each tag's name or id. The delete_tags method will return True if the tags are deleted successfully, False otherwise.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
success = contact.delete_tags([{'name': "Old Tag"}])
# or
success = hatchbuck.delete_tags("alex@pyhatchbuck.net", [{'name': "Old Tag"}])
# or
success = hatchbuck.delete_tags("alex@pyhatchbuck.net", [{'id': "ABCDEF123456"}])

Getting Campaigns

You can get active campaigns by email or by contact id.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
campaigns = contact.get_campaigns()
# or
campaigns = hatchbuck.get_campaigns("alex@pyhatchbuck.net")

>>> print campaigns[0].name
"Campaign Name"
>>> print campaigns[0].id
"ABCDEF123456"

Starting Campaigns

You can start campaigns by email or by contact id. You must give a list of campaigns to start with each campaign's name or id. The start_campaigns method will return True if the campaigns are started successfully, False otherwise.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
success = contact.start_campaigns([{'name': "New Campaign"}])
# or
success = hatchbuck.start_campaigns("alex@pyhatchbuck.net", [{'name': "New Campaign"}])
# or
success = hatchbuck.start_campaigns("alex@pyhatchbuck.net", [{'id': "ABCDEF123456"}])

Stopping Campaigns

You can delete tags by email or by contact id. You must give a list of tags to delete with each tag's name or id. The stop_campaigns method will return True if the campaigns are stopped successfully, False otherwise.

contact = hatchbuck.search_contacts(contactId=contact_id)[0]
success = contact.stop_campaigns([{'name': "Old Campaign"}])
# or
success = hatchbuck.stop_campaigns("alex@pyhatchbuck.net", [{'name': "Old Campaign"}])
# or
success = hatchbuck.stop_campaigns("alex@pyhatchbuck.net", [{'id': "ABCDEF123456"}])

Building and Testing Locally

If you want to work on the pyhatchbuck project locally, you can clone this repo or a fork and setup your local environment with the following instructions.

Requirements

Commands

Install dependencies:

poetry install

Build the library:

poetry run python setup.py install

Test:

poetry run nosetests -v