How to Send MMS in Go using Plivo’s Messaging API

How to Send MMS in Go using Plivo’s Messaging API

Overview

This guide shows how to send an MMS message to any phone number. Businesses can make messages more meaningful by using MMS instead of SMS and including images, audio, and video to provide context.

Here’s how to use Plivo’s SMS APIs to send outbound MMS text messages.

How it works

Prerequisites

To get started, you need a Plivo account — sign up with your work email address if you don’t have one already. If this is your first time using Plivo APIs, follow our instructions to set up a Go development environment.

Create the send MMS application

Create a file called SendMMS.go and paste into it this code.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
package main

import (
        "fmt"
        plivo "github.com/plivo/plivo-go/v7"
)

func main() {

        client, err := plivo.NewClient("<auth_id>","<auth_token>",
                &plivo.ClientOptions{})
        if err != nil {
                panic(err)
        }
        createResp, err := client.Messages.Create(plivo.MessageCreateParams{
                Src: "<sender_id>",
                Dst:  "<destination_number>",
                Text: "Hello, from Go!",
                Type: "mms",
                MediaUrls: []string
                {"https://media.giphy.com/media/26gscSULUcfKU7dHq/source.gif"},
                MediaIds: []string{"801c2056-33ab-499c-80ef-58b574a462a2"},
        })
        if err != nil {
                panic(err)
        }

Replace the auth placeholders with your authentication credentials from the Plivo console. Replace the phone number placeholders with actual phone numbers in E.164 format (for example, +12025551234). In countries other than the US and Canada you can use a sender ID for the message source. You must have a Plivo phone number to send messages to the US or Canada; you can buy a Plivo number from Phone Numbers > Buy Numbers on the Plivo console or via the Numbers API.

Note: We recommend that you store your credentials in the auth_id and auth_token environment variables to avoid the possibility of accidentally committing them to source control. If you do this, you can initialize the client with no arguments and Plivo will automatically fetch the values from the environment variables. You can use os.Setenv and os.Getenv functions to store environment variables and fetch them when initializing the client.

Test

Save the file and run it.

go run SendMMS.go

Note: If you’re using a Plivo Trial account, you can send messages only to phone numbers that have been verified with Plivo. You can verify (sandbox) a number by going to the console’s Phone Numbers > Sandbox Numbers page.


Haven’t tried Plivo yet? Getting started is easy and only takes minutes. Sign up today.

Get Volume Pricing

Thousands of businesses in more than 220 countries trust Plivo’s cloud communications platform

The best communications platform forthe world’s leading entertainment service

Frequently asked questions

No items found.
footer bg

Subscribe to Our Newsletter

Get monthly product and feature updates, the latest industry news, and more!

Thank you icon
Thank you!
Thank you for subscribing
Oops! Something went wrong while submitting the form.