uni_sender gem provides full ruby dev kit to access API of unisender.com.ua. It uses method_missing
to provide flexible functionality. All methods will return hash that represents response from the server. To experiment with the code, run pry
for an interactive prompt.
Add this line to your application's Gemfile:
gem 'uni_sender'
And then execute:
$ bundle
Or install it yourself as:
$ gem install uni_sender
Gem provides class UniSender::Client
for accessing server's API. For creating client you need your personal key
client = UniSender::Client.new("your secret key")
Sandbox mode API key "2pF44VzCfXmNSVOJtMhgBTLzTWlZokU8w"
client = UniSender::Client.new("2pF44VzCfXmNSVOJtMhgBTLzTWlZokU8w")
Retrieve mailing lists with their codes
client.get_lists
Create a new mailing list
client.create_list({ :title => "NewListTitle" })
Subscribe addressee on one or several mailing lists
client.subscribe({
:list_ids => [1, 2],
:fields => {
:email => "dougal.mcguire@example.com",
:phone => "+380987654321",
:name => "Dougal"
}
})
Create an e-mail to a mass mailing
client.create_email_message({
:sender_name => "Test Name",
:sender_email => "test@example.com",
:list_id => 1,
:lang => "en",
:subject => "Subject",
:body => "Body"
})
Sending individual email message
client.send_email({
:sender_name => "Test Name",
:sender_email => "test@example.com",
:list_id => 1,
:lang => "en",
:subject => "Subject",
:body => "Body",
:email => "receiver@example.com"
})
Create SMS for mass mailing
client.create_sms_message({
:sender => "CompanyName",
:list_id => 1,
:body => "Sample SMS message"
})
Send SMS-message
client.create_sms_message({
:phone => "+380987654321",
:sender => "MyCompany",
:list_id => 1,
:body => "Sample SMS message",
:text => "Hello, it's a test message"
})
Gem provides non-sensitive style, so action getLits
will equal to get_lists
For getting contacts call client.exportContacts
(or client.export_contacts
). If request will be accepted client will return hash in the next format:
{ 'result' => { 'field_names' => [...], 'data' => [[...], [...], ... ] } }
Before sent action to server gem processes all parameters.
If parameter is array, uni_sender
will join contents by comma, also process all items like string
{ :sample => [233, 'foo', 545] }
will be transformed to sample=233,foo,545
Hash
will be encoded into nested variables, for example:
{ :friend => { :name => "Роман", :car => "BMW" } }
will be friend[name]=Роман&friend[car]=BMW
Keep in mind, that field_names
and data
for API method importContacts
translated in the different way
field_names[0]=email&field_names[1]=email_list_ids&
data[0][0]=a@example.com&data[0][1]=123&data[1][0]=b@example.org
After checking out the repo, run bundle install
to install dependencies. Then, run rake spec
to run the tests. You can also run pry
for an interactive prompt that will allow you to experiment.
For more information about API methods please visit:
General information about UniSender API
Bug reports and pull requests are welcome on GitHub at https://github.com/sharkzp/uni_sender. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
The gem is available as open source under the terms of the MIT License.