- Messente API version: 2.0.0
- C# package version: 4.1.1
Messente is a global provider of messaging and user verification services. * Send and receive SMS, Viber and WhatsApp messages. * Manage contacts and groups. * Fetch detailed info about phone numbers. * Blacklist phone numbers to make sure you're not sending any unwanted messages. Messente builds tools to help organizations connect their services to people anywhere in the world.
Install Messente API library via NuGet Package Manager or .NET CLI.
Install-Package com.Messente.Api -Version 4.1.1
dotnet add package com.Messente.Api --version 4.1.1
Messente API has the following features:
- Omnichannel (external docs),
- Phonebook (external docs).
Messente API Library provides the operations described below to access the features.
- Get account balance GetAccountBalance
- Get account balance GetAccountBalanceUsingPost
- Adds a phone number to the blacklist AddToBlacklist
- Deletes a phone number from the blacklist DeleteFromBlacklist
- Returns all blacklisted phone numbers FetchBlacklist
- Checks if a phone number is blacklisted IsBlacklisted
- Sends a bulk Omnimessage SendBulkOmnimessage
- Adds a contact to a group AddContactToGroup
- Creates a new contact CreateContact
- Deletes a contact DeleteContact
- Lists a contact FetchContact
- Lists groups of a contact FetchContactGroups
- Returns all contacts FetchContacts
- Removes a contact from a group RemoveContactFromGroup
- Updates a contact UpdateContact
- Retrieves the delivery report for the Omnimessage RetrieveDeliveryReport
- Creates a new group with the provided name CreateGroup
- Deletes a group DeleteGroup
- Lists a group FetchGroup
- Returns all groups FetchGroups
- Updates a group with the provided name UpdateGroup
- Requests info about phone numbers FetchInfo
- verify number VerifyNumber
- verified the PIN code entered by the user. VerifyPin
- Cancels a scheduled Omnimessage CancelScheduledMessage
- Sends an Omnimessage SendOmnimessage
- Get pricelist for account GetPricelist
- Get pricing for a specific country GetPrices
- Requests statistics reports for each country CreateStatisticsReport
- Creates a WhatsApp template CreateWhatsappTemplate
- Deletes a WhatsApp template DeleteWhatsappTemplate
- Requests a WhatsApp template with the given ID GetWhatsappTemplateById
- Requests a list of WhatsApp templates ListWhatsappTemplates
- Updates a WhatsApp template UpdateWhatsappTemplate
Type: HTTP basic authentication
Read the external getting-started article which explains API keys and Sender ID logic.
// PM > Install-Package com.Messente.Api
using System;
using com.Messente.Api.Api;
using com.Messente.Api.Client;
using com.Messente.Api.Model;
namespace Example
{
    public class SendOmniMessageExample
    {
        public static void Main()
        {
            Configuration conf = new Configuration
            {
                Username = "YOUR_MESSENTE_API_USERNAME",
                Password = "YOUR_MESSENTE_API_PASSWORD"
            };
            var apiInstance = new OmnimessageApi(conf);
            var sms = new SMS(sender: "<sender name (optional)>", text: "Hello SMS!");
            OmnimessageMessagesInner smsOmnimessageInner = new OmnimessageMessagesInner(sms)
            {
                ActualInstance = sms
            };
            var viber = new Viber(sender: "<sender name (optional)>", text: "Hello viber!");
            OmnimessageMessagesInner viberOmnimessageInner = new OmnimessageMessagesInner(viber)
            {
                ActualInstance = viber
            };
            WhatsAppParameter whatsAppParameter = new WhatsAppParameter(
                type: "text",
                text: "hello whatsapp"
            );
            WhatsAppComponent whatsAppComponent = new WhatsAppComponent(
                type: "body",
                parameters: new List<WhatsAppParameter> { whatsAppParameter }
            );
            WhatsAppTemplate whatsAppTemplate = new WhatsAppTemplate(
                name: "<template_name>",
                language: new WhatsAppLanguage(code: "<language_code>"),
                components: new List<WhatsAppComponent> { whatsAppComponent }
            );
            var whatsapp = new WhatsApp(
                sender: "<sender name (optional)>",
                template: whatsAppTemplate
            );
            OmnimessageMessagesInner whatsAppOmnimessageInner = new OmnimessageMessagesInner(whatsapp)
            {
                ActualInstance = whatsapp
            };
            var omnimessage = new Omnimessage(
                to: "<recipient_phone_number>",
                messages: new List<OmnimessageMessagesInner> {
                    smsOmnimessageInner,
                    viberOmnimessageInner,
                    whatsAppOmnimessageInner
                }
            );
            try
            {
                var result = apiInstance.SendOmnimessage(omnimessage);
                Console.WriteLine(result.ToJson());
            }
            catch (Exception e)
            {
                Console.WriteLine("Exception when calling SendOmnimessage: " + e.Message);
            }
        }
    }
}