Skip to content

infobip/infobip-api-go-client

Repository files navigation

Infobip API Go Client

Infobip

Go Reference MIT License

This is a Go module for Infobip API and you can use it as a dependency when you want to consume Infobip APIs in your application. To use this, you'll need an Infobip account. You can create a free trial account here.

infobip-api-go-client is built on top of OpenAPI Specification, powered by OpenAPI Generator.

Table of contents:

Documentation

Detailed documentation about Infobip API can be found here. The current version of this library includes this subset of Infobip products:

General Info

For infobip-api-go-client versioning we use Semantic Versioning scheme.

Published under MIT License.

Minimum Go version supported by this library is 1.18.

Installation

Pull the library by using the following command:

go get github.com/infobip/infobip-api-go-client/v3

To use our library you have to import it in your project files:

import "github.com/infobip/infobip-api-go-client/v3"

Afterwards, to update your go.mod and go.sum files, simply run the following:

go mod tidy

Quickstart

Initialize the Client

In order to initialize the client first you need to set some basics like configuration and authentication.

We support multiple authentication methods, e.g. you can use API Key or any of the other supported approaches. Once you have an Infobip account, you can manage your API keys through the Infobip API key management page.

To see your base URL, log in to the Infobip API Resource hub with your Infobip credentials or visit your Infobip account.

Let's first set the configuration field.

configuration := infobip.NewConfiguration()
configuration.Host = "<YOUR_BASE_URL>"

Now you can initialize the API client.

infobipClient := api.NewAPIClient(configuration)

For details, check the client source code.

Authentication

After that is done, we should set the authentication method.

auth := context.WithValue(
		context.Background(),
		infobip.ContextAPIKeys,
		map[string]infobip.APIKey{
			"APIKeyHeader": {Key: "<YOUR_API_KEY>", Prefix: "<YOUR_API_PREFIX>"},
		},
	)

To understand how to generate above mentioned tokens, check this page.

That is it, now you are set to use the API.

Send an SMS

Here's a basic example of sending the SMS message.

    import (
    	"context"
    	"fmt"

    	"github.com/infobip/infobip-api-go-client/v3/pkg/infobip"
    	"github.com/infobip/infobip-api-go-client/v3/pkg/infobip/api"
    	"github.com/infobip/infobip-api-go-client/v3/pkg/infobip/models/sms"
    )

    ...

    destinations := []sms.Destination{
		{To: "421907372599"},
	}

	content := sms.LogContent{
		TextMessageContent: sms.NewTextMessageContent("Congratulations on sending your first message with GO library."),
	}

	givenMessage := sms.NewMessage(destinations, content)
	givenMessage.SetSender("421902028966")

	request := sms.NewRequestEnvelope([]sms.Message{
		*givenMessage,
	})

	// Send the SMS message
	apiResponse, httpResponse, err := infobipClient.
		SmsAPI.
		SendSmsMessages(auth).
		RequestEnvelope(*request).
		Execute()

// If, for any reason, you don't want to use some of the response fields, feel free to replace them with an underscore wildcard, eg. // apiResponse, _, _ := ...


In order to be able to access our generated `Exception` models, you will have to do a little bit of type casting.
Methods provided within `ServiceException` object are `GetMessageId()` and `GetText()` referring to the nature of the exception.
Withing the `http.Response` response field (in example labeled as `httpResponse`) you can find pretty much everything that is referring to the HTTP status, e.g. `Status`, `StatusCode`, `Body`, `Header`, etc.

```go
if err != nil {
    apiErr, isApiErr := err.(*api.GenericOpenAPIError)
    if isApiErr {
        ibErr, isIbErr := apiErr.Model().(sms.ApiException)
        if isIbErr {
            errMessageId := ibErr.RequestError.ServiceException.GetMessageId()
            errText := ibErr.RequestError.ServiceException.GetText()
            // HANDLE THE IB ERROR EXCEPTION
        } else {
            // HANDLE THE API ERROR EXCEPTION
        }
    } else {
        // HANDLE THE EXCEPTION
    }
    return
}

Additionally, you can retrieve a the bulkId and messageId from the successful response (SmsResponse object) to use for fetching a delivery report for a given message or a bulk. Bulk ID is received only when you send a message to more than one destination address or send multiple messages in a single request.

bulkId := *apiResponse.BulkId
messageId := *apiResponse.Messages[0].MessageId

Receive sent SMS report

For each SMS that you send out, we can send you a message delivery report in real time. All you need to do is specify your endpoint when sending SMS in notifyUrl field of SmsTextualMessage, or subscribe for reports by contacting our support team. e.g. https://{yourDomain}/delivery-reports

Example of webhook implementation:

func deliveryReports(w http.ResponseWriter, req *http.Request) {
    reqBody, _ := io.ReadAll(req.Body)
    var report sms.DeliveryResult
    err := json.Unmarshal(reqBody, &report)
    if err != nil {
        fmt.Println("Error:", err)
        return
    }

    if report.HasResults() {
        results := report.GetResults()
        for _, result := range results {
            status := result.GetStatus()
            fmt.Println(fmt.Sprintf("%s - %s", result.GetMessageId(), status.GetName()))
        }
    }
}

func main() {
    http.HandleFunc("/delivery-reports", deliveryReports)
}

If you prefer to use your own serializer, please pay attention to the supported date format. In this library, we are wrapping around the time.Time model with our own infobip.Time in order to enforce the time format to be serialized properly.

Unicode & SMS preview

Infobip API supports Unicode characters and automatically detects encoding. Unicode and non-standard GSM characters use additional space, avoid unpleasant surprises and check how different message configurations will affect your message text, number of characters and message parts.

text := "Let's see how many characters will remain unused in this message."
request := sms.NewPreviewRequest(text)

apiResponse, httpResponse, err := infobipClient.
    SendSmsApi.
    PreviewSmsMessage(auth).
    SmsPreviewRequest(*request).
    Execute()

Receive incoming SMS

If you want to receive SMS messages from your subscribers we can have them delivered to you in real time. When you buy and configure a number capable of receiving SMS, specify your endpoint as explained here. e.g. https://{yourDomain}/incoming-sms.

Example of webhook implementation:

func incomingSms(w http.ResponseWriter, req *http.Request) {
    reqBody, _ := io.ReadAll(req.Body)
    var result sms.InboundMessageResult
    err := json.Unmarshal(reqBody, &result)
    if err != nil {
        fmt.Println("Error:", err)
        return
    }

    if result.HasResults() {
        msgs := result.GetResults()
        for _, msg := range msgs {
            fmt.Println(fmt.Sprintf("%s - %s", msg.GetFrom(), msg.GetCleanText()))
        }
    }
}

func main() {
    http.HandleFunc("/incoming-sms", incomingSms)
}

Two-Factor Authentication (2FA)

For 2FA quick start guide please check these examples.

Messages API

For Messages API quick start guide, view these examples.

Ask for help

Feel free to open issues on the repository for any issue or feature request. As per pull requests, for details check the CONTRIBUTING file related to it - in short, we will not merge any pull requests, this code is auto-generated.

If it is, however, something that requires our imminent attention feel free to contact us @ [email protected].