Evo Voice

<back to all web services

NewDeviceToken

Create a new device token if it doesn't exist already

Requires Authentication
Required role:User
The following routes are available for this service:
POST/app/tokens
import datetime
import decimal
from marshmallow.fields import *
from servicestack import *
from typing import *
from dataclasses import dataclass, field
from dataclasses_json import dataclass_json, LetterCase, Undefined, config
from enum import Enum, IntEnum


class DeviceTypes(str, Enum):
    WEB = 'Web'
    I_O_S = 'iOS'
    ANDROID = 'Android'


@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class DeviceTokenInfo:
    device_type: Optional[DeviceTypes] = None
    token: Optional[str] = None


# @Api(Description="Create a new device token if it doesn't exist already")
@dataclass_json(letter_case=LetterCase.CAMEL, undefined=Undefined.EXCLUDE)
@dataclass
class NewDeviceToken(IPost):
    """
    Create a new device token if it doesn't exist already
    """

    # @ApiMember(Description="The type of device")
    device_type: Optional[DeviceTypes] = None
    """
    The type of device
    """


    # @ApiMember(Description="The device token to save")
    token: Optional[str] = None
    """
    The device token to save
    """

Python NewDeviceToken DTOs

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

To embed the response in a jsonp callback, append ?callback=myCallback

HTTP + JSON

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

POST /app/tokens HTTP/1.1 
Host: evovoice.io 
Accept: application/json
Content-Type: application/json
Content-Length: length

{"deviceType":"Web","token":"String"}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: length

{"deviceType":"Web","token":"String"}