aboutsummaryrefslogtreecommitdiff
path: root/telegram/commands.go
diff options
context:
space:
mode:
Diffstat (limited to 'telegram/commands.go')
-rw-r--r--telegram/commands.go31
1 files changed, 31 insertions, 0 deletions
diff --git a/telegram/commands.go b/telegram/commands.go
index 58f4db3..17d212f 100644
--- a/telegram/commands.go
+++ b/telegram/commands.go
@@ -59,6 +59,7 @@ var chatCommands = map[string]command{
"s": command{"edited message", "edit your last message"},
"silent": command{"message", "send a message without sound"},
"schedule": command{"{online | 2006-01-02T15:04:05 | 15:04:05} message", "schedules a message either to timestamp or to whenever the user goes online"},
+ "forward": command{"message_id target_chat", "forwards a message"},
"add": command{"@username", "add @username to your chat list"},
"join": command{"https://t.me/invite_link", "join to chat via invite link"},
"group": command{"title", "create groupchat «title» with current user"},
@@ -575,6 +576,36 @@ func (c *Client) ProcessChatCommand(chatID int64, cmdline string) (string, bool)
} else {
return "Message processing error", true
}
+ // forward a message to chat
+ case "forward":
+ if len(args) < 2 {
+ return notEnoughArguments, true
+ }
+
+ messageId, err := strconv.ParseInt(args[0], 10, 64)
+ if err != nil {
+ return "Cannot parse message ID", true
+ }
+
+ targetChatParts := strings.Split(args[1], "@") // full JIDs are supported too
+ targetChatId, err := strconv.ParseInt(targetChatParts[0], 10, 64)
+ if err != nil {
+ return "Cannot parse target chat ID", true
+ }
+
+ messages, err := c.client.ForwardMessages(&client.ForwardMessagesRequest{
+ ChatId: targetChatId,
+ FromChatId: chatID,
+ MessageIds: []int64{messageId},
+ })
+ if err != nil {
+ return err.Error(), true
+ }
+ if messages != nil && messages.Messages != nil {
+ for _, message := range messages.Messages {
+ c.ProcessIncomingMessage(targetChatId, message)
+ }
+ }
// add @contact
case "add":
if len(args) < 1 {