mirror of
https://git.klmp200.net/ALFRED/ALFRED.git
synced 2025-01-18 18:46:44 +01:00
Merge branch 'bro-features' of ALFRED/ALFRED into master
This commit is contained in:
commit
4ecc1e2072
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* @Author: Amalvy Arthur
|
* @Authors: Amalvy Arthur, Bartuccio Antoine
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// This module uses a property named "subscribed_chats" in the shared Users structure.
|
// This module uses a property named "subscribed_chats" in the shared Users structure.
|
||||||
@ -11,7 +11,7 @@
|
|||||||
package commands
|
package commands
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"encoding/json"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@ -19,13 +19,47 @@ import (
|
|||||||
tb "gopkg.in/tucnak/telebot.v2"
|
tb "gopkg.in/tucnak/telebot.v2"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func getPublishedMessages(chatID int64) []tb.Message {
|
||||||
|
messages := []tb.Message{}
|
||||||
|
|
||||||
|
serializedMessages, exists := shared.ChatData.Get(chatID, "published_messages")
|
||||||
|
if !exists {
|
||||||
|
return messages
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, ok := serializedMessages.(string); !ok {
|
||||||
|
return messages
|
||||||
|
}
|
||||||
|
|
||||||
|
if json.Unmarshal([]byte(serializedMessages.(string)), &messages) != nil {
|
||||||
|
return []tb.Message{}
|
||||||
|
}
|
||||||
|
|
||||||
|
return messages
|
||||||
|
}
|
||||||
|
|
||||||
|
func setPublishedMessages(chatID int64, messages []tb.Message) {
|
||||||
|
data, err := json.Marshal(messages)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
shared.ChatData.Set(chatID, "published_messages", string(data))
|
||||||
|
}
|
||||||
|
|
||||||
// Subscribe user sending the command to the current chat
|
// Subscribe user sending the command to the current chat
|
||||||
// Command syntax : /subscribe
|
// Command syntax : /subscribe
|
||||||
func Subscribe(m *tb.Message) {
|
func Subscribe(m *tb.Message) {
|
||||||
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
||||||
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if m.Sender.Username == "" {
|
||||||
|
shared.Bot.Send(m.Chat, "Il faut avoir enregistré un username pour pouvoir utiliser cette fonction")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
||||||
if !exists {
|
if !exists {
|
||||||
shared.Bot.Send(m.Chat, "Abonnement au chat : "+m.Chat.Title)
|
shared.Bot.Send(m.Chat, "Abonnement au chat : "+m.Chat.Title)
|
||||||
@ -51,9 +85,15 @@ func Subscribe(m *tb.Message) {
|
|||||||
// Command syntax : /unsubscribe
|
// Command syntax : /unsubscribe
|
||||||
func Unsubscribe(m *tb.Message) {
|
func Unsubscribe(m *tb.Message) {
|
||||||
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
||||||
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if m.Sender.Username == "" {
|
||||||
|
shared.Bot.Send(m.Chat, "Il faut avoir enregistré un username pour pouvoir utiliser cette fonction")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
||||||
if !exists || len(userSubscribedChats) == 0 {
|
if !exists || len(userSubscribedChats) == 0 {
|
||||||
shared.Bot.Send(m.Chat, "Vous n'êtes abonné à aucun chat")
|
shared.Bot.Send(m.Chat, "Vous n'êtes abonné à aucun chat")
|
||||||
@ -74,7 +114,7 @@ func Unsubscribe(m *tb.Message) {
|
|||||||
// Command syntax : /listsubscribers
|
// Command syntax : /listsubscribers
|
||||||
func ListSubscribers(m *tb.Message) {
|
func ListSubscribers(m *tb.Message) {
|
||||||
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
||||||
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
subscribers := m.Chat.Title + " subscribers : \n\n"
|
subscribers := m.Chat.Title + " subscribers : \n\n"
|
||||||
@ -85,52 +125,69 @@ func ListSubscribers(m *tb.Message) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Publish a message from the current chat
|
// Publish a message from the current chat
|
||||||
// Command syntax (while repying to a message) : /publish
|
// Command syntax (while replying to a message) : /publish
|
||||||
func Publish(m *tb.Message) {
|
func Publish(m *tb.Message) {
|
||||||
if m.ReplyTo == nil {
|
if m.ReplyTo == nil {
|
||||||
shared.Bot.Send(m.Chat, "Veuillez répondre à un message pour le publier")
|
shared.Bot.Send(m.Chat, "Veuillez répondre à un message pour le publier")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
defer shared.Bot.Send(m.Chat, "Message publié : "+m.ReplyTo.Text)
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
||||||
savedMessages, exists := shared.ChatData.Get(m.Chat.ID, "published_messages")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
if !exists {
|
|
||||||
messageList := []string{m.ReplyTo.Text}
|
|
||||||
shared.ChatData.Set(m.Chat.ID, "published_messages", messageList)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
shared.ChatData.Set(
|
|
||||||
m.Chat.ID,
|
defer shared.Bot.Send(m.Chat, "Message publié : "+m.ReplyTo.Text)
|
||||||
"published_messages",
|
savedMessages := getPublishedMessages(m.Chat.ID)
|
||||||
append(savedMessages.([]interface{}), m.ReplyTo.Text),
|
setPublishedMessages(m.Chat.ID, append(savedMessages, *m.ReplyTo))
|
||||||
)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Unpublish remove a message from published messages in the current chat
|
// Unpublish remove a message from published messages in the current chat
|
||||||
// Command syntax : /unpublish [publication ID]
|
// Command syntax (while replying to a message) : /unpublish
|
||||||
func Unpublish(m *tb.Message) {
|
func Unpublish(m *tb.Message) {
|
||||||
parsedCommand := strings.Split(m.Text, " ")
|
|
||||||
if len(parsedCommand) < 2 {
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup {
|
||||||
shared.Bot.Send(m.Chat, "syntaxe : /unpublish [publication ID]")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
index, err := strconv.Atoi(parsedCommand[1])
|
|
||||||
if err != nil {
|
if m.ReplyTo == nil {
|
||||||
shared.Bot.Send(m.Chat, "ID de publication invalide")
|
shared.Bot.Send(m.Chat, "Veuillez répondre à un message pour le dépublier")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
savedMessages, exists := shared.ChatData.Get(m.Chat.ID, "published_messages")
|
|
||||||
if !exists || len(savedMessages.([]interface{})) == 0 {
|
if !m.ReplyTo.IsForwarded() {
|
||||||
shared.Bot.Send(m.Chat, "Aucun message publié")
|
shared.Bot.Send(m.Chat, "Ce message ne peut pas avoir été publié")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if len(savedMessages.([]interface{})) <= index || index < 0 {
|
|
||||||
shared.Bot.Send(m.Chat, "Aucun message avec cet ID de publication n'existe")
|
publishedMessages := getPublishedMessages(m.Chat.ID)
|
||||||
|
filteredPublishedMessages := []tb.Message{}
|
||||||
|
found := false
|
||||||
|
for _, message := range publishedMessages {
|
||||||
|
// You can't just compare messages id because
|
||||||
|
// when retrieving, the newly send message
|
||||||
|
// has a different ID from the one stored so you can't detect that's
|
||||||
|
// it's in the database except if you find the original message
|
||||||
|
// which is very unlikely to happen
|
||||||
|
// As a workaround, we check the original sender, original unix time
|
||||||
|
// and associated text
|
||||||
|
if message.Sender.ID == m.ReplyTo.OriginalSender.ID &&
|
||||||
|
message.Unixtime == int64(m.ReplyTo.OriginalUnixtime) &&
|
||||||
|
message.Text == m.ReplyTo.Text {
|
||||||
|
found = true
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
filteredPublishedMessages = append(filteredPublishedMessages, message)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !found {
|
||||||
|
shared.Bot.Send(m.Chat, "Ce message n'a jamais été publié")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
savedMessages = append(savedMessages.([]interface{})[:index], savedMessages.([]interface{})[index+1:]...)
|
|
||||||
shared.ChatData.Set(m.Chat.ID, "published_messages", savedMessages)
|
setPublishedMessages(m.Chat.ID, filteredPublishedMessages)
|
||||||
shared.Bot.Send(m.Chat, "Message supprimé des publication")
|
shared.Bot.Send(m.Chat, "Message supprimé des publication")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -139,7 +196,7 @@ func Unpublish(m *tb.Message) {
|
|||||||
// Command syntax : /retrieve
|
// Command syntax : /retrieve
|
||||||
func Retrieve(m *tb.Message) {
|
func Retrieve(m *tb.Message) {
|
||||||
chatList := []int64{}
|
chatList := []int64{}
|
||||||
messageList := []string{}
|
hasMessage := false
|
||||||
|
|
||||||
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup && m.Chat.Type != tb.ChatPrivate {
|
if m.Chat.Type != tb.ChatGroup && m.Chat.Type != tb.ChatSuperGroup && m.Chat.Type != tb.ChatPrivate {
|
||||||
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
@ -167,25 +224,22 @@ func Retrieve(m *tb.Message) {
|
|||||||
chatList = append(chatList, m.Chat.ID)
|
chatList = append(chatList, m.Chat.ID)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, chatID := range chatList {
|
|
||||||
if savedMessages, exists := shared.ChatData.Get(chatID, "published_messages"); exists {
|
|
||||||
for _, message := range savedMessages.([]interface{}) {
|
|
||||||
if message, ok := message.(string); ok {
|
|
||||||
messageList = append(messageList, message)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(messageList) == 0 {
|
|
||||||
shared.Bot.Send(m.Chat, "Aucun message publié")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
for index, message := range messageList {
|
|
||||||
shared.Bot.Send(m.Chat, fmt.Sprintf("%d : %s", index, message))
|
for _, chatID := range chatList {
|
||||||
|
messages := getPublishedMessages(chatID)
|
||||||
|
if len(messages) > 0 {
|
||||||
|
hasMessage = true
|
||||||
}
|
}
|
||||||
|
for _, message := range messages {
|
||||||
|
shared.Bot.Forward(m.Chat, &message)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !hasMessage {
|
||||||
|
shared.Bot.Send(m.Chat, "Aucun message publié")
|
||||||
|
}
|
||||||
|
|
||||||
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -52,7 +52,9 @@ The publish module intend to be a "multi-pin" feature for chats, allowing users
|
|||||||
|
|
||||||
**Usage location** : Group chat only
|
**Usage location** : Group chat only
|
||||||
|
|
||||||
**Command syntax** : /unpublish [publication ID]
|
**usage conditions** : Reply to the message to unpublish
|
||||||
|
|
||||||
|
**Command syntax** : /unpublish
|
||||||
|
|
||||||
|
|
||||||
### Retrieve
|
### Retrieve
|
||||||
|
Loading…
Reference in New Issue
Block a user