Evo Voice

<back to all web services

SendMessage

Requires Authentication
Required role:User
The following routes are available for this service:
POST/sessions/{sessionId}/messages
All Verbs/messages
Imports System
Imports System.Collections
Imports System.Collections.Generic
Imports System.Runtime.Serialization
Imports ServiceStack
Imports ServiceStack.DataAnnotations
Imports Voice.Api.Sessions
Imports Voice.Api.Messaging

Namespace Global

    Namespace Voice.Api.Messaging

        Public Enum MessageDirections
            Incoming
            Outgoing
        End Enum

        Public Partial Class MessageInfo
            Public Overridable Property Id As String
            Public Overridable Property AccountId As String
            Public Overridable Property CustomerId As String
            Public Overridable Property EndpointId As String
            Public Overridable Property EndpointDisplayName As String
            Public Overridable Property [Date] As String
            Public Overridable Property Direction As MessageDirections
            Public Overridable Property OtherAddress As String
            Public Overridable Property Sender As String
            Public Overridable Property Text As String
            Public Overridable Property IsUnread As Boolean
        End Class
    End Namespace

    Namespace Voice.Api.Sessions

        Public Partial Class SendMessage
            '''<Summary>
            '''The ID of the session you want to post a message to. Specify either this or EndpointId+ToAddress
            '''</Summary>
            <ApiMember(Description:="The ID of the session you want to post a message to. Specify either this or EndpointId+ToAddress")>
            Public Overridable Property SessionId As String

            '''<Summary>
            '''The ID of the endpoint you want to post a message to. Typically the ID of a phone number endpoint. Not used if SessionId is specified
            '''</Summary>
            <ApiMember(Description:="The ID of the endpoint you want to post a message to. Typically the ID of a phone number endpoint. Not used if SessionId is specified")>
            Public Overridable Property EndpointId As String

            '''<Summary>
            '''The address of the party you want to send a message to, e.g. +15556667777. Not used if SessionId is specified
            '''</Summary>
            <ApiMember(Description:="The address of the party you want to send a message to, e.g. +15556667777. Not used if SessionId is specified")>
            Public Overridable Property ToAddress As String

            '''<Summary>
            '''The body of the message
            '''</Summary>
            <ApiMember(Description:="The body of the message")>
            Public Overridable Property Body As String
        End Class
    End Namespace
End Namespace

VB.NET SendMessage DTOs

To override the Content-type in your clients, use the HTTP Accept Header, append the .csv suffix or ?format=csv

HTTP + CSV

The following are sample HTTP requests and responses. The placeholders shown need to be replaced with actual values.

POST /sessions/{sessionId}/messages HTTP/1.1 
Host: evovoice.io 
Accept: text/csv
Content-Type: text/csv
Content-Length: length

{"sessionId":"String","endpointId":"String","toAddress":"String","body":"String"}
HTTP/1.1 200 OK
Content-Type: text/csv
Content-Length: length

{"id":"String","accountId":"String","customerId":"String","endpointId":"String","endpointDisplayName":"String","date":"String","direction":"Incoming","otherAddress":"String","sender":"String","text":"String","isUnread":false}