# Messente API Library - Messente API version: 1.0.2 - Ruby gem version: 1.0.2 [Messente](https://messente.com) is a global provider of messaging and user verification services. Use Messente API library to send and receive SMS, Viber and WhatsApp messages, blacklist phone numbers to make sure you're not sending any unwanted messages, manage contacts and groups. Messente builds [tools](https://messente.com/documentation) to help organizations connect their services to people anywhere in the world. ## Installation Install Messente API library with `gem install messente_api`. ## Features Messente API has the following features: - Omnichannel ([external docs](https://messente.com/documentation/omnichannel-api)), - Phonebook ([external docs](https://messente.com/documentation/phonebook-api)). Messente API Library provides the operations described below to access the features. ### BlacklistApi 1. Adds a phone number to the blacklist [`add_to_blacklist`](docs/BlacklistApi.md#add_to_blacklist) 1. Deletes a phone number from the blacklist [`delete_from_blacklist`](docs/BlacklistApi.md#delete_from_blacklist) 1. Returns all blacklisted phone numbers [`fetch_blacklist`](docs/BlacklistApi.md#fetch_blacklist) 1. Checks if a phone number is blacklisted [`is_blacklisted`](docs/BlacklistApi.md#is_blacklisted) ### ContactsApi 1. Adds a contact to a group [`add_contact_to_group`](docs/ContactsApi.md#add_contact_to_group) 1. Creates a new contact [`create_contact`](docs/ContactsApi.md#create_contact) 1. Deletes a contact [`delete_contact`](docs/ContactsApi.md#delete_contact) 1. Lists a contact [`fetch_contact`](docs/ContactsApi.md#fetch_contact) 1. Lists groups of a contact [`fetch_contact_groups`](docs/ContactsApi.md#fetch_contact_groups) 1. Returns all contacts [`fetch_contacts`](docs/ContactsApi.md#fetch_contacts) 1. Removes a contact from a group [`remove_contact_from_group`](docs/ContactsApi.md#remove_contact_from_group) 1. Updates a contact [`update_contact`](docs/ContactsApi.md#update_contact) ### DeliveryReportApi 1. Retrieves the delivery report for the Omnimessage [`retrieve_delivery_report`](docs/DeliveryReportApi.md#retrieve_delivery_report) ### GroupsApi 1. Creates a new group with the provided name [`create_group`](docs/GroupsApi.md#create_group) 1. Deletes a group [`delete_group`](docs/GroupsApi.md#delete_group) 1. Lists a group [`fetch_group`](docs/GroupsApi.md#fetch_group) 1. Returns all groups [`fetch_groups`](docs/GroupsApi.md#fetch_groups) 1. Updates a group with the provided name [`update_group`](docs/GroupsApi.md#update_group) ### OmnimessageApi 1. Cancels a scheduled Omnimessage [`cancel_scheduled_message`](docs/OmnimessageApi.md#cancel_scheduled_message) 1. Sends an Omnimessage [`send_omnimessage`](docs/OmnimessageApi.md#send_omnimessage) ## Auth **Type**: HTTP basic authentication Read the [external getting-started article](https://messente.com/documentation/getting-started) which explains API keys and Sender ID logic. ## Getting started: sending an omnimessage ```ruby require 'messente_api' # setup authorization MessenteApi.configure do |config| # Configure HTTP basic authorization: basicAuth config.username = '' config.password = '' end api_instance = MessenteApi::OmnimessageApi.new omnimessage = MessenteApi::Omnimessage.new omnimessage.to = '' omnimessage.messages = [ MessenteApi::SMS.new( { :sender => "", :text => "Hello SMS!" } ), MessenteApi::WhatsApp.new( { :sender => "", :text => MessenteApi::WhatsAppText.new( { :body => "Hello from WhatsApp!", :preview_url => false } ) } ), MessenteApi::Viber.new( { :sender => "", :text => "Hello from Viber!" } ) ] begin result = api_instance.send_omnimessage(omnimessage) rescue MessenteApi::ApiError => e puts "Exception when calling send_omnimessage: #{e}" puts e.response_body end ``` ## License [Apache 2.0](http://www.apache.org/licenses/LICENSE-2.0.html) ## Terms [https://messente.com/terms-and-conditions](https://messente.com/terms-and-conditions)