mirror of
https://github.com/retailcrm/mg-bot-api-client-go.git
synced 2024-11-23 13:26:03 +03:00
Merge pull request #82 from ilyavlasoff/added_message_dialog_field
Added Message.Dialog field for all types of messages
This commit is contained in:
commit
5466d2d1ad
@ -555,6 +555,83 @@ func TestMgClient_Messages(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestMgClient_MessagesDialog(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
c := client()
|
||||||
|
|
||||||
|
defer gock.Off()
|
||||||
|
|
||||||
|
gock.New(mgURL).
|
||||||
|
Get("/api/bot/v1/messages").
|
||||||
|
Reply(200).
|
||||||
|
BodyString(`[
|
||||||
|
{
|
||||||
|
"id": 1,
|
||||||
|
"time": "2024-11-14T20:48:21Z",
|
||||||
|
"type": "system",
|
||||||
|
"scope": "private",
|
||||||
|
"chat_id": 1,
|
||||||
|
"is_read": false,
|
||||||
|
"is_edit": false,
|
||||||
|
"status": "received",
|
||||||
|
"dialog": {
|
||||||
|
"id": 2054
|
||||||
|
},
|
||||||
|
"action": "dialog_closed",
|
||||||
|
"channel_id": 71,
|
||||||
|
"created_at": "2024-11-14T20:48:21.907566Z",
|
||||||
|
"updated_at": "2024-11-14T20:48:21.907566Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": 2,
|
||||||
|
"time": "2024-11-14T19:58:42Z",
|
||||||
|
"type": "text",
|
||||||
|
"scope": "public",
|
||||||
|
"chat_id": 1,
|
||||||
|
"is_read": false,
|
||||||
|
"is_edit": false,
|
||||||
|
"status": "failed",
|
||||||
|
"from": {
|
||||||
|
"id": 1,
|
||||||
|
"external_id": "1",
|
||||||
|
"type": "user",
|
||||||
|
"avatar": "http://avatars-test.jpeg",
|
||||||
|
"name": "John Smith",
|
||||||
|
"first_name": "John",
|
||||||
|
"last_name": "Smith",
|
||||||
|
"available": true
|
||||||
|
},
|
||||||
|
"dialog": {
|
||||||
|
"id": 2054
|
||||||
|
},
|
||||||
|
"error": {
|
||||||
|
"code": "malformed_response"
|
||||||
|
},
|
||||||
|
"content": "Message from user John Smith",
|
||||||
|
"quote": null,
|
||||||
|
"channel_id": 71,
|
||||||
|
"created_at": "2024-11-14T19:58:42.933025Z",
|
||||||
|
"updated_at": "2024-11-14T19:58:45.01619Z"
|
||||||
|
}
|
||||||
|
]`)
|
||||||
|
|
||||||
|
req := MessagesRequest{}
|
||||||
|
|
||||||
|
data, status, err := c.Messages(req)
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("%d %v", status, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Len(t, data, 2)
|
||||||
|
|
||||||
|
for _, m := range data {
|
||||||
|
assert.NotNil(t, m.Message.Dialog)
|
||||||
|
assert.Equal(t, uint64(2054), m.Message.Dialog.ID)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func TestMgClient_MessageSendText(t *testing.T) {
|
func TestMgClient_MessageSendText(t *testing.T) {
|
||||||
c := client()
|
c := client()
|
||||||
|
|
||||||
|
@ -467,6 +467,7 @@ type (
|
|||||||
From *UserRef `json:"from"`
|
From *UserRef `json:"from"`
|
||||||
Product *MessageProduct `json:"product,omitempty"`
|
Product *MessageProduct `json:"product,omitempty"`
|
||||||
Order *MessageOrder `json:"order,omitempty"`
|
Order *MessageOrder `json:"order,omitempty"`
|
||||||
|
Dialog *MessageDialog `json:"dialog,omitempty"`
|
||||||
*TextMessage
|
*TextMessage
|
||||||
*SystemMessage
|
*SystemMessage
|
||||||
*AttachmentList
|
*AttachmentList
|
||||||
@ -483,16 +484,22 @@ type (
|
|||||||
}
|
}
|
||||||
|
|
||||||
SystemMessage struct {
|
SystemMessage struct {
|
||||||
Action string `json:"action"`
|
Action string `json:"action"`
|
||||||
|
// Deprecated: Use Message.Dialog.ID instead.
|
||||||
Dialog *SystemMessageDialog `json:"dialog,omitempty"`
|
Dialog *SystemMessageDialog `json:"dialog,omitempty"`
|
||||||
User *UserRef `json:"user,omitempty"`
|
User *UserRef `json:"user,omitempty"`
|
||||||
Responsible *UserRef `json:"responsible,omitempty"`
|
Responsible *UserRef `json:"responsible,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Deprecated: Use MessageDialog instead.
|
||||||
SystemMessageDialog struct {
|
SystemMessageDialog struct {
|
||||||
ID uint64 `json:"id"`
|
ID uint64 `json:"id"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MessageDialog struct {
|
||||||
|
ID uint64 `json:"id"`
|
||||||
|
}
|
||||||
|
|
||||||
QuoteMessage struct {
|
QuoteMessage struct {
|
||||||
ID uint64 `json:"id"`
|
ID uint64 `json:"id"`
|
||||||
Content string `json:"content"`
|
Content string `json:"content"`
|
||||||
|
Loading…
Reference in New Issue
Block a user