+ call request
Some checks failed
ci/woodpecker/push/billing_fees Pipeline was successful
ci/woodpecker/push/bff Pipeline was successful
ci/woodpecker/push/db Pipeline was successful
ci/woodpecker/push/chain_gateway Pipeline was successful
ci/woodpecker/push/frontend Pipeline was successful
ci/woodpecker/push/fx_oracle Pipeline was successful
ci/woodpecker/push/fx_ingestor Pipeline was successful
ci/woodpecker/push/bump_version Pipeline failed
ci/woodpecker/push/nats Pipeline was successful
ci/woodpecker/push/ledger Pipeline was successful
ci/woodpecker/push/notification Pipeline was successful
ci/woodpecker/push/payments_orchestrator Pipeline was successful
Some checks failed
ci/woodpecker/push/billing_fees Pipeline was successful
ci/woodpecker/push/bff Pipeline was successful
ci/woodpecker/push/db Pipeline was successful
ci/woodpecker/push/chain_gateway Pipeline was successful
ci/woodpecker/push/frontend Pipeline was successful
ci/woodpecker/push/fx_oracle Pipeline was successful
ci/woodpecker/push/fx_ingestor Pipeline was successful
ci/woodpecker/push/bump_version Pipeline failed
ci/woodpecker/push/nats Pipeline was successful
ci/woodpecker/push/ledger Pipeline was successful
ci/woodpecker/push/notification Pipeline was successful
ci/woodpecker/push/payments_orchestrator Pipeline was successful
This commit is contained in:
@@ -80,7 +80,7 @@ func CreateAPI(a api.API) (*NotificationAPI, error) {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
if err := a.Register().Consumer(snotifications.NewSiteRequestProcessor(p.logger, p.onDemoRequest, p.onContactRequest)); err != nil {
|
||||
if err := a.Register().Consumer(snotifications.NewSiteRequestProcessor(p.logger, p.onDemoRequest, p.onContactRequest, p.onCallRequest)); err != nil {
|
||||
p.logger.Error("Failed to register site request handler", zap.Error(err))
|
||||
return nil, err
|
||||
}
|
||||
@@ -111,3 +111,15 @@ func (a *NotificationAPI) onContactRequest(ctx context.Context, request *model.C
|
||||
a.logger.Info("Contact request sent via Telegram", zap.String("name", request.Name), zap.String("topic", request.Topic))
|
||||
return nil
|
||||
}
|
||||
|
||||
func (a *NotificationAPI) onCallRequest(ctx context.Context, request *model.CallRequest) error {
|
||||
if a.tg == nil {
|
||||
return merrors.Internal("telegram client is not configured")
|
||||
}
|
||||
if err := a.tg.SendCallRequest(ctx, request); err != nil {
|
||||
a.logger.Warn("Failed to send call request via telegram", zap.Error(err))
|
||||
return err
|
||||
}
|
||||
a.logger.Info("Call request sent via Telegram", zap.String("phone", request.Phone))
|
||||
return nil
|
||||
}
|
||||
|
||||
@@ -0,0 +1,18 @@
|
||||
package telegram
|
||||
|
||||
import "github.com/tech/sendico/pkg/model"
|
||||
|
||||
func newCallRequestTemplate(request *model.CallRequest) messageTemplate {
|
||||
return messageTemplate{
|
||||
title: "New call request received",
|
||||
emphasize: []string{"call request"},
|
||||
fields: []messageField{
|
||||
{label: "Name", value: request.Name},
|
||||
{label: "Phone", value: request.Phone},
|
||||
{label: "Email", value: request.Email},
|
||||
{label: "Company", value: request.Company},
|
||||
{label: "Preferred time", value: request.PreferredTime},
|
||||
{label: "Message", value: request.Message},
|
||||
},
|
||||
}
|
||||
}
|
||||
@@ -24,6 +24,7 @@ const defaultAPIURL = "https://api.telegram.org"
|
||||
type Client interface {
|
||||
SendDemoRequest(ctx context.Context, request *model.DemoRequest) error
|
||||
SendContactRequest(ctx context.Context, request *model.ContactRequest) error
|
||||
SendCallRequest(ctx context.Context, request *model.CallRequest) error
|
||||
}
|
||||
|
||||
type client struct {
|
||||
@@ -161,6 +162,13 @@ func (c *client) SendContactRequest(ctx context.Context, request *model.ContactR
|
||||
return c.sendForm(ctx, newContactRequestTemplate(request))
|
||||
}
|
||||
|
||||
func (c *client) SendCallRequest(ctx context.Context, request *model.CallRequest) error {
|
||||
if request == nil {
|
||||
return merrors.InvalidArgument("call request payload is nil", "request")
|
||||
}
|
||||
return c.sendForm(ctx, newCallRequestTemplate(request))
|
||||
}
|
||||
|
||||
func (c *client) sendForm(ctx context.Context, template messageTemplate) error {
|
||||
message := template.Format(c.parseMode)
|
||||
payload := sendMessagePayload{
|
||||
|
||||
@@ -10,8 +10,8 @@ type parseMode string
|
||||
|
||||
const (
|
||||
parseModeUnset parseMode = ""
|
||||
parseModeMarkdown parseMode = "markdown"
|
||||
parseModeMarkdownV2 parseMode = "markdownV2"
|
||||
parseModeMarkdown parseMode = "Markdown"
|
||||
parseModeMarkdownV2 parseMode = "MarkdownV2"
|
||||
parseModeHTML parseMode = "HTML"
|
||||
)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user