2020-04-30 16:36:31 +02:00
|
|
|
package gorocket
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2022-09-27 09:57:03 +02:00
|
|
|
"strconv"
|
2020-04-30 16:36:31 +02:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Message struct {
|
2020-06-20 17:14:33 +02:00
|
|
|
Alias string `json:"alias,omitempty"`
|
|
|
|
Avatar string `json:"avatar,omitempty"`
|
|
|
|
Channel string `json:"channel,omitempty"`
|
|
|
|
Emoji string `json:"emoji,omitempty"`
|
|
|
|
RoomID string `json:"roomId,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
Text string `json:"text"`
|
2022-09-01 15:22:58 +02:00
|
|
|
Attachments []Attachment `json:"attachments"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type Attachment struct {
|
|
|
|
AudioURL string `json:"audio_url,omitempty"`
|
|
|
|
AuthorIcon string `json:"author_icon,omitempty"`
|
|
|
|
AuthorLink string `json:"author_link,omitempty"`
|
|
|
|
AuthorName string `json:"author_name,omitempty"`
|
|
|
|
Collapsed bool `json:"collapsed,omitempty"`
|
|
|
|
Color string `json:"color,omitempty"`
|
|
|
|
Fields []AttachField `json:"fields,omitempty"`
|
|
|
|
ImageURL string `json:"image_url,omitempty"`
|
|
|
|
MessageLink string `json:"message_link,omitempty"`
|
|
|
|
Text string `json:"text,omitempty"`
|
|
|
|
ThumbURL string `json:"thumb_url,omitempty"`
|
|
|
|
Title string `json:"title,omitempty"`
|
|
|
|
TitleLink string `json:"title_link,omitempty"`
|
|
|
|
TitleLinkDownload bool `json:"title_link_download,omitempty"`
|
|
|
|
Ts time.Time `json:"ts,omitempty"`
|
|
|
|
VideoURL string `json:"video_url,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type AttachField struct {
|
|
|
|
Short bool `json:"short,omitempty"`
|
|
|
|
Title string `json:"title,omitempty"`
|
|
|
|
Value string `json:"value,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
type RespPostMessage struct {
|
2020-09-07 23:27:48 +02:00
|
|
|
Ts int64 `json:"ts"`
|
|
|
|
Channel string `json:"channel"`
|
2022-09-01 15:22:58 +02:00
|
|
|
Message RespMessageData `json:"message"`
|
2020-06-20 17:14:33 +02:00
|
|
|
Success bool `json:"success"`
|
|
|
|
Error string `json:"error,omitempty"`
|
|
|
|
ErrorType string `json:"errorType,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type RespMessageData struct {
|
|
|
|
Alias string `json:"alias,omitempty"`
|
|
|
|
Msg string `json:"msg,omitempty"`
|
|
|
|
ParseUrls bool `json:"parseUrls,omitempty"`
|
|
|
|
Groupable bool `json:"groupable,omitempty"`
|
|
|
|
Ts time.Time `json:"ts,omitempty"`
|
|
|
|
U UChat `json:"u,omitempty"`
|
|
|
|
Rid string `json:"rid,omitempty"`
|
|
|
|
UpdatedAt time.Time `json:"_updatedAt,omitempty"`
|
|
|
|
ID string `json:"_id,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type UChat struct {
|
|
|
|
ID string `json:"_id,omitempty"`
|
|
|
|
Username string `json:"username,omitempty"`
|
2020-04-30 16:36:31 +02:00
|
|
|
}
|
|
|
|
|
2020-09-07 23:27:48 +02:00
|
|
|
type SingleMessageId struct {
|
|
|
|
MessageId string `json:"messageId"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type GetMessageResponse struct {
|
2022-09-01 15:22:58 +02:00
|
|
|
Message MessageResp `json:"message"`
|
|
|
|
Success bool `json:"success"`
|
2020-09-07 23:27:48 +02:00
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type MessageResp struct {
|
2020-09-07 23:27:48 +02:00
|
|
|
ID string `json:"_id"`
|
|
|
|
Rid string `json:"rid"`
|
|
|
|
Msg string `json:"msg"`
|
|
|
|
Ts time.Time `json:"ts"`
|
|
|
|
U struct {
|
|
|
|
ID string `json:"_id"`
|
|
|
|
Username string `json:"username"`
|
|
|
|
} `json:"u"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type DeleteMessageRequest struct {
|
|
|
|
RoomID string `json:"roomId"`
|
|
|
|
MsgID string `json:"msgId"`
|
|
|
|
AsUser bool `json:"asUser,omitempty"`
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// todo add the remaining fields
|
2020-09-07 23:27:48 +02:00
|
|
|
type DeleteMessageResponse struct {
|
|
|
|
ID string `json:"_id"`
|
|
|
|
Ts int64 `json:"ts"`
|
|
|
|
Success bool `json:"success"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type GetPinnedMsgRequest struct {
|
|
|
|
RoomId string
|
|
|
|
Count int
|
|
|
|
Offset int
|
|
|
|
}
|
|
|
|
|
|
|
|
type GetPinnedMsgResponse struct {
|
2022-09-01 15:22:58 +02:00
|
|
|
Messages []PinnedMessage `json:"messages"`
|
2020-09-07 23:27:48 +02:00
|
|
|
Count int `json:"count"`
|
|
|
|
Offset int `json:"offset"`
|
|
|
|
Total int `json:"total"`
|
|
|
|
Success bool `json:"success"`
|
|
|
|
}
|
|
|
|
|
2022-09-01 15:22:58 +02:00
|
|
|
type PinnedMessage struct {
|
2020-09-07 23:27:48 +02:00
|
|
|
ID string `json:"_id"`
|
|
|
|
Rid string `json:"rid"`
|
|
|
|
Msg string `json:"msg"`
|
|
|
|
Ts time.Time `json:"ts"`
|
|
|
|
U struct {
|
|
|
|
ID string `json:"_id"`
|
|
|
|
Username string `json:"username"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
} `json:"u"`
|
|
|
|
Mentions []interface{} `json:"mentions"`
|
|
|
|
Channels []interface{} `json:"channels"`
|
|
|
|
UpdatedAt time.Time `json:"_updatedAt"`
|
|
|
|
Pinned bool `json:"pinned"`
|
|
|
|
PinnedAt time.Time `json:"pinnedAt"`
|
|
|
|
PinnedBy struct {
|
|
|
|
ID string `json:"_id"`
|
|
|
|
Username string `json:"username"`
|
|
|
|
} `json:"pinnedBy"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type PinMessageResponse struct {
|
|
|
|
Message struct {
|
|
|
|
T string `json:"t"`
|
|
|
|
Rid string `json:"rid"`
|
|
|
|
Ts time.Time `json:"ts"`
|
|
|
|
Msg string `json:"msg"`
|
|
|
|
U struct {
|
|
|
|
ID string `json:"_id"`
|
|
|
|
Username string `json:"username"`
|
|
|
|
} `json:"u"`
|
|
|
|
Groupable bool `json:"groupable"`
|
|
|
|
Attachments []struct {
|
|
|
|
Text string `json:"text"`
|
|
|
|
AuthorName string `json:"author_name"`
|
|
|
|
AuthorIcon string `json:"author_icon"`
|
|
|
|
Ts time.Time `json:"ts"`
|
|
|
|
} `json:"attachments"`
|
|
|
|
UpdatedAt time.Time `json:"_updatedAt"`
|
|
|
|
ID string `json:"_id"`
|
|
|
|
} `json:"message"`
|
|
|
|
Success bool `json:"success"`
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// PostMessage posts a new chat message.
|
2020-04-30 16:36:31 +02:00
|
|
|
func (c *Client) PostMessage(msg *Message) (*RespPostMessage, error) {
|
|
|
|
|
|
|
|
opt, _ := json.Marshal(msg)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST",
|
2020-06-10 18:19:25 +02:00
|
|
|
fmt.Sprintf("%s/%s/chat.postMessage", c.baseURL, c.apiVersion),
|
2020-04-30 16:36:31 +02:00
|
|
|
bytes.NewBuffer(opt))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2020-06-21 11:50:28 +02:00
|
|
|
|
2020-04-30 16:36:31 +02:00
|
|
|
res := RespPostMessage{}
|
2020-06-20 17:14:33 +02:00
|
|
|
|
2020-04-30 16:36:31 +02:00
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|
2020-09-07 23:27:48 +02:00
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// GetMessage retrieves a single chat message by the provided id.
|
2020-09-07 23:27:48 +02:00
|
|
|
// Callee must have permission to access the room where the message resides.
|
|
|
|
func (c *Client) GetMessage(param *SingleMessageId) (*GetMessageResponse, error) {
|
|
|
|
req, err := http.NewRequest("GET",
|
|
|
|
fmt.Sprintf("%s/%s/chat.getMessage", c.baseURL, c.apiVersion),
|
|
|
|
nil)
|
|
|
|
|
|
|
|
if param.MessageId == "" {
|
2024-02-03 21:54:40 +02:00
|
|
|
return nil, fmt.Errorf("false parameters")
|
2020-09-07 23:27:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
url := req.URL.Query()
|
|
|
|
if param.MessageId != "" {
|
|
|
|
url.Add("msgId", param.MessageId)
|
|
|
|
}
|
|
|
|
req.URL.RawQuery = url.Encode()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
res := GetMessageResponse{}
|
|
|
|
|
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// DeleteMessage deletes an existing chat message.
|
2020-09-07 23:27:48 +02:00
|
|
|
func (c *Client) DeleteMessage(param *DeleteMessageRequest) (*DeleteMessageResponse, error) {
|
|
|
|
opt, _ := json.Marshal(param)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST",
|
|
|
|
fmt.Sprintf("%s/%s/chat.delete", c.baseURL, c.apiVersion),
|
|
|
|
bytes.NewBuffer(opt))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
res := DeleteMessageResponse{}
|
|
|
|
|
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// GetPinnedMessages retrieve pinned messages from a room.
|
2020-09-07 23:27:48 +02:00
|
|
|
func (c *Client) GetPinnedMessages(param *GetPinnedMsgRequest) (*GetPinnedMsgResponse, error) {
|
|
|
|
req, err := http.NewRequest("GET",
|
|
|
|
fmt.Sprintf("%s/%s/chat.getPinnedMessages", c.baseURL, c.apiVersion),
|
|
|
|
nil)
|
|
|
|
|
|
|
|
if param.RoomId == "" {
|
2024-02-03 21:54:40 +02:00
|
|
|
return nil, fmt.Errorf("false parameters")
|
2020-09-07 23:27:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
url := req.URL.Query()
|
|
|
|
if param.RoomId != "" {
|
|
|
|
url.Add("roomId", param.RoomId)
|
|
|
|
}
|
|
|
|
if param.Offset != 0 {
|
2022-09-27 09:57:03 +02:00
|
|
|
url.Add("offset", strconv.Itoa(param.Offset))
|
2020-09-07 23:27:48 +02:00
|
|
|
}
|
|
|
|
if param.Count != 0 {
|
2022-09-27 09:57:03 +02:00
|
|
|
url.Add("count", strconv.Itoa(param.Count))
|
2020-09-07 23:27:48 +02:00
|
|
|
}
|
|
|
|
req.URL.RawQuery = url.Encode()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
res := GetPinnedMsgResponse{}
|
|
|
|
|
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// PinMessage pins a chat message to the message's channel.
|
2020-09-07 23:27:48 +02:00
|
|
|
func (c *Client) PinMessage(param *SingleMessageId) (*PinMessageResponse, error) {
|
|
|
|
opt, _ := json.Marshal(param)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST",
|
|
|
|
fmt.Sprintf("%s/%s/chat.pinMessage", c.baseURL, c.apiVersion),
|
|
|
|
bytes.NewBuffer(opt))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
res := PinMessageResponse{}
|
|
|
|
|
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|
|
|
|
|
2024-02-03 21:54:40 +02:00
|
|
|
// UnpinMessage unpins a chat message to the message's channel.
|
2020-09-07 23:27:48 +02:00
|
|
|
func (c *Client) UnpinMessage(param *SingleMessageId) (*SimpleSuccessResponse, error) {
|
|
|
|
opt, _ := json.Marshal(param)
|
|
|
|
|
|
|
|
req, err := http.NewRequest("POST",
|
|
|
|
fmt.Sprintf("%s/%s/chat.unPinMessage", c.baseURL, c.apiVersion),
|
|
|
|
bytes.NewBuffer(opt))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
res := SimpleSuccessResponse{}
|
|
|
|
|
|
|
|
if err := c.sendRequest(req, &res); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &res, nil
|
|
|
|
}
|