update godoc for methods and some types
This commit is contained in:
parent
933d2051ab
commit
5e605c9d19
542
v1/client.go
542
v1/client.go
@ -49,7 +49,7 @@ func (c *MgClient) writeLog(format string, v ...interface{}) {
|
|||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// client := v1.New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
//
|
||||||
// data, status, err := client.TransportTemplates()
|
// data, status, err := client.TransportTemplates()
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
@ -76,57 +76,29 @@ func (c *MgClient) TransportTemplates() ([]Template, int, error) {
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func ooga() {
|
// ActivateTemplate activates template with provided structure.
|
||||||
client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
|
||||||
|
|
||||||
status, err := client.ActivateTemplate(1, ActivateTemplateRequest{
|
|
||||||
UpdateTemplateRequest: UpdateTemplateRequest{
|
|
||||||
Name: "New Template",
|
|
||||||
Body: "Hello, {{1}}! Welcome to our store!",
|
|
||||||
Lang: "en",
|
|
||||||
Category: "marketing",
|
|
||||||
Example: &TemplateExample{
|
|
||||||
Header: []string{"https://example.com/image.png"},
|
|
||||||
Body: []string{"John"},
|
|
||||||
},
|
|
||||||
VerificationStatus: TemplateStatusApproved,
|
|
||||||
Header: &TemplateHeader{
|
|
||||||
Content: HeaderContentImage{},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
Code: "new_template",
|
|
||||||
Type: TemplateTypeMedia,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalf("request error: %s (%d)", err, status)
|
|
||||||
}
|
|
||||||
|
|
||||||
log.Printf("status: %d", status)
|
|
||||||
}
|
|
||||||
|
|
||||||
// ActivateTemplate implements template activation
|
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// client := v1.New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
//
|
||||||
// status, err := client.ActivateTemplate(1, v1.ActivateTemplateRequest{
|
// status, err := client.ActivateTemplate(1, ActivateTemplateRequest{
|
||||||
// UpdateTemplateRequest: v1.UpdateTemplateRequest{
|
// UpdateTemplateRequest: UpdateTemplateRequest{
|
||||||
// Name: "New Template",
|
// Name: "New Template",
|
||||||
// Body: "Hello, {{1}}! Welcome to our store!",
|
// Body: "Hello, {{1}}! Welcome to our store!",
|
||||||
// Lang: "en",
|
// Lang: "en",
|
||||||
// Category: "marketing",
|
// Category: "marketing",
|
||||||
// Example: &v1.TemplateExample{
|
// Example: &TemplateExample{
|
||||||
// Header: []string{"https://example.com/image.png"},
|
// Header: []string{"https://example.com/image.png"},
|
||||||
// Body: []string{"John"},
|
// Body: []string{"John"},
|
||||||
// },
|
// },
|
||||||
// VerificationStatus: v1.TemplateStatusApproved,
|
// VerificationStatus: TemplateStatusApproved,
|
||||||
// Header: &v1.TemplateHeader{
|
// Header: &TemplateHeader{
|
||||||
// Content: v1.HeaderContentImage{},
|
// Content: HeaderContentImage{},
|
||||||
// },
|
// },
|
||||||
// },
|
// },
|
||||||
// Code: "new_template",
|
// Code: "new_template",
|
||||||
// Type: v1.TemplateTypeMedia,
|
// Type: TemplateTypeMedia,
|
||||||
// })
|
// })
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// log.Fatalf("request error: %s (%d)", err, status)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
@ -148,36 +120,31 @@ func (c *MgClient) ActivateTemplate(channelID uint64, request ActivateTemplateRe
|
|||||||
return status, err
|
return status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateTemplate implements template updating
|
// UpdateTemplate updates existing template by its code.
|
||||||
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
//
|
||||||
// request := v1.Template{
|
// status, err := client.UpdateTemplate(1, "new_template", UpdateTemplateRequest{
|
||||||
// Code: "templateCode",
|
// Name: "New Template",
|
||||||
// ChannelID: 1,
|
// Body: "Hello, {{1}}! Welcome to our store!",
|
||||||
// Name: "templateName",
|
// Lang: "en",
|
||||||
// Template: []v1.TemplateItem{
|
// Category: "marketing",
|
||||||
// {
|
// Example: &TemplateExample{
|
||||||
// Type: v1.TemplateItemTypeText,
|
// Header: []string{"https://example.com/image.png"},
|
||||||
// Text: "Welcome, ",
|
// Body: []string{"John"},
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// Type: v1.TemplateItemTypeVar,
|
|
||||||
// VarType: v1.TemplateVarName,
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// Type: v1.TemplateItemTypeText,
|
|
||||||
// Text: "!",
|
|
||||||
// },
|
|
||||||
// },
|
// },
|
||||||
// }
|
// VerificationStatus: TemplateStatusApproved,
|
||||||
//
|
// Header: &TemplateHeader{
|
||||||
// _, err := client.UpdateTemplate(request)
|
// Content: HeaderContentImage{},
|
||||||
//
|
// },
|
||||||
|
// })
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%#v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d", status)
|
||||||
func (c *MgClient) UpdateTemplate(channelID uint64, code string, request UpdateTemplateRequest) (int, error) {
|
func (c *MgClient) UpdateTemplate(channelID uint64, code string, request UpdateTemplateRequest) (int, error) {
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
|
|
||||||
@ -198,17 +165,18 @@ func (c *MgClient) UpdateTemplate(channelID uint64, code string, request UpdateT
|
|||||||
return status, err
|
return status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeactivateTemplate implements template deactivation
|
// DeactivateTemplate deactivates the template by its code.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
|
||||||
// _, err := client.DeactivateTemplate(3053450384, "templateCode")
|
|
||||||
//
|
//
|
||||||
|
// status, err := client.DeactivateTemplate(1, "new_template")
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d", status)
|
||||||
func (c *MgClient) DeactivateTemplate(channelID uint64, templateCode string) (int, error) {
|
func (c *MgClient) DeactivateTemplate(channelID uint64, templateCode string) (int, error) {
|
||||||
data, status, err := c.DeleteRequest(
|
data, status, err := c.DeleteRequest(
|
||||||
fmt.Sprintf("/channels/%d/templates/%s", channelID, url.PathEscape(templateCode)), []byte{})
|
fmt.Sprintf("/channels/%d/templates/%s", channelID, url.PathEscape(templateCode)), []byte{})
|
||||||
@ -223,19 +191,20 @@ func (c *MgClient) DeactivateTemplate(channelID uint64, templateCode string) (in
|
|||||||
return status, err
|
return status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// TransportChannels returns channels list
|
// TransportChannels returns channels for current transport.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
|
||||||
// data, status, err := client.TransportChannels(Channels{Active: true})
|
|
||||||
//
|
//
|
||||||
|
// resp, status, err := client.TransportChannels(Channels{
|
||||||
|
// Active: true,
|
||||||
|
// })
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("Status: %v, Channels found: %v", status, len(data))
|
// log.Printf("status: %d, channels: %#v", status, resp)
|
||||||
func (c *MgClient) TransportChannels(request Channels) ([]ChannelListItem, int, error) {
|
func (c *MgClient) TransportChannels(request Channels) ([]ChannelListItem, int, error) {
|
||||||
var resp []ChannelListItem
|
var resp []ChannelListItem
|
||||||
var b []byte
|
var b []byte
|
||||||
@ -257,45 +226,80 @@ func (c *MgClient) TransportChannels(request Channels) ([]ChannelListItem, int,
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// ActivateTransportChannel implement channel activation
|
// ActivateTransportChannel activates the channel with provided settings.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
|
// uint16Ptr := func(val uint16) *uint16 {
|
||||||
|
// return &val
|
||||||
|
// }
|
||||||
|
// mbToBytes := func(val uint64) *uint64 {
|
||||||
|
// val = val * 1024 * 1024
|
||||||
|
// return &val
|
||||||
|
// }
|
||||||
//
|
//
|
||||||
// request := ActivateRequest{
|
// resp, status, err := client.ActivateTransportChannel(Channel{
|
||||||
// Type: "telegram",
|
// Type: "telegram",
|
||||||
// Name: "@my_shopping_bot",
|
// Name: "@my_shopping_bot",
|
||||||
// Settings: ChannelSettings{
|
// Settings: ChannelSettings{
|
||||||
// Status: Status{
|
// Status: Status{
|
||||||
// Delivered: ChannelFeatureNone,
|
// Delivered: ChannelFeatureNone,
|
||||||
// Read: ChannelFeatureReceive,
|
// Read: ChannelFeatureReceive,
|
||||||
// },
|
// },
|
||||||
// Text: ChannelSettingsText{
|
// Text: ChannelSettingsText{
|
||||||
// Creating: ChannelFeatureBoth,
|
// Creating: ChannelFeatureBoth,
|
||||||
// Editing: ChannelFeatureBoth,
|
// Editing: ChannelFeatureBoth,
|
||||||
// Quoting: ChannelFeatureReceive,
|
// Quoting: ChannelFeatureReceive,
|
||||||
// Deleting: ChannelFeatureSend,
|
// Deleting: ChannelFeatureSend,
|
||||||
// MaxCharsCount: 2000,
|
// MaxCharsCount: 2000,
|
||||||
// },
|
// },
|
||||||
// Product: Product{
|
// Product: Product{
|
||||||
// Creating: ChannelFeatureSend,
|
// Creating: ChannelFeatureSend,
|
||||||
|
// Editing: ChannelFeatureNone,
|
||||||
// Deleting: ChannelFeatureSend,
|
// Deleting: ChannelFeatureSend,
|
||||||
// },
|
// },
|
||||||
// Order: Order{
|
// Order: Order{
|
||||||
// Creating: ChannelFeatureBoth,
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureNone,
|
||||||
// Deleting: ChannelFeatureSend,
|
// Deleting: ChannelFeatureSend,
|
||||||
// },
|
// },
|
||||||
|
// File: ChannelSettingsFilesBase{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// Max: 10,
|
||||||
|
// NoteMaxCharsCount: uint16Ptr(256),
|
||||||
|
// MaxItemSize: mbToBytes(50),
|
||||||
|
// },
|
||||||
|
// Image: ChannelSettingsFilesBase{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// Max: 10,
|
||||||
|
// NoteMaxCharsCount: uint16Ptr(256),
|
||||||
|
// MaxItemSize: mbToBytes(10),
|
||||||
|
// },
|
||||||
|
// Suggestions: ChannelSettingsSuggestions{
|
||||||
|
// Text: ChannelFeatureBoth,
|
||||||
|
// Phone: ChannelFeatureBoth,
|
||||||
|
// Email: ChannelFeatureBoth,
|
||||||
|
// },
|
||||||
|
// Audio: ChannelSettingsAudio{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// MaxItemSize: mbToBytes(10),
|
||||||
|
// },
|
||||||
// },
|
// },
|
||||||
// }
|
// })
|
||||||
//
|
|
||||||
// data, status, err := client.ActivateTransportChannel(request)
|
|
||||||
//
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.CreatedAt)
|
// log.Printf("status: %d, channel external_id: %s", status, resp.ExternalID)
|
||||||
func (c *MgClient) ActivateTransportChannel(request Channel) (ActivateResponse, int, error) {
|
func (c *MgClient) ActivateTransportChannel(request Channel) (ActivateResponse, int, error) {
|
||||||
var resp ActivateResponse
|
var resp ActivateResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -316,45 +320,81 @@ func (c *MgClient) ActivateTransportChannel(request Channel) (ActivateResponse,
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateTransportChannel implement channel activation
|
// UpdateTransportChannel updates an existing channel with provided settings.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
|
// uint16Ptr := func(val uint16) *uint16 {
|
||||||
|
// return &val
|
||||||
|
// }
|
||||||
|
// mbToBytes := func(val uint64) *uint64 {
|
||||||
|
// val = val * 1024 * 1024
|
||||||
|
// return &val
|
||||||
|
// }
|
||||||
//
|
//
|
||||||
// request := ActivateRequest{
|
// resp, status, err := client.UpdateTransportChannel(Channel{
|
||||||
// ID: 3053450384,
|
// ID: 305,
|
||||||
// Type: "telegram",
|
// Type: "telegram",
|
||||||
// Name: "@my_shopping_bot",
|
// Name: "@my_shopping_bot",
|
||||||
// Settings: ChannelSettings{
|
// Settings: ChannelSettings{
|
||||||
// Status: Status{
|
// Status: Status{
|
||||||
// Delivered: ChannelFeatureNone,
|
// Delivered: ChannelFeatureNone,
|
||||||
// Read: ChannelFeatureReceive,
|
// Read: ChannelFeatureReceive,
|
||||||
// },
|
// },
|
||||||
// Text: ChannelSettingsText{
|
// Text: ChannelSettingsText{
|
||||||
// Creating: ChannelFeatureBoth,
|
// Creating: ChannelFeatureBoth,
|
||||||
// Editing: ChannelFeatureSend,
|
// Editing: ChannelFeatureBoth,
|
||||||
// Quoting: ChannelFeatureReceive,
|
// Quoting: ChannelFeatureReceive,
|
||||||
// Deleting: ChannelFeatureBoth,
|
// Deleting: ChannelFeatureSend,
|
||||||
|
// MaxCharsCount: 2000,
|
||||||
// },
|
// },
|
||||||
// Product: Product{
|
// Product: Product{
|
||||||
// Creating: ChannelFeatureSend,
|
// Creating: ChannelFeatureSend,
|
||||||
|
// Editing: ChannelFeatureNone,
|
||||||
// Deleting: ChannelFeatureSend,
|
// Deleting: ChannelFeatureSend,
|
||||||
// },
|
// },
|
||||||
// Order: Order{
|
// Order: Order{
|
||||||
// Creating: ChannelFeatureBoth,
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureNone,
|
||||||
// Deleting: ChannelFeatureSend,
|
// Deleting: ChannelFeatureSend,
|
||||||
// },
|
// },
|
||||||
|
// File: ChannelSettingsFilesBase{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// Max: 10,
|
||||||
|
// NoteMaxCharsCount: uint16Ptr(256),
|
||||||
|
// MaxItemSize: mbToBytes(50),
|
||||||
|
// },
|
||||||
|
// Image: ChannelSettingsFilesBase{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Editing: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// Max: 10,
|
||||||
|
// NoteMaxCharsCount: uint16Ptr(256),
|
||||||
|
// MaxItemSize: mbToBytes(10),
|
||||||
|
// },
|
||||||
|
// Suggestions: ChannelSettingsSuggestions{
|
||||||
|
// Text: ChannelFeatureBoth,
|
||||||
|
// Phone: ChannelFeatureBoth,
|
||||||
|
// Email: ChannelFeatureBoth,
|
||||||
|
// },
|
||||||
|
// Audio: ChannelSettingsAudio{
|
||||||
|
// Creating: ChannelFeatureBoth,
|
||||||
|
// Quoting: ChannelFeatureBoth,
|
||||||
|
// Deleting: ChannelFeatureBoth,
|
||||||
|
// MaxItemSize: mbToBytes(10),
|
||||||
|
// },
|
||||||
// },
|
// },
|
||||||
// }
|
// })
|
||||||
//
|
|
||||||
// data, status, err := client.UpdateTransportChannel(request)
|
|
||||||
//
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.UpdatedAt)
|
// log.Printf("status: %d, channel_id: %d", status, resp.ChannelID)
|
||||||
func (c *MgClient) UpdateTransportChannel(request Channel) (UpdateResponse, int, error) {
|
func (c *MgClient) UpdateTransportChannel(request Channel) (UpdateResponse, int, error) {
|
||||||
var resp UpdateResponse
|
var resp UpdateResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -375,19 +415,18 @@ func (c *MgClient) UpdateTransportChannel(request Channel) (UpdateResponse, int,
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeactivateTransportChannel implement channel deactivation
|
// DeactivateTransportChannel deactivates the channel by its ID.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
|
||||||
// data, status, err := client.DeactivateTransportChannel(3053450384)
|
|
||||||
//
|
//
|
||||||
|
// resp, status, err := client.DeactivateTransportChannel(305)
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.DeactivatedAt)
|
// log.Printf("status: %d, deactivated at: %s", status, resp.DeactivatedAt)
|
||||||
func (c *MgClient) DeactivateTransportChannel(id uint64) (DeleteResponse, int, error) {
|
func (c *MgClient) DeactivateTransportChannel(id uint64) (DeleteResponse, int, error) {
|
||||||
var resp DeleteResponse
|
var resp DeleteResponse
|
||||||
var buf []byte
|
var buf []byte
|
||||||
@ -411,35 +450,49 @@ func (c *MgClient) DeactivateTransportChannel(id uint64) (DeleteResponse, int, e
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// Messages implement send message
|
// Messages sends new message.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
// msg := SendData{
|
// getReplyDeadline := func(after time.Duration) *time.Time {
|
||||||
// SendMessage{
|
// deadline := time.Now().Add(after)
|
||||||
// Message{
|
// return &deadline
|
||||||
// ExternalID: "274628",
|
// }
|
||||||
// Type: "text",
|
//
|
||||||
// Text: "hello!",
|
// resp, status, err := client.Messages(SendData{
|
||||||
|
// Message: Message{
|
||||||
|
// ExternalID: "uid_1",
|
||||||
|
// Type: MsgTypeText,
|
||||||
|
// Text: "Hello customer!",
|
||||||
|
// PageLink: "https://example.com",
|
||||||
|
// },
|
||||||
|
// Originator: OriginatorCustomer,
|
||||||
|
// Customer: Customer{
|
||||||
|
// ExternalID: "client_id_1",
|
||||||
|
// Nickname: "customer",
|
||||||
|
// Firstname: "Tester",
|
||||||
|
// Lastname: "Tester",
|
||||||
|
// Avatar: "https://example.com/image.png",
|
||||||
|
// ProfileURL: "https://example.com/user/client_id_1",
|
||||||
|
// Language: "en",
|
||||||
|
// Utm: &Utm{
|
||||||
|
// Source: "myspace.com",
|
||||||
|
// Medium: "social",
|
||||||
|
// Campaign: "something",
|
||||||
|
// Term: "fedora",
|
||||||
|
// Content: "autumn_collection",
|
||||||
// },
|
// },
|
||||||
// time.Now(),
|
|
||||||
// },
|
// },
|
||||||
// User{
|
// Channel: 305,
|
||||||
// ExternalID: "8",
|
// ExternalChatID: "chat_id_1",
|
||||||
// Nickname: "@octopus",
|
// ReplyDeadline: getReplyDeadline(24 * time.Hour),
|
||||||
// Firstname: "Joe",
|
// })
|
||||||
// },
|
|
||||||
// 10,
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// data, status, err := client.Messages(msg)
|
|
||||||
//
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.MessageID)
|
// log.Printf("status: %d, message ID: %d", status, resp.MessageID)
|
||||||
func (c *MgClient) Messages(request SendData) (MessagesResponse, int, error) {
|
func (c *MgClient) Messages(request SendData) (MessagesResponse, int, error) {
|
||||||
var resp MessagesResponse
|
var resp MessagesResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -460,37 +513,49 @@ func (c *MgClient) Messages(request SendData) (MessagesResponse, int, error) {
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// MessagesHistory implement history message sending.
|
// MessagesHistory sends history message.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
// msg := v1.SendHistoryMessageRequest{
|
// getModifiedNow := func(after time.Duration) *time.Time {
|
||||||
// Message: v1.SendMessageRequestMessage{
|
// deadline := time.Now().Add(after)
|
||||||
// Type: v1.MsgTypeText,
|
// return &deadline
|
||||||
// ExternalID: "external_id",
|
|
||||||
// CreatedAt: v1.TimePtr(time.Now()),
|
|
||||||
// IsComment: false,
|
|
||||||
// Text: "Test message",
|
|
||||||
// },
|
|
||||||
// ChannelID: 1,
|
|
||||||
// ExternalChatID: "chat_id",
|
|
||||||
// Customer: &v1.Customer{
|
|
||||||
// ExternalID: "1",
|
|
||||||
// Nickname: "@john_doe",
|
|
||||||
// Firstname: "John",
|
|
||||||
// Lastname: "Doe",
|
|
||||||
// },
|
|
||||||
// Originator: v1.OriginatorCustomer,
|
|
||||||
// ReplyDeadline: v1.TimePtr(time.Now().Add(time.Hour * 24)),
|
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// data, status, err := client.MessagesHistory(msg)
|
// resp, status, err := client.MessagesHistory(SendHistoryMessageRequest{
|
||||||
|
// Message: SendMessageRequestMessage{
|
||||||
|
// ExternalID: "uid_1",
|
||||||
|
// Type: MsgTypeText,
|
||||||
|
// Text: "Hello customer!",
|
||||||
|
// CreatedAt: getModifiedNow(-time.Hour),
|
||||||
|
// },
|
||||||
|
// Originator: OriginatorCustomer,
|
||||||
|
// Customer: &Customer{
|
||||||
|
// ExternalID: "client_id_1",
|
||||||
|
// Nickname: "customer",
|
||||||
|
// Firstname: "Tester",
|
||||||
|
// Lastname: "Tester",
|
||||||
|
// Avatar: "https://example.com/image.png",
|
||||||
|
// ProfileURL: "https://example.com/user/client_id_1",
|
||||||
|
// Language: "en",
|
||||||
|
// Utm: &Utm{
|
||||||
|
// Source: "myspace.com",
|
||||||
|
// Medium: "social",
|
||||||
|
// Campaign: "something",
|
||||||
|
// Term: "fedora",
|
||||||
|
// Content: "autumn_collection",
|
||||||
|
// },
|
||||||
|
// },
|
||||||
|
// ChannelID: 305,
|
||||||
|
// ExternalChatID: "chat_id_1",
|
||||||
|
// ReplyDeadline: getModifiedNow(24 * time.Hour),
|
||||||
|
// })
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("[%d]: %v", status, err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%d\n", data.MessageID)
|
// log.Printf("status: %d, message ID: %d", status, resp.MessageID)
|
||||||
func (c *MgClient) MessagesHistory(request SendHistoryMessageRequest) (MessagesResponse, int, error) {
|
func (c *MgClient) MessagesHistory(request SendHistoryMessageRequest) (MessagesResponse, int, error) {
|
||||||
var (
|
var (
|
||||||
resp MessagesResponse
|
resp MessagesResponse
|
||||||
@ -514,30 +579,24 @@ func (c *MgClient) MessagesHistory(request SendHistoryMessageRequest) (MessagesR
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateMessages implement edit message
|
// UpdateMessages edits existing message. Only text messages are supported.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
// msg := UpdateData{
|
//
|
||||||
// UpdateMessage{
|
// resp, status, err := client.UpdateMessages(EditMessageRequest{
|
||||||
// Message{
|
// Message: EditMessageRequestMessage{
|
||||||
// ExternalID: "274628",
|
// ExternalID: "message_id_1",
|
||||||
// Type: "text",
|
// Text: "This is a new text!",
|
||||||
// Text: "hello hello!",
|
|
||||||
// },
|
|
||||||
// MakeTimestamp(),
|
|
||||||
// },
|
// },
|
||||||
// 10,
|
// Channel: 305,
|
||||||
// }
|
// })
|
||||||
//
|
|
||||||
// data, status, err := client.UpdateMessages(msg)
|
|
||||||
//
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.MessageID)
|
// log.Printf("status: %d, message ID: %d", status, resp.MessageID)
|
||||||
func (c *MgClient) UpdateMessages(request EditMessageRequest) (MessagesResponse, int, error) {
|
func (c *MgClient) UpdateMessages(request EditMessageRequest) (MessagesResponse, int, error) {
|
||||||
var resp MessagesResponse
|
var resp MessagesResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -558,25 +617,23 @@ func (c *MgClient) UpdateMessages(request EditMessageRequest) (MessagesResponse,
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarkMessageRead send message read event to MG
|
// MarkMessageRead send message read event to MG.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
// msg := MarkMessageReadRequest{
|
//
|
||||||
// Message{
|
// _, status, err := client.MarkMessageRead(MarkMessageReadRequest{
|
||||||
// ExternalID: "274628",
|
// Message: MarkMessageReadRequestMessage{
|
||||||
|
// ExternalID: "message_id_1",
|
||||||
// },
|
// },
|
||||||
// 10,
|
// ChannelID: 305,
|
||||||
// }
|
// })
|
||||||
//
|
|
||||||
// data, status, err := client.MarkMessageRead(msg)
|
|
||||||
//
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%v %v\n", status, data)
|
// log.Printf("status: %d", status)
|
||||||
func (c *MgClient) MarkMessageRead(request MarkMessageReadRequest) (MarkMessageReadResponse, int, error) {
|
func (c *MgClient) MarkMessageRead(request MarkMessageReadRequest) (MarkMessageReadResponse, int, error) {
|
||||||
var resp MarkMessageReadResponse
|
var resp MarkMessageReadResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -597,22 +654,21 @@ func (c *MgClient) MarkMessageRead(request MarkMessageReadRequest) (MarkMessageR
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// AckMessage implements ack of message
|
// AckMessage sets success status for message or appends an error to message.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
|
||||||
// request := AckMessageRequest{
|
|
||||||
// ExternalMessageID: "274628",
|
|
||||||
// Channel: 10,
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// status, err := client.AckMessage(request)
|
|
||||||
//
|
//
|
||||||
|
// status, err := client.AckMessage(AckMessageRequest{
|
||||||
|
// ExternalMessageID: "message_id_1",
|
||||||
|
// Channel: 305,
|
||||||
|
// })
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d", status)
|
||||||
func (c *MgClient) AckMessage(request AckMessageRequest) (int, error) {
|
func (c *MgClient) AckMessage(request AckMessageRequest) (int, error) {
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
|
|
||||||
@ -632,20 +688,18 @@ func (c *MgClient) AckMessage(request AckMessageRequest) (int, error) {
|
|||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
//
|
||||||
// request := ReadUntilRequest{
|
// resp, status, err := client.ReadUntil(MarkMessagesReadUntilRequest{
|
||||||
// ExternalMessageID: "274628",
|
// CustomerExternalID: "customer_id_1",
|
||||||
// Channel: 10,
|
// ChannelID: 305,
|
||||||
// }
|
// Until: time.Now().Add(-time.Hour),
|
||||||
//
|
// })
|
||||||
// resp, status, err := client.ReadUntil(request)
|
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
|
||||||
// if resp != nil {
|
|
||||||
// fmt.Printf("Marked these as read: %s", resp.IDs)
|
|
||||||
// }
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d, marked messages: %+v", status, resp.IDs)
|
||||||
func (c *MgClient) ReadUntil(request MarkMessagesReadUntilRequest) (*MarkMessagesReadUntilResponse, int, error) {
|
func (c *MgClient) ReadUntil(request MarkMessagesReadUntilRequest) (*MarkMessagesReadUntilResponse, int, error) {
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
|
|
||||||
@ -664,27 +718,23 @@ func (c *MgClient) ReadUntil(request MarkMessagesReadUntilRequest) (*MarkMessage
|
|||||||
return resp, status, nil
|
return resp, status, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteMessage implement delete message
|
// DeleteMessage removes the message.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
//
|
||||||
// msg := DeleteData{
|
// resp, status, err := client.DeleteMessage(DeleteData{
|
||||||
// Message{
|
// Message: Message{
|
||||||
// ExternalID: "274628",
|
// ExternalID: "message_id_1",
|
||||||
// },
|
// },
|
||||||
// 10,
|
// Channel: 305,
|
||||||
// }
|
// })
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
|
// }
|
||||||
//
|
//
|
||||||
// previousChatMessage, status, err := client.DeleteMessage(msg)
|
// log.Printf("status: %d, message ID: %d", status, resp.MessageID)
|
||||||
// if err != nil {
|
|
||||||
// fmt.Printf("%v", err)
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// if previousChatMessage != nil {
|
|
||||||
// fmt.Printf("Previous chat message id = %d", previousChatMessage.MessageID)
|
|
||||||
// }
|
|
||||||
func (c *MgClient) DeleteMessage(request DeleteData) (*MessagesResponse, int, error) {
|
func (c *MgClient) DeleteMessage(request DeleteData) (*MessagesResponse, int, error) {
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
|
|
||||||
@ -707,19 +757,18 @@ func (c *MgClient) DeleteMessage(request DeleteData) (*MessagesResponse, int, er
|
|||||||
return previousChatMessage, status, nil
|
return previousChatMessage, status, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetFile implement get file url
|
// GetFile returns file information by its ID.
|
||||||
//
|
//
|
||||||
// Example:
|
// Example:
|
||||||
//
|
//
|
||||||
// var client = v1.New("https://token.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
//
|
|
||||||
// data, status, err := client.GetFile("file_ID")
|
|
||||||
//
|
//
|
||||||
|
// resp, status, err := client.GetFile("file_id")
|
||||||
// if err != nil {
|
// if err != nil {
|
||||||
// fmt.Printf("%v", err)
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
// }
|
// }
|
||||||
//
|
//
|
||||||
// fmt.Printf("%s\n", data.MessageID)
|
// log.Printf("status: %d, file URL: %s", status, resp.Url)
|
||||||
func (c *MgClient) GetFile(request string) (FullFileResponse, int, error) {
|
func (c *MgClient) GetFile(request string) (FullFileResponse, int, error) {
|
||||||
var resp FullFileResponse
|
var resp FullFileResponse
|
||||||
var b []byte
|
var b []byte
|
||||||
@ -741,7 +790,29 @@ func (c *MgClient) GetFile(request string) (FullFileResponse, int, error) {
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// UploadFile upload file.
|
// UploadFile uploads a file.
|
||||||
|
//
|
||||||
|
// Example:
|
||||||
|
//
|
||||||
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
|
//
|
||||||
|
// file, err := os.Open("/tmp/file.png")
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatalf("cannot open file for reading: %s", err)
|
||||||
|
// }
|
||||||
|
// defer func() { _ = file.Close() }()
|
||||||
|
//
|
||||||
|
// data, err := io.ReadAll(file)
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatalf("cannot read file data: %s", err)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// resp, status, err := client.UploadFile(bytes.NewReader(data))
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d, file ID: %s", status, resp.ID)
|
||||||
func (c *MgClient) UploadFile(request io.Reader) (UploadFileResponse, int, error) {
|
func (c *MgClient) UploadFile(request io.Reader) (UploadFileResponse, int, error) {
|
||||||
var resp UploadFileResponse
|
var resp UploadFileResponse
|
||||||
|
|
||||||
@ -761,7 +832,20 @@ func (c *MgClient) UploadFile(request io.Reader) (UploadFileResponse, int, error
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// UploadFileByURL upload file by url.
|
// UploadFileByURL uploads a file from provided URL.
|
||||||
|
//
|
||||||
|
// Example:
|
||||||
|
//
|
||||||
|
// client := New("https://message-gateway.url", "cb8ccf05e38a47543ad8477d4999be73bff503ea6")
|
||||||
|
//
|
||||||
|
// resp, status, err := client.UploadFileByURL(UploadFileByUrlRequest{
|
||||||
|
// Url: "https://example.com/file.png",
|
||||||
|
// })
|
||||||
|
// if err != nil {
|
||||||
|
// log.Fatalf("request error: %s (%d)", err, status)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// log.Printf("status: %d, file ID: %s", status, resp.ID)
|
||||||
func (c *MgClient) UploadFileByURL(request UploadFileByUrlRequest) (UploadFileResponse, int, error) {
|
func (c *MgClient) UploadFileByURL(request UploadFileByUrlRequest) (UploadFileResponse, int, error) {
|
||||||
var resp UploadFileResponse
|
var resp UploadFileResponse
|
||||||
outgoing, _ := json.Marshal(&request)
|
outgoing, _ := json.Marshal(&request)
|
||||||
@ -782,7 +866,11 @@ func (c *MgClient) UploadFileByURL(request UploadFileByUrlRequest) (UploadFileRe
|
|||||||
return resp, status, err
|
return resp, status, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// MakeTimestamp returns current unix timestamp.
|
// MakeTimestamp returns current unix timestamp in milliseconds.
|
||||||
|
//
|
||||||
|
// Example:
|
||||||
|
//
|
||||||
|
// fmt.Printf("UNIX timestamp in milliseconds: %d", MakeTimestamp())
|
||||||
func MakeTimestamp() int64 {
|
func MakeTimestamp() int64 {
|
||||||
return time.Now().UnixNano() / (int64(time.Millisecond) / int64(time.Nanosecond))
|
return time.Now().UnixNano() / (int64(time.Millisecond) / int64(time.Nanosecond))
|
||||||
}
|
}
|
||||||
|
@ -13,20 +13,24 @@ var defaultErrorMessage = "http client error"
|
|||||||
var internalServerError = "internal server error"
|
var internalServerError = "internal server error"
|
||||||
var marshalError = "cannot unmarshal response body"
|
var marshalError = "cannot unmarshal response body"
|
||||||
|
|
||||||
|
// MGErrors contains a list of errors as sent by MessageGateway.
|
||||||
type MGErrors struct {
|
type MGErrors struct {
|
||||||
Errors []string
|
Errors []string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// HTTPClientError is a common error type used in the client.
|
||||||
type HTTPClientError struct {
|
type HTTPClientError struct {
|
||||||
ErrorMsg string
|
ErrorMsg string
|
||||||
BaseError error
|
BaseError error
|
||||||
Response io.Reader
|
Response io.Reader
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Unwrap returns underlying error. Its presence usually indicates a problem with the network.
|
||||||
func (err *HTTPClientError) Unwrap() error {
|
func (err *HTTPClientError) Unwrap() error {
|
||||||
return err.BaseError
|
return err.BaseError
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Error message will contain either an error from MG or underlying error message.
|
||||||
func (err *HTTPClientError) Error() string {
|
func (err *HTTPClientError) Error() string {
|
||||||
message := defaultErrorMessage
|
message := defaultErrorMessage
|
||||||
|
|
||||||
@ -39,10 +43,12 @@ func (err *HTTPClientError) Error() string {
|
|||||||
return message
|
return message
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewCriticalHTTPError wraps *http.Client error.
|
||||||
func NewCriticalHTTPError(err error) error {
|
func NewCriticalHTTPError(err error) error {
|
||||||
return &HTTPClientError{BaseError: err}
|
return &HTTPClientError{BaseError: err}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewAPIClientError wraps MG error.
|
||||||
func NewAPIClientError(responseBody []byte) error {
|
func NewAPIClientError(responseBody []byte) error {
|
||||||
var data MGErrors
|
var data MGErrors
|
||||||
var message string
|
var message string
|
||||||
@ -62,6 +68,7 @@ func NewAPIClientError(responseBody []byte) error {
|
|||||||
return &HTTPClientError{ErrorMsg: message}
|
return &HTTPClientError{ErrorMsg: message}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// NewServerError wraps an unexpected API error (e.g. 5xx).
|
||||||
func NewServerError(response *http.Response) error {
|
func NewServerError(response *http.Response) error {
|
||||||
var serverError *HTTPClientError
|
var serverError *HTTPClientError
|
||||||
|
|
||||||
|
@ -23,10 +23,12 @@ func buildLimitedRawResponse(resp *http.Response) ([]byte, error) {
|
|||||||
return body, nil
|
return body, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// BoolPtr returns provided boolean as pointer. Can be used while editing the integration module activity.
|
||||||
func BoolPtr(v bool) *bool {
|
func BoolPtr(v bool) *bool {
|
||||||
return &v
|
return &v
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TimePtr returns provided time.Time's pointer.
|
||||||
func TimePtr(v time.Time) *time.Time {
|
func TimePtr(v time.Time) *time.Time {
|
||||||
return &v
|
return &v
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ import (
|
|||||||
|
|
||||||
var prefix = "/api/transport/v1"
|
var prefix = "/api/transport/v1"
|
||||||
|
|
||||||
// GetRequest implements GET Request.
|
// GetRequest performs GET request to the provided route.
|
||||||
func (c *MgClient) GetRequest(url string, parameters []byte) ([]byte, int, error) {
|
func (c *MgClient) GetRequest(url string, parameters []byte) ([]byte, int, error) {
|
||||||
return makeRequest(
|
return makeRequest(
|
||||||
"GET",
|
"GET",
|
||||||
@ -20,7 +20,7 @@ func (c *MgClient) GetRequest(url string, parameters []byte) ([]byte, int, error
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PostRequest implements POST Request.
|
// PostRequest performs POST request to the provided route.
|
||||||
func (c *MgClient) PostRequest(url string, parameters io.Reader) ([]byte, int, error) {
|
func (c *MgClient) PostRequest(url string, parameters io.Reader) ([]byte, int, error) {
|
||||||
return makeRequest(
|
return makeRequest(
|
||||||
"POST",
|
"POST",
|
||||||
@ -30,7 +30,7 @@ func (c *MgClient) PostRequest(url string, parameters io.Reader) ([]byte, int, e
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PutRequest implements PUT Request.
|
// PutRequest performs PUT request to the provided route.
|
||||||
func (c *MgClient) PutRequest(url string, parameters []byte) ([]byte, int, error) {
|
func (c *MgClient) PutRequest(url string, parameters []byte) ([]byte, int, error) {
|
||||||
return makeRequest(
|
return makeRequest(
|
||||||
"PUT",
|
"PUT",
|
||||||
@ -40,7 +40,7 @@ func (c *MgClient) PutRequest(url string, parameters []byte) ([]byte, int, error
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteRequest implements DELETE Request.
|
// DeleteRequest performs DELETE request to the provided route.
|
||||||
func (c *MgClient) DeleteRequest(url string, parameters []byte) ([]byte, int, error) {
|
func (c *MgClient) DeleteRequest(url string, parameters []byte) ([]byte, int, error) {
|
||||||
return makeRequest(
|
return makeRequest(
|
||||||
"DELETE",
|
"DELETE",
|
||||||
|
@ -27,27 +27,47 @@ func (w WebhookRequest) IsMessageWebhook() bool {
|
|||||||
w.Type == MessageSendWebhookType || w.Type == MessageUpdateWebhookType
|
w.Type == MessageSendWebhookType || w.Type == MessageUpdateWebhookType
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// IsTemplateWebhook returns true if current webhook contains data related to the templates changes.
|
||||||
func (w WebhookRequest) IsTemplateWebhook() bool {
|
func (w WebhookRequest) IsTemplateWebhook() bool {
|
||||||
return w.Type == TemplateCreateWebhookType ||
|
return w.Type == TemplateCreateWebhookType ||
|
||||||
w.Type == TemplateUpdateWebhookType ||
|
w.Type == TemplateUpdateWebhookType ||
|
||||||
w.Type == TemplateDeleteWebhookType
|
w.Type == TemplateDeleteWebhookType
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MessageWebhookData returns the message data from webhook contents.
|
||||||
|
//
|
||||||
|
// Note: this call will not fail even if underlying data is not related to the messages.
|
||||||
|
// Use IsMessageWebhook to mitigate this.
|
||||||
func (w WebhookRequest) MessageWebhookData() (wd MessageWebhookData) {
|
func (w WebhookRequest) MessageWebhookData() (wd MessageWebhookData) {
|
||||||
_ = json.Unmarshal(w.Data, &wd)
|
_ = json.Unmarshal(w.Data, &wd)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TemplateCreateWebhookData returns new template data from webhook contents.
|
||||||
|
// This method is used if current webhook was initiated because user created a template.
|
||||||
|
//
|
||||||
|
// Note: this call will not fail even if underlying data is not related to the templates.
|
||||||
|
// Use IsTemplateWebhook or direct Type comparison (Type == TemplateCreateWebhookType) to mitigate this.
|
||||||
func (w WebhookRequest) TemplateCreateWebhookData() (wd TemplateCreateWebhookData) {
|
func (w WebhookRequest) TemplateCreateWebhookData() (wd TemplateCreateWebhookData) {
|
||||||
_ = json.Unmarshal(w.Data, &wd)
|
_ = json.Unmarshal(w.Data, &wd)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TemplateUpdateWebhookData returns existing template data from webhook contents.
|
||||||
|
// This method is used if current webhook was initiated because user updated a template.
|
||||||
|
//
|
||||||
|
// Note: this call will not fail even if underlying data is not related to the templates.
|
||||||
|
// Use IsTemplateWebhook or direct Type comparison (Type == TemplateUpdateWebhookData) to mitigate this.
|
||||||
func (w WebhookRequest) TemplateUpdateWebhookData() (wd TemplateUpdateWebhookData) {
|
func (w WebhookRequest) TemplateUpdateWebhookData() (wd TemplateUpdateWebhookData) {
|
||||||
_ = json.Unmarshal(w.Data, &wd)
|
_ = json.Unmarshal(w.Data, &wd)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TemplateDeleteWebhookData returns existing template data from webhook contents.
|
||||||
|
// This method is used if current webhook was initiated because user deleted a template.
|
||||||
|
//
|
||||||
|
// Note: this call will not fail even if underlying data is not related to the templates.
|
||||||
|
// Use IsTemplateWebhook or direct Type comparison (Type == TemplateDeleteWebhookType) to mitigate this.
|
||||||
func (w WebhookRequest) TemplateDeleteWebhookData() (wd TemplateDeleteWebhookData) {
|
func (w WebhookRequest) TemplateDeleteWebhookData() (wd TemplateDeleteWebhookData) {
|
||||||
_ = json.Unmarshal(w.Data, &wd)
|
_ = json.Unmarshal(w.Data, &wd)
|
||||||
return
|
return
|
||||||
|
Loading…
Reference in New Issue
Block a user