Documentation ¶
Index ¶
- Constants
- Variables
- func EnsureSpoolDirPresent(spoolDir string, subdir string) (err error)
- func LogChannelEventReceived(r *http.Request, event ChannelEvent)
- func LogMsgReceived(r *http.Request, msg Msg)
- func LogMsgStatusReceived(r *http.Request, status MsgStatus)
- func LogRequestError(r *http.Request, channel Channel, err error)
- func LogRequestHandled(r *http.Request, channel Channel, details string)
- func LogRequestIgnored(r *http.Request, channel Channel, details string)
- func RegisterBackend(backendType string, constructorFunc BackendConstructorFunc)
- func RegisterFlusher(directory string, flusherFunc FlusherFunc)
- func RegisterHandler(handler ChannelHandler)
- func WriteAndLogUnauthorized(ctx context.Context, w http.ResponseWriter, r *http.Request, c Channel, ...) error
- func WriteChannelEventSuccess(ctx context.Context, w http.ResponseWriter, r *http.Request, ...) error
- func WriteDataResponse(ctx context.Context, w http.ResponseWriter, statusCode int, message string, ...) error
- func WriteError(ctx context.Context, w http.ResponseWriter, r *http.Request, err error) error
- func WriteIgnored(ctx context.Context, w http.ResponseWriter, r *http.Request, details string) error
- func WriteMsgSuccess(ctx context.Context, w http.ResponseWriter, r *http.Request, msgs []Msg) error
- func WriteStatusSuccess(ctx context.Context, w http.ResponseWriter, r *http.Request, ...) error
- func WriteToSpool(spoolDir string, subdir string, contents interface{}) error
- type Backend
- type BackendConstructorFunc
- type Channel
- type ChannelEvent
- type ChannelEventType
- type ChannelHandleFunc
- type ChannelHandler
- type ChannelID
- type ChannelLog
- func NewChannelLog(description string, channel Channel, msgID MsgID, method string, url string, ...) *ChannelLog
- func NewChannelLogFromError(description string, channel Channel, msgID MsgID, elapsed time.Duration, ...) *ChannelLog
- func NewChannelLogFromRR(description string, channel Channel, msgID MsgID, rr *utils.RequestResponse) *ChannelLog
- type ChannelType
- type ChannelUUID
- type Config
- type Contact
- type ContactUUID
- type ErrorData
- type Event
- type EventReceiveData
- type FlusherFunc
- type Foreman
- type InfoData
- type MediaDownloadRequestBuilder
- type MockBackend
- func (mb *MockBackend) AddChannel(channel Channel)
- func (mb *MockBackend) AddURNtoContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error)
- func (mb *MockBackend) CheckExternalIDSeen(msg Msg) Msg
- func (mb *MockBackend) Cleanup() error
- func (mb *MockBackend) ClearChannels()
- func (mb *MockBackend) ClearQueueMsgs()
- func (mb *MockBackend) ClearSeenExternalIDs()
- func (mb *MockBackend) GetChannel(ctx context.Context, cType ChannelType, uuid ChannelUUID) (Channel, error)
- func (mb *MockBackend) GetContact(ctx context.Context, channel Channel, urn urns.URN, auth string, name string) (Contact, error)
- func (mb *MockBackend) GetLastChannelEvent() (ChannelEvent, error)
- func (mb *MockBackend) GetLastContactName() string
- func (mb *MockBackend) GetLastMsgStatus() (MsgStatus, error)
- func (mb *MockBackend) GetLastQueueMsg() (Msg, error)
- func (mb *MockBackend) Health() string
- func (mb *MockBackend) Heartbeat() error
- func (mb *MockBackend) LenQueuedMsgs() int
- func (mb *MockBackend) MarkOutgoingMsgComplete(ctx context.Context, msg Msg, s MsgStatus)
- func (mb *MockBackend) NewChannelEvent(channel Channel, eventType ChannelEventType, urn urns.URN) ChannelEvent
- func (mb *MockBackend) NewIncomingMsg(channel Channel, urn urns.URN, text string) Msg
- func (mb *MockBackend) NewMsgStatusForExternalID(channel Channel, externalID string, status MsgStatusValue) MsgStatus
- func (mb *MockBackend) NewMsgStatusForID(channel Channel, id MsgID, status MsgStatusValue) MsgStatus
- func (mb *MockBackend) NewOutgoingMsg(channel Channel, id MsgID, urn urns.URN, text string, highPriority bool, ...) Msg
- func (mb *MockBackend) PopNextOutgoingMsg(ctx context.Context) (Msg, error)
- func (mb *MockBackend) PushOutgoingMsg(msg Msg)
- func (mb *MockBackend) RedisPool() *redis.Pool
- func (mb *MockBackend) RemoveURNfromContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error)
- func (mb *MockBackend) SetErrorOnQueue(shouldError bool)
- func (mb *MockBackend) Start() error
- func (mb *MockBackend) Status() string
- func (mb *MockBackend) Stop() error
- func (mb *MockBackend) WasMsgSent(ctx context.Context, msg Msg) (bool, error)
- func (mb *MockBackend) WriteChannelEvent(ctx context.Context, event ChannelEvent) error
- func (mb *MockBackend) WriteChannelLogs(ctx context.Context, logs []*ChannelLog) error
- func (mb *MockBackend) WriteExternalIDSeen(msg Msg)
- func (mb *MockBackend) WriteMsg(ctx context.Context, m Msg) error
- func (mb *MockBackend) WriteMsgStatus(ctx context.Context, status MsgStatus) error
- type MockChannel
- func (c *MockChannel) Address() string
- func (c *MockChannel) BoolConfigForKey(key string, defaultValue bool) bool
- func (c *MockChannel) CallbackDomain(fallbackDomain string) string
- func (c *MockChannel) ChannelType() ChannelType
- func (c *MockChannel) ConfigForKey(key string, defaultValue interface{}) interface{}
- func (c *MockChannel) Country() string
- func (c *MockChannel) IntConfigForKey(key string, defaultValue int) int
- func (c *MockChannel) IsScheme(scheme string) bool
- func (c *MockChannel) Name() string
- func (c *MockChannel) OrgConfigForKey(key string, defaultValue interface{}) interface{}
- func (c *MockChannel) Schemes() []string
- func (c *MockChannel) SetConfig(key string, value interface{})
- func (c *MockChannel) SetScheme(scheme string)
- func (c *MockChannel) StringConfigForKey(key string, defaultValue string) string
- func (c *MockChannel) UUID() ChannelUUID
- type Msg
- type MsgID
- type MsgReceiveData
- type MsgStatus
- type MsgStatusValue
- type MsgUUID
- type Sender
- type Server
- type StatusData
- type URNDescriber
Constants ¶
const ( // ConfigAPIKey is a constant key for channel configs ConfigAPIKey = "api_key" // ConfigAuthToken is a constant key for channel configs ConfigAuthToken = "auth_token" // ConfigBaseURL is a constant key for channel configs ConfigBaseURL = "base_url" // ConfigCallbackDomain is the domain that should be used for this channel when registering callbacks ConfigCallbackDomain = "callback_domain" // ConfigContentType is a constant key for channel configs ConfigContentType = "content_type" // ConfigMaxLength is the maximum size of a message in characters ConfigMaxLength = "max_length" // ConfigPassword is a constant key for channel configs ConfigPassword = "password" // ConfigSecret is the secret used for signing commands by the channel ConfigSecret = "secret" // ConfigSendAuthorization is a constant key for channel configs ConfigSendAuthorization = "send_authorization" // ConfigSendBody is a constant key for channel configs ConfigSendBody = "body" // ConfigSendMethod is a constant key for channel configs ConfigSendMethod = "method" // ConfigSendURL is a constant key for channel configs ConfigSendURL = "send_url" // ConfigUsername is a constant key for channel configs ConfigUsername = "username" )
const NilChannelID = ChannelID(0)
NilChannelID represents a nil channel id
const NilStatusCode int = 417
NilStatusCode is used when we have an error before even sending anything
Variables ¶
var AnyChannelType = ChannelType("")
AnyChannelType is our empty channel type used when doing lookups without channel type assertions
var ErrChannelExpired = errors.New("channel expired")
ErrChannelExpired is returned when our cached channel has outlived it's TTL
var ErrChannelNotFound = errors.New("channel not found")
ErrChannelNotFound is returned when we fail to find a channel in the db
var ErrChannelWrongType = errors.New("channel type wrong")
ErrChannelWrongType is returned when we find a channel with the set UUID but with a different type
var ErrMsgNotFound = errors.New("message not found")
ErrMsgNotFound is returned when trying to queue the status for a Msg that doesn't exit
var ErrWrongIncomingMsgStatus = errors.New("Incoming messages can only be PENDING or HANDLED")
ErrWrongIncomingMsgStatus use do ignore the status update if the DB raise this
var NilChannelUUID = ChannelUUID{uuid.Nil}
NilChannelUUID is our nil value for channel UUIDs
var NilContactUUID = ContactUUID{uuid.Nil}
NilContactUUID is our nil value for contact UUIDs
var NilMsgID = MsgID(0)
NilMsgID is our nil value for MsgID
var NilMsgUUID = MsgUUID{uuid.Nil}
NilMsgUUID is a "zero value" message UUID
Functions ¶
func EnsureSpoolDirPresent ¶
EnsureSpoolDirPresent checks that the passed in spool directory is present and writable
func LogChannelEventReceived ¶
func LogChannelEventReceived(r *http.Request, event ChannelEvent)
LogChannelEventReceived logs that we received the passed in channel event
func LogMsgReceived ¶
LogMsgReceived logs that we received the passed in message
func LogMsgStatusReceived ¶
LogMsgStatusReceived logs our that we received a new MsgStatus
func LogRequestError ¶
LogRequestError logs that errored during parsing (this is logged as an info as it isn't an error on our side)
func LogRequestHandled ¶
LogRequestHandled logs that we handled the passed in request but didn't create any events
func LogRequestIgnored ¶
LogRequestIgnored logs that we ignored the passed in request
func RegisterBackend ¶
func RegisterBackend(backendType string, constructorFunc BackendConstructorFunc)
RegisterBackend adds a new backend, called by individual backends in their init() func
func RegisterFlusher ¶
func RegisterFlusher(directory string, flusherFunc FlusherFunc)
RegisterFlusher creates a new walker which we will use to flush files from the passed in directory
func RegisterHandler ¶
func RegisterHandler(handler ChannelHandler)
RegisterHandler adds a new handler for a channel type, this is called by individual handlers when they are initialized
func WriteAndLogUnauthorized ¶
func WriteAndLogUnauthorized(ctx context.Context, w http.ResponseWriter, r *http.Request, c Channel, err error) error
WriteAndLogUnauthorized writes a JSON response for the passed in message and logs an info message
func WriteChannelEventSuccess ¶
func WriteChannelEventSuccess(ctx context.Context, w http.ResponseWriter, r *http.Request, event ChannelEvent) error
WriteChannelEventSuccess writes a JSON response for the passed in event indicating we handled it
func WriteDataResponse ¶
func WriteDataResponse(ctx context.Context, w http.ResponseWriter, statusCode int, message string, data []interface{}) error
WriteDataResponse writes a JSON formatted response with the passed in status code, message and data
func WriteError ¶
WriteError writes a JSON response for the passed in error
func WriteIgnored ¶
func WriteIgnored(ctx context.Context, w http.ResponseWriter, r *http.Request, details string) error
WriteIgnored writes a JSON response indicating that we ignored the request
func WriteMsgSuccess ¶
WriteMsgSuccess writes a JSON response for the passed in msg indicating we handled it
func WriteStatusSuccess ¶
func WriteStatusSuccess(ctx context.Context, w http.ResponseWriter, r *http.Request, statuses []MsgStatus) error
WriteStatusSuccess writes a JSON response for the passed in status update indicating we handled it
func WriteToSpool ¶
WriteToSpool writes the passed in object to the passed in subdir
Types ¶
type Backend ¶
type Backend interface { // Start starts the backend and opens any db connections it needs Start() error // Stop stops any backend processes Stop() error // Cleanup closes any active connections to databases Cleanup() error // GetChannel returns the channel with the passed in type and UUID GetChannel(context.Context, ChannelType, ChannelUUID) (Channel, error) // GetContact returns (or creates) the contact for the passed in channel and URN GetContact(context context.Context, channel Channel, urn urns.URN, auth string, name string) (Contact, error) // AddURNtoContact adds a URN to the passed in contact AddURNtoContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error) // RemoveURNFromcontact removes a URN from the passed in contact RemoveURNfromContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error) // NewIncomingMsg creates a new message from the given params NewIncomingMsg(channel Channel, urn urns.URN, text string) Msg // WriteMsg writes the passed in message to our backend WriteMsg(context.Context, Msg) error // NewMsgStatusForID creates a new Status object for the given message id NewMsgStatusForID(Channel, MsgID, MsgStatusValue) MsgStatus // NewMsgStatusForExternalID creates a new Status object for the given external id NewMsgStatusForExternalID(Channel, string, MsgStatusValue) MsgStatus // WriteMsgStatus writes the passed in status update to our backend WriteMsgStatus(context.Context, MsgStatus) error // NewChannelEvent creates a new channel event for the given channel and event type NewChannelEvent(Channel, ChannelEventType, urns.URN) ChannelEvent // WriteChannelEvent writes the passed in channel even returning any error WriteChannelEvent(context.Context, ChannelEvent) error // WriteChannelLogs writes the passed in channel logs to our backend WriteChannelLogs(context.Context, []*ChannelLog) error // PopNextOutgoingMsg returns the next message that needs to be sent, callers should call MarkOutgoingMsgComplete with the // returned message when they have dealt with the message (regardless of whether it was sent or not) PopNextOutgoingMsg(context.Context) (Msg, error) // WasMsgSent returns whether the backend thinks the passed in message was already sent. This can be used in cases where // a backend wants to implement a failsafe against double sending messages (say if they were double queued) WasMsgSent(context.Context, Msg) (bool, error) // MarkOutgoingMsgComplete marks the passed in message as having been processed. Note this should be called even in the case // of errors during sending as it will manage the number of active workers per channel. The optional status parameter can be // used to determine any sort of deduping of msg sends MarkOutgoingMsgComplete(context.Context, Msg, MsgStatus) // Check if external ID has been seen in a period CheckExternalIDSeen(Msg) Msg // Mark a external ID as seen for a period WriteExternalIDSeen(Msg) // Health returns a string describing any health problems the backend has, or empty string if all is well Health() string // Status returns a string describing the current status, this can detail queue sizes or other attributes Status() string // Heartbeat is called every minute, it can be used by backends to log status to a dashboard such as librato Heartbeat() error // RedisPool returns the redisPool for this backend RedisPool() *redis.Pool }
Backend represents the part of Courier that deals with looking up and writing channels and results
func NewBackend ¶
NewBackend creates the type of backend passed in
type BackendConstructorFunc ¶
BackendConstructorFunc defines a function to create a particular backend type
type Channel ¶
type Channel interface { UUID() ChannelUUID Name() string ChannelType() ChannelType Schemes() []string Country() string Address() string // is this channel for the passed in scheme (and only that scheme) IsScheme(string) bool // CallbackDomain returns the domain that should be used for any callbacks the channel registers CallbackDomain(fallbackDomain string) string ConfigForKey(key string, defaultValue interface{}) interface{} StringConfigForKey(key string, defaultValue string) string BoolConfigForKey(key string, defaultValue bool) bool IntConfigForKey(key string, defaultValue int) int OrgConfigForKey(key string, defaultValue interface{}) interface{} }
Channel defines the general interface backend Channel implementations must adhere to
type ChannelEvent ¶
type ChannelEvent interface { ChannelUUID() ChannelUUID URN() urns.URN EventType() ChannelEventType Extra() map[string]interface{} CreatedOn() time.Time OccurredOn() time.Time Logs() []*ChannelLog AddLog(log *ChannelLog) WithContactName(name string) ChannelEvent WithExtra(extra map[string]interface{}) ChannelEvent WithOccurredOn(time.Time) ChannelEvent EventID() int64 }
ChannelEvent represents an event on a channel, such as a follow, new conversation or referral
type ChannelEventType ¶
type ChannelEventType string
ChannelEventType is the type of channel event this is
const ( NewConversation ChannelEventType = "new_conversation" Referral ChannelEventType = "referral" StopContact ChannelEventType = "stop_contact" WelcomeMessage ChannelEventType = "welcome_message" )
Possible values for ChannelEventTypes
type ChannelHandleFunc ¶
type ChannelHandleFunc func(context.Context, Channel, http.ResponseWriter, *http.Request) ([]Event, error)
ChannelHandleFunc is the interface ChannelHandlers must satisfy to handle incoming requests. The Server will take care of looking up the channel by UUID before passing it to this function. Errors in format of the request or by the caller should be handled and logged internally. Errors in execution or in courier itself should be passed back.
type ChannelHandler ¶
type ChannelHandler interface { Initialize(Server) error ChannelType() ChannelType ChannelName() string SendMsg(context.Context, Msg) (MsgStatus, error) }
ChannelHandler is the interface all handlers must satisfy
func GetHandler ¶
func GetHandler(ct ChannelType) ChannelHandler
GetHandler returns the handler for the passed in channel type, or nil if not found
type ChannelID ¶
ChannelID is our SQL type for a channel's id
func NewChannelID ¶
NewChannelID creates a new ChannelID for the passed in int64
func (ChannelID) MarshalJSON ¶
MarshalJSON marshals into JSON. 0 values will become null
func (*ChannelID) UnmarshalJSON ¶
UnmarshalJSON unmarshals from JSON. null values become 0
type ChannelLog ¶
type ChannelLog struct { Description string Channel Channel MsgID MsgID Method string URL string StatusCode int Error string Request string Response string Elapsed time.Duration CreatedOn time.Time }
ChannelLog represents the log for a msg being received, sent or having its status updated. It includes the HTTP request and response for the action as well as the channel it was performed on and an option ID of the msg (for some error cases we may log without a msg id)
func NewChannelLog ¶
func NewChannelLog(description string, channel Channel, msgID MsgID, method string, url string, statusCode int, request string, response string, elapsed time.Duration, err error) *ChannelLog
NewChannelLog creates a new channel log for the passed in channel, id, and request and response info
func NewChannelLogFromError ¶
func NewChannelLogFromError(description string, channel Channel, msgID MsgID, elapsed time.Duration, err error) *ChannelLog
NewChannelLogFromError creates a new channel log for the passed in channel, msg id and error
func NewChannelLogFromRR ¶
func NewChannelLogFromRR(description string, channel Channel, msgID MsgID, rr *utils.RequestResponse) *ChannelLog
NewChannelLogFromRR creates a new channel log for the passed in channel, id, and request/response log
func (*ChannelLog) String ¶
func (l *ChannelLog) String() string
func (*ChannelLog) WithError ¶
func (l *ChannelLog) WithError(description string, err error) *ChannelLog
WithError augments the passed in ChannelLog with the passed in description and error if error is not nil
type ChannelType ¶
type ChannelType string
ChannelType is our typing of the two char channel types
func (ChannelType) String ¶
func (ct ChannelType) String() string
type ChannelUUID ¶
ChannelUUID is our typing of a channel's UUID
func NewChannelUUID ¶
func NewChannelUUID(u string) (ChannelUUID, error)
NewChannelUUID creates a new ChannelUUID for the passed in string
type Config ¶
type Config struct { Backend string `help:"the backend that will be used by courier (currently only rapidpro is supported)"` SentryDSN string `help:"the DSN used for logging errors to Sentry"` Domain string `help:"the domain courier is exposed on"` Address string `help:"the network interface address courier will bind to"` Port int `help:"the port courier will listen on"` DB string `help:"URL describing how to connect to the RapidPro database"` Redis string `help:"URL describing how to connect to Redis"` SpoolDir string `help:"the local directory where courier will write statuses or msgs that need to be retried (needs to be writable)"` S3Endpoint string `help:"the S3 endpoint we will write attachments to"` S3Region string `help:"the S3 region we will write attachments to"` S3MediaBucket string `help:"the S3 bucket we will write attachments to"` S3MediaPrefix string `help:"the prefix that will be added to attachment filenames"` S3DisableSSL bool `` /* 158-byte string literal not displayed */ S3ForcePathStyle bool `` /* 127-byte string literal not displayed */ AWSAccessKeyID string `help:"the access key id to use when authenticating S3"` AWSSecretAccessKey string `help:"the secret access key id to use when authenticating S3"` MaxWorkers int `help:"the maximum number of go routines that will be used for sending (set to 0 to disable sending)"` LibratoUsername string `help:"the username that will be used to authenticate to Librato"` LibratoToken string `help:"the token that will be used to authenticate to Librato"` StatusUsername string `help:"the username that is needed to authenticate against the /status endpoint"` StatusPassword string `help:"the password that is needed to authenticate against the /status endpoint"` LogLevel string `help:"the logging level courier should use"` Version string `help:"the version that will be used in request and response headers"` // IncludeChannels is the list of channels to enable, empty means include all IncludeChannels []string // ExcludeChannels is the list of channels to exclude, empty means exclude none ExcludeChannels []string }
Config is our top level configuration object
func LoadConfig ¶
LoadConfig loads our configuration from the passed in filename
type Contact ¶
type Contact interface {
UUID() ContactUUID
}
Contact defines the attributes on a contact, for our purposes that is just a contact UUID
type ContactUUID ¶
ContactUUID is our typing of a contact's UUID
func NewContactUUID ¶
func NewContactUUID(u string) (ContactUUID, error)
NewContactUUID creates a new ContactUUID for the passed in string
type ErrorData ¶
ErrorData is our response payload for an error
func NewErrorData ¶
NewErrorData creates a new data segment for the passed in error string
type Event ¶
type Event interface {
EventID() int64
}
Event is our interface for the types of things a ChannelHandleFunc can return.
type EventReceiveData ¶
type EventReceiveData struct { Type string `json:"type"` ChannelUUID ChannelUUID `json:"channel_uuid"` EventType ChannelEventType `json:"event_type"` URN urns.URN `json:"urn"` ReceivedOn time.Time `json:"received_on"` Extra map[string]interface{} `json:"extra,omitempty"` }
EventReceiveData is our response payload for a channel event
func NewEventReceiveData ¶
func NewEventReceiveData(event ChannelEvent) EventReceiveData
NewEventReceiveData creates a new receive data for the passed in event
type FlusherFunc ¶
FlusherFunc defines our interface for flushers, they are handed a filename and byte blob and are expected to try to flush that to the db, returning an error if the db is still down
type Foreman ¶
type Foreman struct {
// contains filtered or unexported fields
}
Foreman takes care of managing our set of sending workers and assigns msgs for each to send
func NewForeman ¶
NewForeman creates a new Foreman for the passed in server with the number of max senders
func (*Foreman) Assign ¶
func (f *Foreman) Assign()
Assign is our main loop for the Foreman, it takes care of popping the next outgoing messages from our backend and assigning them to workers
type InfoData ¶
InfoData is our response payload for an informational message
func NewInfoData ¶
NewInfoData creates a new data segment for the passed in info string
type MediaDownloadRequestBuilder ¶
type MediaDownloadRequestBuilder interface {
BuildDownloadMediaRequest(context.Context, Backend, Channel, string) (*http.Request, error)
}
MediaDownloadRequestBuilder is the interface handlers which can allow a custom way to download attachment media for messages should satisfy
type MockBackend ¶
type MockBackend struct {
// contains filtered or unexported fields
}
MockBackend is a mocked version of a backend which doesn't require a real database or cache
func NewMockBackend ¶
func NewMockBackend() *MockBackend
NewMockBackend returns a new mock backend suitable for testing
func (*MockBackend) AddChannel ¶
func (mb *MockBackend) AddChannel(channel Channel)
AddChannel adds a test channel to the test server
func (*MockBackend) AddURNtoContact ¶
func (mb *MockBackend) AddURNtoContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error)
AddURNtoContact adds a URN to the passed in contact
func (*MockBackend) CheckExternalIDSeen ¶
func (mb *MockBackend) CheckExternalIDSeen(msg Msg) Msg
CheckExternalIDSeen checks if external ID has been seen in a period
func (*MockBackend) Cleanup ¶
func (mb *MockBackend) Cleanup() error
Cleanup cleans up any connections that are open
func (*MockBackend) ClearChannels ¶
func (mb *MockBackend) ClearChannels()
ClearChannels is a utility function on our mock server to clear all added channels
func (*MockBackend) ClearQueueMsgs ¶
func (mb *MockBackend) ClearQueueMsgs()
ClearQueueMsgs clears our mock msg queue
func (*MockBackend) ClearSeenExternalIDs ¶
func (mb *MockBackend) ClearSeenExternalIDs()
ClearSeenExternalIDs clears our mock seen external ids
func (*MockBackend) GetChannel ¶
func (mb *MockBackend) GetChannel(ctx context.Context, cType ChannelType, uuid ChannelUUID) (Channel, error)
GetChannel returns the channel with the passed in type and channel uuid
func (*MockBackend) GetContact ¶
func (mb *MockBackend) GetContact(ctx context.Context, channel Channel, urn urns.URN, auth string, name string) (Contact, error)
GetContact creates a new contact with the passed in channel and URN
func (*MockBackend) GetLastChannelEvent ¶
func (mb *MockBackend) GetLastChannelEvent() (ChannelEvent, error)
GetLastChannelEvent returns the last event written to the server
func (*MockBackend) GetLastContactName ¶
func (mb *MockBackend) GetLastContactName() string
GetLastContactName returns the contact name set on the last msg or channel event written
func (*MockBackend) GetLastMsgStatus ¶
func (mb *MockBackend) GetLastMsgStatus() (MsgStatus, error)
GetLastMsgStatus returns the last status written to the server
func (*MockBackend) GetLastQueueMsg ¶
func (mb *MockBackend) GetLastQueueMsg() (Msg, error)
GetLastQueueMsg returns the last message queued to the server
func (*MockBackend) Health ¶
func (mb *MockBackend) Health() string
Health gives a string representing our health, empty for our mock
func (*MockBackend) Heartbeat ¶
func (mb *MockBackend) Heartbeat() error
Heartbeat is a noop for our mock backend
func (*MockBackend) LenQueuedMsgs ¶
func (mb *MockBackend) LenQueuedMsgs() int
LenQueuedMsgs Get the length of queued msgs
func (*MockBackend) MarkOutgoingMsgComplete ¶
func (mb *MockBackend) MarkOutgoingMsgComplete(ctx context.Context, msg Msg, s MsgStatus)
MarkOutgoingMsgComplete marks the passed msg as having been dealt with
func (*MockBackend) NewChannelEvent ¶
func (mb *MockBackend) NewChannelEvent(channel Channel, eventType ChannelEventType, urn urns.URN) ChannelEvent
NewChannelEvent creates a new channel event with the passed in parameters
func (*MockBackend) NewIncomingMsg ¶
NewIncomingMsg creates a new message from the given params
func (*MockBackend) NewMsgStatusForExternalID ¶
func (mb *MockBackend) NewMsgStatusForExternalID(channel Channel, externalID string, status MsgStatusValue) MsgStatus
NewMsgStatusForExternalID creates a new Status object for the given external id
func (*MockBackend) NewMsgStatusForID ¶
func (mb *MockBackend) NewMsgStatusForID(channel Channel, id MsgID, status MsgStatusValue) MsgStatus
NewMsgStatusForID creates a new Status object for the given message id
func (*MockBackend) NewOutgoingMsg ¶
func (mb *MockBackend) NewOutgoingMsg(channel Channel, id MsgID, urn urns.URN, text string, highPriority bool, replies []string, responseToID int64, responseToExternalID string) Msg
NewOutgoingMsg creates a new outgoing message from the given params
func (*MockBackend) PopNextOutgoingMsg ¶
func (mb *MockBackend) PopNextOutgoingMsg(ctx context.Context) (Msg, error)
PopNextOutgoingMsg returns the next message that should be sent, or nil if there are none to send
func (*MockBackend) PushOutgoingMsg ¶
func (mb *MockBackend) PushOutgoingMsg(msg Msg)
PushOutgoingMsg is a test method to add a message to our queue of messages to send
func (*MockBackend) RedisPool ¶
func (mb *MockBackend) RedisPool() *redis.Pool
RedisPool returns the redisPool for this backend
func (*MockBackend) RemoveURNfromContact ¶
func (mb *MockBackend) RemoveURNfromContact(context context.Context, channel Channel, contact Contact, urn urns.URN) (urns.URN, error)
RemoveURNFromcontact removes a URN from the passed in contact
func (*MockBackend) SetErrorOnQueue ¶
func (mb *MockBackend) SetErrorOnQueue(shouldError bool)
SetErrorOnQueue is a mock method which makes the QueueMsg call throw the passed in error on next call
func (*MockBackend) Status ¶
func (mb *MockBackend) Status() string
Status returns a string describing the status of the service, queue size etc..
func (*MockBackend) WasMsgSent ¶
WasMsgSent returns whether the passed in msg was already sent
func (*MockBackend) WriteChannelEvent ¶
func (mb *MockBackend) WriteChannelEvent(ctx context.Context, event ChannelEvent) error
WriteChannelEvent writes the channel event passed in
func (*MockBackend) WriteChannelLogs ¶
func (mb *MockBackend) WriteChannelLogs(ctx context.Context, logs []*ChannelLog) error
WriteChannelLogs writes the passed in channel logs to the DB
func (*MockBackend) WriteExternalIDSeen ¶
func (mb *MockBackend) WriteExternalIDSeen(msg Msg)
WriteExternalIDSeen marks a external ID as seen for a period
func (*MockBackend) WriteMsg ¶
func (mb *MockBackend) WriteMsg(ctx context.Context, m Msg) error
WriteMsg queues the passed in message internally
func (*MockBackend) WriteMsgStatus ¶
func (mb *MockBackend) WriteMsgStatus(ctx context.Context, status MsgStatus) error
WriteMsgStatus writes the status update to our queue
type MockChannel ¶
type MockChannel struct {
// contains filtered or unexported fields
}
MockChannel implements the Channel interface and is used in our tests
func NewMockChannel ¶
func NewMockChannel(uuid string, channelType string, address string, country string, config map[string]interface{}) *MockChannel
NewMockChannel creates a new mock channel for the passed in type, address, country and config
func (*MockChannel) Address ¶
func (c *MockChannel) Address() string
Address returns the address of this channel
func (*MockChannel) BoolConfigForKey ¶
func (c *MockChannel) BoolConfigForKey(key string, defaultValue bool) bool
BoolConfigForKey returns the config value for the passed in key
func (*MockChannel) CallbackDomain ¶
func (c *MockChannel) CallbackDomain(fallbackDomain string) string
CallbackDomain returns the callback domain to use for this channel
func (*MockChannel) ChannelType ¶
func (c *MockChannel) ChannelType() ChannelType
ChannelType returns the type of this channel
func (*MockChannel) ConfigForKey ¶
func (c *MockChannel) ConfigForKey(key string, defaultValue interface{}) interface{}
ConfigForKey returns the config value for the passed in key
func (*MockChannel) Country ¶
func (c *MockChannel) Country() string
Country returns the country this channel is for (if any)
func (*MockChannel) IntConfigForKey ¶
func (c *MockChannel) IntConfigForKey(key string, defaultValue int) int
IntConfigForKey returns the config value for the passed in key
func (*MockChannel) IsScheme ¶
func (c *MockChannel) IsScheme(scheme string) bool
IsScheme returns whether the passed in scheme is the scheme for this channel
func (*MockChannel) Name ¶
func (c *MockChannel) Name() string
Name returns the name of this channel, we just return our UUID for our mock instances
func (*MockChannel) OrgConfigForKey ¶
func (c *MockChannel) OrgConfigForKey(key string, defaultValue interface{}) interface{}
OrgConfigForKey returns the org config value for the passed in key
func (*MockChannel) Schemes ¶
func (c *MockChannel) Schemes() []string
Schemes returns the schemes for this channel
func (*MockChannel) SetConfig ¶
func (c *MockChannel) SetConfig(key string, value interface{})
SetConfig sets the passed in config parameter
func (*MockChannel) SetScheme ¶
func (c *MockChannel) SetScheme(scheme string)
SetScheme sets the scheme for this channel
func (*MockChannel) StringConfigForKey ¶
func (c *MockChannel) StringConfigForKey(key string, defaultValue string) string
StringConfigForKey returns the config value for the passed in key
func (*MockChannel) UUID ¶
func (c *MockChannel) UUID() ChannelUUID
UUID returns the uuid for this channel
type Msg ¶
type Msg interface { ID() MsgID UUID() MsgUUID Text() string Attachments() []string ExternalID() string URN() urns.URN URNAuth() string ContactName() string QuickReplies() []string Metadata() json.RawMessage ResponseToID() MsgID ResponseToExternalID() string Channel() Channel ReceivedOn() *time.Time SentOn() *time.Time HighPriority() bool WithContactName(name string) Msg WithReceivedOn(date time.Time) Msg WithExternalID(id string) Msg WithID(id MsgID) Msg WithUUID(uuid MsgUUID) Msg WithAttachment(url string) Msg WithURNAuth(auth string) Msg WithMetadata(metadata json.RawMessage) Msg EventID() int64 }
Msg is our interface to represent an incoming or outgoing message
type MsgID ¶
MsgID is our typing of the db int type
func (MsgID) MarshalJSON ¶
MarshalJSON marshals into JSON. 0 values will become null
func (*MsgID) UnmarshalJSON ¶
UnmarshalJSON unmarshals from JSON. null values become 0
type MsgReceiveData ¶
type MsgReceiveData struct { Type string `json:"type"` ChannelUUID ChannelUUID `json:"channel_uuid"` MsgUUID MsgUUID `json:"msg_uuid"` Text string `json:"text"` URN urns.URN `json:"urn"` Attachments []string `json:"attachments,omitempty"` ExternalID string `json:"external_id,omitempty"` ReceivedOn *time.Time `json:"received_on,omitempty"` }
MsgReceiveData is our response payload for a received message
func NewMsgReceiveData ¶
func NewMsgReceiveData(msg Msg) MsgReceiveData
NewMsgReceiveData creates a new data response for the passed in msg parameters
type MsgStatus ¶
type MsgStatus interface { EventID() int64 ChannelUUID() ChannelUUID ID() MsgID ExternalID() string SetExternalID(string) Status() MsgStatusValue SetStatus(MsgStatusValue) Logs() []*ChannelLog AddLog(log *ChannelLog) }
MsgStatus represents a status update on a message
type MsgStatusValue ¶
type MsgStatusValue string
MsgStatusValue is the status of a message
const ( MsgPending MsgStatusValue = "P" MsgQueued MsgStatusValue = "Q" MsgSent MsgStatusValue = "S" MsgWired MsgStatusValue = "W" MsgErrored MsgStatusValue = "E" MsgDelivered MsgStatusValue = "D" MsgFailed MsgStatusValue = "F" NilMsgStatus MsgStatusValue = "" )
Possible values for MsgStatus
type MsgUUID ¶
MsgUUID is the UUID of a message which has been received
func NewMsgUUIDFromString ¶
NewMsgUUIDFromString creates a new message UUID for the passed in string
type Sender ¶
type Sender struct {
// contains filtered or unexported fields
}
Sender is our type for a single goroutine that is sending messages
type Server ¶
type Server interface { Config() *Config AddHandlerRoute(handler ChannelHandler, method string, action string, handlerFunc ChannelHandleFunc) SendMsg(context.Context, Msg) (MsgStatus, error) Backend() Backend WaitGroup() *sync.WaitGroup StopChan() chan bool Stopped() bool Router() chi.Router Start() error Stop() error }
Server is the main interface ChannelHandlers use to interact with backends. It provides an abstraction that makes mocking easier for isolated unit tests
type StatusData ¶
type StatusData struct { Type string `json:"type"` ChannelUUID ChannelUUID `json:"channel_uuid"` Status MsgStatusValue `json:"status"` MsgID MsgID `json:"msg_id,omitempty"` ExternalID string `json:"external_id,omitempty"` }
StatusData is our response payload for a status update
func NewStatusData ¶
func NewStatusData(status MsgStatus) StatusData
NewStatusData creates a new status data object for the passed in status