2016-04-13 16:14:23 +10:00
|
|
|
package messenger
|
|
|
|
|
|
|
|
import "time"
|
|
|
|
|
2016-04-14 09:53:55 +10:00
|
|
|
// Message represents a Facebook messenge message.
|
2016-04-13 16:14:23 +10:00
|
|
|
type Message struct {
|
2016-04-14 09:53:55 +10:00
|
|
|
// Sender is who the message was sent from.
|
|
|
|
Sender Sender `json:"-"`
|
|
|
|
// Recipient is who the message was sent to.
|
|
|
|
Recipient Recipient `json:"-"`
|
|
|
|
// Time is when the message was sent.
|
|
|
|
Time time.Time `json:"-"`
|
2016-09-08 10:55:48 +03:00
|
|
|
// Message is mine
|
|
|
|
IsEcho bool `json:"is_echo,omitempty"`
|
2016-04-14 09:53:55 +10:00
|
|
|
// Mid is the ID of the message.
|
|
|
|
Mid string `json:"mid"`
|
|
|
|
// Seq is order the message was sent in relation to other messages.
|
|
|
|
Seq int `json:"seq"`
|
2019-01-02 21:12:22 +02:00
|
|
|
// StickerID is the ID of the sticker user sent.
|
|
|
|
StickerID int `json:"sticker_id"`
|
2016-04-14 09:53:55 +10:00
|
|
|
// Text is the textual contents of the message.
|
|
|
|
Text string `json:"text"`
|
|
|
|
// Attachments is the information about the attachments which were sent
|
|
|
|
// with the message.
|
2016-04-13 19:46:52 +10:00
|
|
|
Attachments []Attachment `json:"attachments"`
|
2016-09-08 10:55:48 +03:00
|
|
|
// Selected quick reply
|
|
|
|
QuickReply *QuickReply `json:"quick_reply,omitempty"`
|
2016-04-13 19:12:23 +10:00
|
|
|
}
|
|
|
|
|
2016-08-18 09:41:25 +10:00
|
|
|
// Delivery represents a the event fired when Facebook delivers a message to the
|
|
|
|
// recipient.
|
2016-04-13 19:12:23 +10:00
|
|
|
type Delivery struct {
|
2016-04-14 09:53:55 +10:00
|
|
|
// Mids are the IDs of the messages which were read.
|
|
|
|
Mids []string `json:"mids"`
|
2016-08-18 09:41:25 +10:00
|
|
|
// RawWatermark is the timestamp of when the delivery was.
|
|
|
|
RawWatermark int64 `json:"watermark"`
|
|
|
|
// Seq is the sequence the message was sent in.
|
|
|
|
Seq int `json:"seq"`
|
|
|
|
}
|
|
|
|
|
2016-10-07 15:28:27 +02:00
|
|
|
// Read represents a the event fired when a message is read by the
|
2016-08-18 09:41:25 +10:00
|
|
|
// recipient.
|
|
|
|
type Read struct {
|
|
|
|
// RawWatermark is the timestamp before which all messages have been read
|
|
|
|
// by the user
|
2016-04-14 09:53:55 +10:00
|
|
|
RawWatermark int64 `json:"watermark"`
|
|
|
|
// Seq is the sequence the message was sent in.
|
|
|
|
Seq int `json:"seq"`
|
2016-04-13 19:36:38 +10:00
|
|
|
}
|
|
|
|
|
2016-05-03 16:42:25 +03:00
|
|
|
// PostBack represents postback callback
|
|
|
|
type PostBack struct {
|
2016-05-04 18:09:34 +10:00
|
|
|
// Sender is who the message was sent from.
|
2016-05-03 16:42:25 +03:00
|
|
|
Sender Sender `json:"-"`
|
|
|
|
// Recipient is who the message was sent to.
|
|
|
|
Recipient Recipient `json:"-"`
|
|
|
|
// Time is when the message was sent.
|
|
|
|
Time time.Time `json:"-"`
|
2016-05-04 18:09:34 +10:00
|
|
|
// PostBack ID
|
2016-05-03 16:42:25 +03:00
|
|
|
Payload string `json:"payload"`
|
2017-02-17 03:29:12 +01:00
|
|
|
// Optional referral info
|
|
|
|
Referral Referral `json:"referral"`
|
2016-05-03 16:42:25 +03:00
|
|
|
}
|
|
|
|
|
2018-03-10 10:12:35 +01:00
|
|
|
type AccountLinking struct {
|
|
|
|
// Sender is who the message was sent from.
|
|
|
|
Sender Sender `json:"-"`
|
|
|
|
// Recipient is who the message was sent to.
|
|
|
|
Recipient Recipient `json:"-"`
|
|
|
|
// Time is when the message was sent.
|
|
|
|
Time time.Time `json:"-"`
|
|
|
|
// Status represents the new account linking status.
|
|
|
|
Status string `json:"status"`
|
|
|
|
// AuthorizationCode is a pass-through code set during the linking process.
|
|
|
|
AuthorizationCode string `json:"authorization_code"`
|
|
|
|
}
|
|
|
|
|
2016-04-14 09:53:55 +10:00
|
|
|
// Watermark is the RawWatermark timestamp rendered as a time.Time.
|
2016-04-13 19:36:38 +10:00
|
|
|
func (d Delivery) Watermark() time.Time {
|
2016-10-04 03:44:18 +02:00
|
|
|
return time.Unix(d.RawWatermark/int64(time.Microsecond), 0)
|
2016-04-13 16:14:23 +10:00
|
|
|
}
|
2016-08-18 09:41:25 +10:00
|
|
|
|
|
|
|
// Watermark is the RawWatermark timestamp rendered as a time.Time.
|
|
|
|
func (r Read) Watermark() time.Time {
|
2016-10-04 03:44:18 +02:00
|
|
|
return time.Unix(r.RawWatermark/int64(time.Microsecond), 0)
|
2016-08-18 09:41:25 +10:00
|
|
|
}
|