Evo Voice

<back to all web services

ListFlows

Lists all the flows

Requires Authentication
Requires any of the roles:SystemAdministrator, Manager, Customer
The following routes are available for this service:
GET/flows
import java.math.*
import java.util.*
import java.io.InputStream
import net.servicestack.client.*
import com.google.gson.annotations.*
import com.google.gson.reflect.*


/**
* Lists all the flows
*/
@Api(Description="Lists all the flows")
open class ListFlows : ListRequest<FlowInfo>()
{
    /**
    * Filter by accounts
    */
    @ApiMember(Description="Filter by accounts")
    open var accountIds:ArrayList<String>? = null

    /**
    * The IDs of the customers whose flows you want to retrieve
    */
    @ApiMember(Description="The IDs of the customers whose flows you want to retrieve")
    open var customerIds:ArrayList<String>? = null

    /**
    * Filter by name
    */
    @ApiMember(Description="Filter by name")
    open var nameFilter:String? = null

    /**
    * The list of tag IDs to filter by (must contain all)
    */
    @ApiMember(Description="The list of tag IDs to filter by (must contain all)")
    open var tagIds:ArrayList<String>? = null

    /**
    * List flows by specific role
    */
    @ApiMember(Description="List flows by specific role")
    open var role:FlowRoles? = null

    /**
    * Exclude nodes
    */
    @ApiMember(Description="Exclude nodes")
    open var includeNodes:Boolean? = null

    /**
    * Node Type Filter
    */
    @ApiMember(Description="Node Type Filter")
    open var nodeTypeFilter:String? = null
}

open class ListRequest<T> : IGet
{
    /**
    * The page of data to retrieve
    */
    @ApiMember(Description="The page of data to retrieve")
    open var page:Int? = null

    /**
    * If you want all objects to be returned. This should be used with care
    */
    @ApiMember(Description="If you want all objects to be returned. This should be used with care")
    open var all:Boolean? = null

    /**
    * The number per page to retrieve
    */
    @ApiMember(Description="The number per page to retrieve")
    open var countPerPage:Int? = null

    /**
    * Specific IDs
    */
    @ApiMember(Description="Specific IDs")
    open var specificIds:ArrayList<String>? = null

    /**
    * Specify a sort field
    */
    @ApiMember(Description="Specify a sort field")
    open var sortField:String? = null

    /**
    * Specify a sort order
    */
    @ApiMember(Description="Specify a sort order")
    open var sortOrder:SortOrders? = null

    /**
    * Disables total / page counts - improves performance. Returns only data. If there is no more data, Items will be empty array
    */
    @ApiMember(Description="Disables total / page counts - improves performance. Returns only data. If there is no more data, Items will be empty array")
    open var simplifiedPaging:Boolean? = null
}

enum class SortOrders
{
    Ascend,
    Descend,
}

open class FlowInfo : EntityInfo()
{
    /**
    * The name of this flow
    */
    @ApiMember(Description="The name of this flow")
    open var name:String? = null

    /**
    * The roles that this flow has
    */
    @ApiMember(Description="The roles that this flow has")
    open var roles:ArrayList<FlowRoles>? = null

    /**
    * What this flow does
    */
    @ApiMember(Description="What this flow does")
    open var description:String? = null

    /**
    * Any notes for this flow
    */
    @ApiMember(Description="Any notes for this flow")
    open var notes:String? = null

    /**
    * The ID of the account associated with the flow
    */
    @ApiMember(Description="The ID of the account associated with the flow")
    open var accountId:String? = null

    /**
    * The name of the account associated with the flow
    */
    @ApiMember(Description="The name of the account associated with the flow")
    open var accountName:String? = null

    /**
    * The ID of the customer this flow is associated with
    */
    @ApiMember(Description="The ID of the customer this flow is associated with")
    open var customerId:String? = null

    /**
    * The name of the customer this flow is associated with
    */
    @ApiMember(Description="The name of the customer this flow is associated with")
    open var customerName:String? = null

    /**
    * The breadcrumb to the flow for this endpoint
    */
    @ApiMember(Description="The breadcrumb to the flow for this endpoint")
    open var customerBreadcrumb:ArrayList<CustomerBreadcrumb>? = null

    /**
    * The nodes in this flow
    */
    @ApiMember(Description="The nodes in this flow")
    open var nodes:ArrayList<FlowNode>? = null

    /**
    * The flow's parameters
    */
    @ApiMember(Description="The flow's parameters")
    open var parameters:ArrayList<FlowParameter>? = null

    /**
    * The flow's exits
    */
    @ApiMember(Description="The flow's exits")
    open var exits:ArrayList<FlowExit>? = null

    /**
    * The UI data for the flow
    */
    @ApiMember(Description="The UI data for the flow")
    open var ui:FlowUI? = null

    /**
    * The list of tags for this flow
    */
    @ApiMember(Description="The list of tags for this flow")
    open var tags:ArrayList<Tag>? = null

    /**
    * The number of nodes in this flow
    */
    @ApiMember(Description="The number of nodes in this flow")
    open var nodeCount:Int? = null
}

open class EntityInfo
{
    /**
    * The ID of the object
    */
    @ApiMember(Description="The ID of the object")
    open var id:String? = null

    /**
    * The date the object was created
    */
    @ApiMember(Description="The date the object was created")
    open var dateCreated:String? = null

    /**
    * The date the object was last modified
    */
    @ApiMember(Description="The date the object was last modified")
    open var dateLastModified:String? = null

    /**
    * The user that created this object
    */
    @ApiMember(Description="The user that created this object")
    open var createdBy:String? = null

    /**
    * The user that last modified this object
    */
    @ApiMember(Description="The user that last modified this object")
    open var lastModifiedBy:String? = null
}

enum class FlowRoles
{
    Ui,
    Reference,
    PhoneNumberRouting,
    UserDialOut,
    FaxNumberRouting,
}

open class CustomerBreadcrumb
{
    open var id:String? = null
    open var name:String? = null
}

open class FlowNode
{
    /**
    * The ID of this node. Must be unique within the flow but can be anything
    */
    @ApiMember(Description="The ID of this node. Must be unique within the flow but can be anything")
    open var id:String? = null

    /**
    * Is this the starting node for the flow. Only one node can have this set
    */
    @ApiMember(Description="Is this the starting node for the flow. Only one node can have this set")
    open var isStartNode:Boolean? = null

    /**
    * The name of the node, descriptive to be used as a reminder in the GUI
    */
    @ApiMember(Description="The name of the node, descriptive to be used as a reminder in the GUI")
    open var name:String? = null

    /**
    * The specification for the node
    */
    @ApiMember(Description="The specification for the node")
    open var spec:FlowNodeSpec? = null

    /**
    * The UI data for the node
    */
    @ApiMember(Description="The UI data for the node")
    open var ui:FlowNodeUI? = null

    /**
    * The data for this node. These will be POST'd to the endpoint when it is called.
    */
    @ApiMember(Description="The data for this node. These will be POST'd to the endpoint when it is called.")
    open var parameters:NodeParameterMap? = null
}

open class FlowNodeSpec
{
    /**
    * The name of this node
    */
    @ApiMember(Description="The name of this node")
    open var name:String? = null

    /**
    * A description of this node
    */
    @ApiMember(Description="A description of this node")
    open var description:String? = null

    /**
    * Icon class for this node (FontAwesome)
    */
    @ApiMember(Description="Icon class for this node (FontAwesome)")
    open var iconClass:String? = null

    /**
    * The type name for this node
    */
    @ApiMember(Description="The type name for this node")
    open var typeName:String? = null

    /**
    * The category this node should be grouped under
    */
    @ApiMember(Description="The category this node should be grouped under")
    open var category:FlowNodeCategories? = null

    /**
    * The URL where this node is located
    */
    @ApiMember(Description="The URL where this node is located")
    open var url:String? = null

    /**
    * The data type for this node
    */
    @ApiMember(Description="The data type for this node")
    open var dataType:DataType? = null

    /**
    * URL for documentation for this node
    */
    @ApiMember(Description="URL for documentation for this node")
    open var documentationUrl:String? = null

    /**
    * The channels that this node is restricted to
    */
    @ApiMember(Description="The channels that this node is restricted to")
    open var restrictToChannels:ArrayList<FlowChannels>? = null
}

enum class FlowNodeCategories
{
    General,
    Voice,
    Logic,
    DateAndTime,
    Audio,
    Messaging,
    Assistant,
    Flows,
    Fax,
    Network,
    Cookies,
    CallCenter,
    Intelligence,
}

open class DataType
{
    open var typeName:String? = null
    open var fields:ArrayList<DataField>? = null
}

open class DataField
{
    open var id:String? = null
    open var name:String? = null
    @SerializedName("type") open var Type:ValueTypes? = null
    open var uiHint:UIHints? = null
    open var uiTab:String? = null
    open var isAsync:Boolean? = null
    open var disableBinding:Boolean? = null
    open var structType:DataType? = null
    open var listType:DataType? = null
    open var description:String? = null
    open var possibleValues:ArrayList<String>? = null
    open var isOutput:Boolean? = null
    open var customFieldValuesUrl:String? = null
    open var defaultValue:Value? = null
    open var transitionNameFormat:String? = null
    open var uniqueness:DataFieldUniqueness? = null
    open var voiceOnly:Boolean? = null
    open var conditionalVisibilityField:String? = null
    open var conditionalVisibilityValue:String? = null
    open var noEvalTemplate:Boolean? = null
    open var userMode:UserDataFieldModes? = null
    open var anyValueType:Boolean? = null
}

enum class ValueTypes
{
    NotSpecified,
    String,
    Boolean,
    Number,
    List,
    Struct,
    Transition,
    Custom,
    Date,
    AudioFile,
    TimeZoneId,
    PhoneNumber,
    User,
    Endpoint,
    Time,
    File,
    FaxNumber,
    EmailAccount,
    Customer,
    Flow,
    Team,
    FlowReference,
    Integration,
    Assistant,
}

enum class UIHints
{
    None,
    LargeText,
    InlineForm,
    Password,
    InlineStruct,
}

open class Value
{
    open var boolValue:Boolean? = null
    open var stringValue:String? = null
    open var numberValue:Double? = null
    open var listValue:ArrayList<Struct>? = null
    open var structValue:Struct? = null
}

open class Struct : HashMap<String,Value>()
{
}

enum class DataFieldUniqueness
{
    NotUnique,
    Unique,
    UniqueToCustomer,
}

enum class UserDataFieldModes
{
    Hidden,
    ReadOnly,
    ReadWrite,
}

enum class FlowChannels
{
    Voice,
    Chat,
    Fax,
}

open class FlowNodeUI
{
    /**
    * The X position of the node
    */
    @ApiMember(Description="The X position of the node")
    open var x:Double? = null

    /**
    * The Y position of the node
    */
    @ApiMember(Description="The Y position of the node")
    open var y:Double? = null

    /**
    * Notes for this node
    */
    @ApiMember(Description="Notes for this node")
    open var notes:String? = null
}

open class NodeParameterMap : HashMap<String,NodeParameter>()
{
}

open class NodeParameter
{
    open var id:String? = null
    @SerializedName("type") open var Type:ValueTypes? = null
    open var source:ValueSources? = null
    open var isAsync:Boolean? = null
    open var referenceId:String? = null
    open var value:Value? = null
    open var noEvalTemplate:Boolean? = null
    open var listParameters:ArrayList<NodeParameterMap>? = null
    open var structParameters:NodeParameterMap? = null
    open var isOutput:Boolean? = null
    open var expression:String? = null
    open var listType:DataType? = null
}

enum class ValueSources
{
    Value,
    Flow,
    System,
    Customer,
    Session,
    Endpoint,
    Expression,
    User,
}

open class FlowParameter : DataField()
{
    open var isPublic:Boolean? = null
    open var isKnob:Boolean? = null
}

open class FlowExit
{
    /**
    * The unique ID for this exit
    */
    @ApiMember(Description="The unique ID for this exit")
    open var id:String? = null

    /**
    * The name of this exit
    */
    @ApiMember(Description="The name of this exit")
    open var name:String? = null

    /**
    * The UI for the exit
    */
    @ApiMember(Description="The UI for the exit")
    open var ui:FlowNodeUI? = null
}

open class FlowUI
{
    open var selectedNode:String? = null
    open var canvasX:Double? = null
    open var canvasY:Double? = null
    open var canvasZoom:Double? = null
}

open class Tag
{
    open var id:String? = null
    open var name:String? = null
    open var color:TagColors? = null
}

enum class TagColors
{
    Magenta,
    Red,
    Volcano,
    Orange,
    Gold,
    Lime,
    Green,
    Cyan,
    Blue,
    GeekBlue,
    Purple,
}

open class ListResponse<T>
{
    /**
    * The items
    */
    @ApiMember(Description="The items")
    open var items:ArrayList<AccountInfo>? = null

    /**
    * The total number of items
    */
    @ApiMember(Description="The total number of items")
    open var totalCount:Int? = null

    /**
    * The total number of pages
    */
    @ApiMember(Description="The total number of pages")
    open var totalPages:Int? = null

    /**
    * Are there more pages of items? Used with simplified paging
    */
    @ApiMember(Description="Are there more pages of items? Used with simplified paging")
    open var hasMorePages:Boolean? = null
}

open class AccountInfo : EntityInfo()
{
    /**
    * The name of this account
    */
    @ApiMember(Description="The name of this account")
    open var name:String? = null

    /**
    * The ID of this account's parent
    */
    @ApiMember(Description="The ID of this account's parent")
    open var parentAccountId:String? = null

    /**
    * The twilio account SID
    */
    @ApiMember(Description="The twilio account SID")
    open var twilioAccountSid:String? = null

    /**
    * The ancestors of this account. Useful for breadcrumbs
    */
    @ApiMember(Description="The ancestors of this account. Useful for breadcrumbs")
    open var ancestorIds:ArrayList<String>? = null

    /**
    * The max number of phone numbers this account can have
    */
    @ApiMember(Description="The max number of phone numbers this account can have")
    open var maxPhoneNumbers:Int? = null

    /**
    * This account is BYOA
    */
    @ApiMember(Description="This account is BYOA")
    open var isBYOA:Boolean? = null

    /**
    * TrustHub Profile Sid
    */
    @ApiMember(Description="TrustHub Profile Sid")
    open var trustHubProfileSid:String? = null

    /**
    * The ID of the logo file
    */
    @ApiMember(Description="The ID of the logo file")
    open var logoId:String? = null

    /**
    * The URI of the logo file
    */
    @ApiMember(Description="The URI of the logo file")
    open var logoUri:String? = null

    /**
    * The billing settings for this account
    */
    @ApiMember(Description="The billing settings for this account")
    open var billingSettings:BillingSettings? = null
}

open class BillingSettings
{
    open var base:BillingItem? = null
    open var localNumbers:BillingItem? = null
    open var tollFreeNumbers:BillingItem? = null
    open var inboundVoiceCalls:BillingItem? = null
    open var outboundVoiceCalls:BillingItem? = null
    open var inboundFaxes:BillingItem? = null
    open var outboundFaxes:BillingItem? = null
    open var inboundSmsMessages:BillingItem? = null
    open var outboundSmsMessages:BillingItem? = null
    open var aiInsights:BillingItem? = null
    open var aiLiveMinutes:BillingItem? = null
}

open class BillingItem
{
    open var baseCost:Double? = null
    open var rawUnitMultiplier:Double? = null
    open var unitCost:Double? = null
    open var allowance:Int? = null
}

Kotlin ListFlows DTOs

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

HTTP + OTHER

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

GET /flows HTTP/1.1 
Host: team.evovoice.io 
Accept: text/jsonl
HTTP/1.1 200 OK
Content-Type: text/jsonl
Content-Length: length

{"items":[{"name":"String","roles":["UI"],"description":"String","notes":"String","accountId":"String","accountName":"String","customerId":"String","customerName":"String","customerBreadcrumb":[{"id":"String","name":"String"}],"nodes":[{"id":"String","isStartNode":false,"name":"String","spec":{"name":"String","description":"String","iconClass":"String","typeName":"String","category":"General","url":"String","documentationUrl":"String","restrictToChannels":["Voice"]},"ui":{"x":0,"y":0,"notes":"String"},"parameters":{}}],"parameters":[{"isPublic":false,"isKnob":false,"id":"String","name":"String","type":"NotSpecified","uiHint":"None","uiTab":"String","isAsync":false,"disableBinding":false,"description":"String","possibleValues":["String"],"isOutput":false,"customFieldValuesUrl":"String","defaultValue":{"boolValue":false,"stringValue":"String","numberValue":0,"listValue":[null]},"transitionNameFormat":"String","uniqueness":"NotUnique","voiceOnly":false,"conditionalVisibilityField":"String","conditionalVisibilityValue":"String","noEvalTemplate":false,"userMode":"Hidden","anyValueType":false}],"exits":[{"id":"String","name":"String","ui":{"x":0,"y":0,"notes":"String"}}],"ui":{"selectedNode":"String","canvasX":0,"canvasY":0,"canvasZoom":0},"tags":[{"id":"String","name":"String","color":"Magenta"}],"nodeCount":0,"id":"String","dateCreated":"String","dateLastModified":"String","createdBy":"String","lastModifiedBy":"String"}],"totalCount":0,"totalPages":0,"hasMorePages":false}