Misar Docs
MisarMailMisar.BlogMisarReachMisarPostMisar.DevMisar PlatformMisar IdentityMisar Posts API
Sdks

Ruby SDK

Install and use the MisarMail Ruby SDK

Installation

gem install misarmail

Or add to your Gemfile:

gem 'misarmail'

Quick Start

require 'misarmail'

client = MisarMail::Client.new(api_key: ENV['MISARMAIL_API_KEY'])

result = client.send(
  from:    { email: '[email protected]', name: 'Misar' },
  to:      [{ email: '[email protected]' }],
  subject: 'Welcome',
  html:    '<p>Hello from MisarMail!</p>'
)

puts "Sent: #{result.message_id}"

Available Methods

MethodDescription
client.send(**params)Send a transactional email
client.contacts.list(**params)List contacts
client.contacts.create(**params)Create a contact
client.contacts.get(id)Get a contact
client.contacts.update(id, **params)Update a contact
client.contacts.delete(id)Delete a contact
client.contacts.import_contacts(**params)Bulk import/upsert contacts
client.campaigns.list(**params)List campaigns
client.campaigns.create(**params)Create a campaign
client.campaigns.get(id)Get a campaign
client.campaigns.update(id, **params)Update a campaign
client.campaigns.send(id)Send a campaign
client.campaigns.delete(id)Delete a campaign
client.templates.list(**params)List templates
client.templates.create(**params)Create a template
client.templates.get(id)Get a template
client.templates.update(id, **params)Update a template
client.templates.delete(id)Delete a template
client.templates.render(id, **params)Render a template with merge data
client.automations.list(**params)List automations
client.automations.create(**params)Create an automation
client.automations.get(id)Get an automation
client.automations.update(id, **params)Update an automation
client.automations.delete(id)Delete an automation
client.automations.activate(id)Activate/deactivate an automation
client.domains.listList sending domains
client.domains.create(**params)Add a sending domain
client.domains.get(id)Get a domain
client.domains.verify(id)Trigger domain DNS verification
client.domains.delete(id)Delete a domain
client.aliases.list(**params)List email aliases
client.aliases.create(**params)Create an alias
client.aliases.get(id)Get an alias
client.aliases.update(id, **params)Update an alias
client.aliases.delete(id)Delete an alias
client.dedicated_ips.listList dedicated IPs
client.dedicated_ips.create(**params)Purchase a dedicated IP
client.dedicated_ips.update(id, **params)Update IP pool assignment
client.dedicated_ips.delete(id)Release a dedicated IP
client.ab_tests.list(**params)List A/B tests
client.ab_tests.create(**params)Create an A/B test
client.ab_tests.get(id)Get an A/B test
client.ab_tests.set_winner(id, variant)Manually set the winning variant
client.sandbox.send(**params)Send in sandbox mode
client.sandbox.list(**params)List sandbox messages
client.sandbox.delete(id)Delete a sandbox message
client.inbound.list(**params)List inbound routing rules
client.inbound.create(**params)Create an inbound route
client.inbound.get(id)Get an inbound route
client.inbound.delete(id)Delete an inbound route
client.analytics.overview(**params)Get send/open/click/bounce analytics
client.track.event(**params)Track a custom event
client.track.purchase(**params)Track a purchase event
client.keys.listList API keys
client.keys.create(**params)Create an API key
client.keys.get(id)Get an API key
client.keys.revoke(id)Revoke an API key
client.validate.email(address)Validate an email address
client.webhooks.list(**params)List webhooks
client.webhooks.create(**params)Create a webhook endpoint
client.webhooks.get(id)Get a webhook
client.webhooks.update(id, **params)Update a webhook
client.webhooks.delete(id)Delete a webhook
client.webhooks.test(id)Send a test event to a webhook
client.usage.get(**params)Get API usage stats
client.billing.subscriptionGet current subscription details
client.billing.checkout(**params)Create a billing checkout session
client.workspaces.listList workspaces
client.workspaces.create(**params)Create a workspace
client.workspaces.get(id)Get a workspace
client.workspaces.update(id, **params)Update a workspace
client.workspaces.delete(id)Delete a workspace
client.workspaces.list_members(id)List workspace members
client.workspaces.invite_member(id, **params)Invite a member to workspace
client.workspaces.update_member(id, user_id, **params)Update member role
client.workspaces.remove_member(id, user_id)Remove a member from workspace

Examples

Webhooks

webhook = client.webhooks.create(
  url: 'https://yourapp.com/webhooks/mail',
  events: %w[email.delivered email.opened email.bounced]
)
client.webhooks.test(webhook.id)

Error Handling

begin
  client.send(...)
rescue MisarMail::APIError => e
  puts "#{e.status_code}: #{e.message}"
end