The Assistly Ruby Gem
====================
A Ruby wrapper for the [Assistly API](http://dev.assistly.com/)
Installation
------------
gem install assistly
What's new in 0.2.0?
------------------
Added support for Topics, Articles, and Macros, which is currently all that is available in the Assistly API.
What's new in 0.1.5?
------------------
Added the ability to create outbound communications over email
What's new in 0.1?
------------------
This is the first release of the Assistly gem, based on the [Twitter gem](http://github.com/jnunemaker/twitter). Support for most of the [Assistly API](http://dev.assistly.com/docs/api) are handled.
There is not yet support for Content or Macros.
Help! I'm getting: "Did not recognize your engine specification. Please specify either a symbol or a class. (RuntimeError)"
---------------------------------------------------------------------------------------------------------------------------
You'll need to explicitly require a JSON library. We recommend [yajl-ruby](http://github.com/brianmario/yajl-ruby).
Usage Examples
--------------
require "rubygems"
require "assistly"
# All methods require authentication. To get your Assistly OAuth credentials,
# register an app in the Assistly admin for your account at http://your-domain.assistly.com/admin
@assistly = Assistly.configure do |config|
config.support_email = "help@example.com"
config.subdomain = YOUR_ASSISTLY_SUBDOMAIN
config.consumer_key = YOUR_CONSUMER_KEY
config.consumer_secret = YOUR_CONSUMER_SECRET
config.oauth_token = YOUR_OAUTH_TOKEN
config.oauth_token_secret = YOUR_OAUTH_TOKEN_SECRET
end
######
# Cases
######
# List cases
@assistly.cases
@assistly.cases(:since_id => 12345)
# Get a specific case
@assistly.case(12345)
# Update a specific case
@assistly.update_case(12345, :subject => "Something Else")
# Get a case url
@assistly.case_url(12345)
######
# Customers
######
# List customers
@assistly.customers
@assistly.customers(:since_id => 12345, :count => 5)
# Get a specific customer
@assistly.customer(12345)
# Create a customer
@assistly.create_customer(:name => "Chris Warren", :twitter => "cdwarren")
# Update a customer
@assistly.update_customer(12345, :name => "Christopher Warren")
# Add a customer email
@assistly.create_customer_email(12345, "foo@example.com")
@assistly.create_customer_email(12345, "foo@example.com", :customer_contact_type => "work")
# Update a customer email
@assistly.update_customer_email(12345, 54321, :email => "foo@example.com")
@assistly.update_customer_email(12345, 54321, :customer_contact_type => "work")
######
# Interactions
######
# List interactions
@assistly.interactions
@assistly.interactions(:since_id => 12345)
@assistly.interactions(:since_id => 12345, :count => 5)
# Create an inbound interaction
@assistly.create_interaction(:interaction_subject => "help me", :customer_email => "foo@example.com", :interaction_body => "You're my only hope.")
@assistly.create_inbound_interaction(:interaction_subject => "help me", :customer_email => "foo@example.com", :interaction_body => "You're my only hope.")
# Create an outbound interaction
# Assistly's API doesn't support creating outbound communications, so we do this over email with a BCC back to Assistly and customer headers.
# Assistly.support_email must be set to your Assistly email address so that the email can be sent to the account and give the customer someone to respond to.
#
# Read more at http://support.assistly.com/customer/portal/articles/4180
# Additional headers can be passed as well http://support.assistly.com/customer/portal/articles/6728
#
# Email is sent using Pony https://github.com/benprew/pony
@assistly.create_interaction(:interaction_subject => "Missed Your Call", :customer_email => "foo@example.com", :interaction_body => "Sorry we missed yoru call. What's up?", :direction => "outbound")
@assistly.create_outbound_interaction("foo@example.com", "Missed Your Call", "Sorry we missed yoru call. What's up?")
######
# Users
######
# List users
@assistly.users
# Get a specific user
@assistly.user(12345)
######
# Topics
######
# List Topics
@assistly.topics
# Get a specific topic
@assistly.topic(12345)
# Create a new topic
@assistly.create_topic("name", :description => "description")
# Update a topic
@assistly.update_topic(12345, :subject => "Updated")
# Delete a topic
@assistly.delete_topic(12345)
######
# Articles
######
# List articles for a topic
@assistly.articles(1)
# Get a specific article
@assistly.article(12345)
# Create a new article within a topic
@assistly.create_article(1, :subject => "API Tips", :main_content => "Tips on using our API")
# Update an article
@assistly.update_article(12345, :subject => "Updated API Tips")
# Delete an article
@assistly.delete_article(12345)
######
# Macros
######
# List Macros
@assistly.macros
# Get a specific macro
@assistly.macro(12345)
# Create a new macro
@assistly.create_macro("name", :labels => "escalated")
# Update a macro
@assistly.update_macro(12345, :name => "Updated Name")
# Delete a macro
@assistly.delete_macro(12345)
# Macro Actions
@assistly.macro_actions(12345)
# Macro Action
@assistly.macro_action(12345, "set-case-description")
# Update Macro Action
@assistly.update_macro_action(12345, "set-case-description", :value => "New Subject")
Contributing
------------
In the spirit of [free software](http://www.fsf.org/licensing/essays/free-sw.html), **everyone** is encouraged to help improve this project.
Here are some ways *you* can contribute:
* by using alpha, beta, and prerelease versions
* by reporting bugs
* by suggesting new features
* by writing or editing documentation
* by writing specifications
* by writing code (**no patch is too small**: fix typos, add comments, clean up inconsistent whitespace)
* by refactoring code
* by closing [issues](http://github.com/zencoder/assistly/issues)
* by reviewing patches
All contributors will be added to the [HISTORY](https://github.com/zencoder/assistly/blob/master/HISTORY.mkd)
file and will receive the respect and gratitude of the community.
Submitting an Issue
-------------------
We use the [GitHub issue tracker](http://github.com/zencoder/assistly/issues) to track bugs and
features. Before submitting a bug report or feature request, check to make sure it hasn't already
been submitted. You can indicate support for an existing issuse by voting it up. When submitting a
bug report, please include a [Gist](http://gist.github.com/) that includes a stack trace and any
details that may be necessary to reproduce the bug, including your gem version, Ruby version, and
operating system. Ideally, a bug report should include a pull request with failing specs.
Submitting a Pull Request
-------------------------
1. Fork the project.
2. Create a topic branch.
3. Implement your feature or bug fix.
4. Add documentation for your feature or bug fix.
5. Run bundle exec rake doc:yard. If your changes are not 100% documented, go back to step 4.
6. Add specs for your feature or bug fix.
7. Run bundle exec rake spec. If your changes are not 100% covered, go back to step 6.
8. Commit and push your changes.
9. Submit a pull request. Please do not include changes to the gemspec, version, or history file. (If you want to create your own version for some reason, please do so in a separate commit.)
Copyright
---------
Copyright (c) 2011 Chris Warren/[Zencoder](http://zencoder.com)
See [LICENSE](https://github.com/zencoder/assistly/blob/master/LICENSE.mkd) for details.