Skip to main content
Skip table of contents

SMS Opt In/Out Queue

Summary

The Opt In/Out Queue API allows our client to opt in or out their subscribers or customers to their SMS Message Types at the message type level.

Base Resource URI

CODE
For Production, use: https://ows.omeda.com/webservices/rest/brand/{brandAbbreviation}/messageoptqueue/*

For Testing, use: https://ows.omedastaging.com/webservices/rest/brand/{brandAbbreviation}/messageoptqueue/*

brandAbbreviation is the abbreviation for the brand who is posting the data.

Technical Requirements

The HTTP header must contain the following elements: x-omeda-appid a unique id provided to you by Omeda to access your data. The request will fail without a valid id. content-type a content type supported by this resource. See Supported Content Types for more details. If omitted, the default content type is application/json.

Supported Content Types

There are three content types supported. If omitted, the default content type is application/json. JSON application/json

JSON is the preferred data exchange format, because it is lightweight and, in most cases, faster to process and utilizes less bandwidth. There are many available open-source JSON libraries available. See json.org for details.

Supported HTTP Methods

There is one HTTP method supported: POST See W3C’s POST specs for details.

Field Definition

The following tables describe the data elements that can be included in the POST method to store data in the database.

Opts Elements

Attribute Name

Required?

Data Type

Description

SiteId

Optional

Integer

The Form ID of where the message type opt in/out is posting from.

SiteSessionId

Optional

String

The site session id of the request.

CountryCallingCode

Required

Integer

The country calling code of the customer’s cell phone number for which the message type opt in/out is requested.

PhoneNumber

Required

Integer

The customer’s cell phone number for which the message type opt-in/out is requested.

MessageOpts

Optional

Array

Array element containing one or multiple MessageOpts elements (see below)

MessageOpts Elements

Attribute Name

Required?

Data Type

Description

Status

Required

Integer

Value of the opt in/out requested. 0 or 1.

1 = opt in
0 = opt out

MessageTypeId

Required

Integer

The message type id for which the opt in/out is requested.

DeleteOptOut

optional

integer

0 or 1, 0 = No delete, 1 = Delete.

Request Examples

In these examples, we’re submitting:

CODE
A Message Type-level OptIn for Message Type Id 6 for cell phone number +16303303039, 
and we want to delete all corresponding OptOuts for that cell phone number (DeleteOptOut=1)

A Message Type-level OptIn for Message Types 7 for cell phone number +17083303909, 
but do not delete all corresponding OptOuts for that cell phone number (no DeleteOptOut)

JSON Example

CODE
{
  "SiteId": 498,
  "SiteSessionId": "ECD8906C31075A7A44F98F39E5F57671",
  "PhoneNumber": "6303303039",
  "CountryCallingCode": 1,
  "MessageOpts": [
    {
      "Status": 1,
      "DeleteOptOut": 1,
      "MessageTypeId": [
        6
      ]
    }
  ]
}

CODE
{
  "SiteId": 498,
  "SiteSessionId": "ECD8906C31075A7A44F98F39E5F57671",
  "PhoneNumber": "7083303909",
  "CountryCallingCode": 1,
  "MessageOpts": [
    {
      "Status": 1,
      "DeleteOptOut": 0,
      "MessageTypeId": [
        7
      ]
    }
  ]
}

Response Examples

Two responses are possible: a successful POST (200 OK Status) or a failed POST (400 Bad Request/403 Forbidden/404 Not Found/405 Method Not Allowed Statuses). See W3C’s Status Codes.

Successful Submission

A successful POST submission may create Opt in/out entries. Messages may be returned in some cases.

JSON Example

If all Opts have been processed Without any messages returned, you will get the following response:

CODE
{
   "Submission":"1be32302-8cbc-4106-96db-e79e17de6490",
   "Success":"Your submission was successful"
}

If you submit a request Without “DeleteOptOut”:1, it may be possible that zero, one or more OptIns have not been processed. A “Message” element will describe the reason why the specific OptIn has not been processed.

Failed Submission

A failed POST submission may be due to several factors:

Status

Description

400 Bad Request

Typically, this error occurs when the request does not follow the specifications.

403 Forbidden

Typically, this error occurs when the credentials are erroneous. Potentially, an incorrect x-omeda-appid.

404 Not Found

Typically, this error occurs with a malformed URL or the resource that is searched for is not found.

405 Method Not Allowed

Typically, this error occurs when the resource accessed is not allowed by the HTTP Method utilized. Make sure you employ the correct HTTP Method (POST) for this request.

This is not an exhaustive list of errors, but common ones. If an error occurs repeatedly, please contact your Omeda representative.

IMPORTANT: If an error occurs, NONE of the Opts submitted will be processed. The errors array simply indicates the reason why the request was rejected. Fixing the errors in the error array and resubmitting the request should work, provided no new errors have been re-introduced. Please contact your Omeda representative if you need assistance.

JSON Example

For each MessageTypeId submitted, our system verifies that it belongs to a BrandId, and that the BrandId is authorized to receive Opts for the x-omeda-appid submitted. If this occurs, you would get the error message below.

CODE
{
   "Submission":"31f8c71a-d2f8-47a6-9b58-fc56439ffe9a",
   "Errors":[
      {
         "Error":"MessageOpts submission (4194): the MessageTypeId is not authorized for Opts for the AppId submitted. Phone number 6303030983 was not opted in."
      },
      {
         "Error":"There were errors with your submission.  None of the Opts submitted in your request were created."
      }
   ]
}

Additional Information

DeleteOptOut Rules

By convention, we use “DeleteOptOut” to determine whether an ‘IN’ submission will override an existing ‘OUT’ submission.

Rule

Action

DeleteOptOut not set to 1 or omitted

If an ‘OUT’ entry exists in the database for the given submission, then the ‘IN’ is not written for this submission. The ‘OUT’ remains.

DeleteOptOut = 1

If an ‘OUT’ entry exists for a submission, it will be overwritten with the ‘IN’ that is being submitted.

Table of Contents

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.