Ruby
dwolla_v2 is available on RubyGems with source code available on our GitHub page.
Getting Started
Installation
To begin using this SDK, you will first need to download it to your machine. We use RubyGems to distribute this package. Add this line to your application’s Gemfile:Initialization
Before any API requests can be made, you must first determine which environment you will be using, as well as fetch the application key and secret. To fetch your application key and secret, please visit one of the following links:- Production: https://dashboard.dwolla.com/applications
- Sandbox: https://dashboard-sandbox.dwolla.com/applications
Client with key and secret replaced with the application key and secret that you fetched from one of the aforementioned links, respectively.
Configure Faraday (Optional)
Dwolla for Ruby uses Faraday to make HTTP requests. You can configure your own Faraday middleware and adapter when configuring your client. Remember to always include an adapter last, even if you want to use the default adapter.Making Requests
Once you’ve created aClient, currently, you can make low-level HTTP requests.
Low-level Requests
To make low-level HTTP requests, you can use theget(), post(), and delete() methods.
GET
POST
DELETE
Setting Headers
To set additional headers on a request, you can pass aHash of headers as the 3rd argument.
For example:
Responses
The following snippets demonstrate successful and errored responses from the Dwolla API. An errored response is returned when Dwolla’s servers respond with a status code that is greater than or equal to 400, whereas a successful response is when Dwolla’s servers respond with a 200-level status code.Success
Successful requests return aDwollaV2::Response.
Error
If the server returns an error, aDwollaV2::Error (or one of its subclasses) will be raised.
DwollaV2::Errors are similar to DwollaV2::Responses.
DwollaV2::Error subclasses:
See https://developers.dwolla.com/api-reference#errors for more info.
- DwollaV2::AccessDeniedError
- DwollaV2::InvalidCredentialsError
- DwollaV2::NotFoundError
- DwollaV2::BadRequestError
- DwollaV2::InvalidGrantError
- DwollaV2::RequestTimeoutError
- DwollaV2::ExpiredAccessTokenError
- DwollaV2::InvalidRequestError
- DwollaV2::ServerError
- DwollaV2::ForbiddenError
- DwollaV2::InvalidResourceStateError
- DwollaV2::TemporarilyUnavailableError
- DwollaV2::InvalidAccessTokenError
- DwollaV2::InvalidScopeError
- DwollaV2::UnauthorizedClientError
- DwollaV2::InvalidAccountStatusError
- DwollaV2::InvalidScopesError
- DwollaV2::UnsupportedGrantTypeError
- DwollaV2::InvalidApplicationStatusError
- DwollaV2::InvalidVersionError
- DwollaV2::UnsupportedResponseTypeError
- DwollaV2::InvalidClientError
- DwollaV2::MethodNotAllowedError
- DwollaV2::ValidationError
- DwollaV2::TooManyRequestsError
- DwollaV2::ConflictError
Community
- If you have any feedback, please reach out to us on our forums or by creating a GitHub issue.
- If you would like to contribute to this library, bug reports and pull requests are always appreciated!
- After checking out the repo, run bin/setupto install dependencies. Then, runrake specto run the tests. You can also runbin/consolefor an interactive prompt that will allow you to experiment.
- To install this gem onto your local machine, run bundle exec rake install. To release a new version, update the version number inversion.rb, and then runbundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the.gemfile to rubygems.org.
 
- After checking out the repo, run