mirror of
https://git.klmp200.net/ALFRED/ALFRED.git
synced 2025-01-18 10:36:44 +01:00
Merge branch 'bro-features' of ALFRED/ALFRED into master
This commit is contained in:
commit
a47c016c62
5
.gitignore
vendored
5
.gitignore
vendored
@ -11,10 +11,13 @@
|
|||||||
# Output of the go coverage tool, specifically when used with LiteIDE
|
# Output of the go coverage tool, specifically when used with LiteIDE
|
||||||
*.out
|
*.out
|
||||||
|
|
||||||
|
#swap files
|
||||||
|
*~
|
||||||
|
|
||||||
# Project-local glide cache, RE: https://github.com/Masterminds/glide/issues/736
|
# Project-local glide cache, RE: https://github.com/Masterminds/glide/issues/736
|
||||||
.glide/
|
.glide/
|
||||||
|
|
||||||
settings_custom.json
|
settings_custom.json
|
||||||
history.json
|
history.json
|
||||||
users.json
|
users.json
|
||||||
chat_data.json
|
chat_data.json
|
||||||
|
32
alfred.go
32
alfred.go
@ -19,19 +19,25 @@ import (
|
|||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
registeredCommands := map[string]func(*tb.Message){
|
registeredCommands := map[string]func(*tb.Message){
|
||||||
tb.OnText: commands.OnText,
|
tb.OnText: commands.OnText,
|
||||||
"/hello": commands.Hello,
|
"/hello": commands.Hello,
|
||||||
"/sponge": commands.Sponge,
|
"/sponge": commands.Sponge,
|
||||||
"/git": commands.Git,
|
"/git": commands.Git,
|
||||||
"/framapad": commands.Framapad,
|
"/framapad": commands.Framapad,
|
||||||
"/setgender": commands.SetGender,
|
"/setgender": commands.SetGender,
|
||||||
"/gender": commands.Gender,
|
"/gender": commands.Gender,
|
||||||
"/roll": commands.Dice,
|
"/roll": commands.Dice,
|
||||||
"/trump": commands.LastTrumpTweet,
|
"/trump": commands.LastTrumpTweet,
|
||||||
"/trends": commands.TwitterTrends,
|
"/trends": commands.TwitterTrends,
|
||||||
"/chaos": commands.TwitterSJW,
|
"/chaos": commands.TwitterSJW,
|
||||||
"/apero": commands.AperoTime,
|
"/apero": commands.AperoTime,
|
||||||
"/quote": commands.Quote,
|
"/quote": commands.Quote,
|
||||||
|
"/subscribe": commands.Subscribe,
|
||||||
|
"/unsubscribe": commands.Unsubscribe,
|
||||||
|
"/listsubscribers": commands.ListSubscribers,
|
||||||
|
"/publish": commands.Publish,
|
||||||
|
"/unpublish": commands.Unpublish,
|
||||||
|
"/retrieve": commands.Retrieve,
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := settings.LoadSettings("settings.json", "settings_custom.json"); err != nil {
|
if err := settings.LoadSettings("settings.json", "settings_custom.json"); err != nil {
|
||||||
|
187
commands/subscribe.go
Normal file
187
commands/subscribe.go
Normal file
@ -0,0 +1,187 @@
|
|||||||
|
/*
|
||||||
|
* @Author: Amalvy Arthur
|
||||||
|
*/
|
||||||
|
|
||||||
|
// This module uses a property named "subscribed_chats" in the shared Users structure.
|
||||||
|
// It consists of a list of chatID as a string, chatID are separated by ":" (unix PATH style)
|
||||||
|
|
||||||
|
// This module uses a property named "saved_messages" in the shared Chats structure
|
||||||
|
// It consists of a slice of string
|
||||||
|
|
||||||
|
package commands
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"../shared"
|
||||||
|
tb "gopkg.in/tucnak/telebot.v2"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Subscribe user sending the command to the current chat
|
||||||
|
// Command syntax : /subscribe
|
||||||
|
func Subscribe(m *tb.Message) {
|
||||||
|
if m.Chat.Type != "group" && m.Chat.Type != "supergroup" {
|
||||||
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
||||||
|
if !exists {
|
||||||
|
shared.Bot.Send(m.Chat, "Abonnement au chat : "+m.Chat.Title)
|
||||||
|
shared.Users.Set(m.Sender.Username, "subscribed_chats", strconv.FormatInt(m.Chat.ID, 10))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
splittedChats := strings.Split(userSubscribedChats, ":")
|
||||||
|
for _, chatID := range splittedChats {
|
||||||
|
if chatID == strconv.FormatInt(m.Chat.ID, 10) {
|
||||||
|
shared.Bot.Send(m.Chat, "Vous êtes déjà abonné à ce chat : "+m.Chat.Title)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, "Abonnement au chat : "+m.Chat.Title)
|
||||||
|
if len(userSubscribedChats) != 0 {
|
||||||
|
shared.Users.Set(m.Sender.Username, "subscribed_chats", userSubscribedChats+":"+strconv.FormatInt(m.Chat.ID, 10))
|
||||||
|
} else {
|
||||||
|
shared.Users.Set(m.Sender.Username, "subscribed_chats", strconv.FormatInt(m.Chat.ID, 10))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unsubscribe user sending the command from the current chat
|
||||||
|
// Command syntax : /unsubscribe
|
||||||
|
func Unsubscribe(m *tb.Message) {
|
||||||
|
if m.Chat.Type != "group" && m.Chat.Type != "supergroup" {
|
||||||
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
||||||
|
if !exists || len(userSubscribedChats) == 0 {
|
||||||
|
shared.Bot.Send(m.Chat, "Vous n'êtes abonné à aucun chat")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
splittedChats := strings.Split(userSubscribedChats, ":")
|
||||||
|
for i, chatID := range splittedChats {
|
||||||
|
if chatID == strconv.FormatInt(m.Chat.ID, 10) {
|
||||||
|
shared.Bot.Send(m.Chat, "désabonnement du chat : "+m.Chat.Title)
|
||||||
|
splittedChats = append(splittedChats[:i], splittedChats[i+1:]...)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
shared.Users.Set(m.Sender.Username, "subscribed_chats", strings.Join(splittedChats, ":"))
|
||||||
|
}
|
||||||
|
|
||||||
|
// ListSubscribers List all subscribers of the current chat
|
||||||
|
// Command syntax : /listsubscribers
|
||||||
|
func ListSubscribers(m *tb.Message) {
|
||||||
|
if m.Chat.Type != "group" && m.Chat.Type != "supergroup" {
|
||||||
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas authorisée pour ce type de chat")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
subscribers := m.Chat.Title + " subscribers : \n\n"
|
||||||
|
for _, subscriber := range getSubscribers(m.Chat.ID) {
|
||||||
|
subscribers = subscribers + "- " + subscriber + "\n"
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, subscribers)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Publish a message from the current chat
|
||||||
|
// Command syntax (while repying to a message) : /publish
|
||||||
|
func Publish(m *tb.Message) {
|
||||||
|
if m.ReplyTo == nil {
|
||||||
|
shared.Bot.Send(m.Chat, "Veuillez répondre à un message pour le publier")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
defer shared.Bot.Send(m.Chat, "Message publié : "+m.ReplyTo.Text)
|
||||||
|
savedMessages, exists := shared.ChatData.Get(m.Chat.ID, "published_messages")
|
||||||
|
if !exists {
|
||||||
|
messageList := []string{m.ReplyTo.Text}
|
||||||
|
shared.ChatData.Set(m.Chat.ID, "published_messages", messageList)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
shared.ChatData.Set(m.Chat.ID, "published_messages",
|
||||||
|
append(savedMessages.([]interface{}), m.ReplyTo.Text))
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unpublish remove a message from published messages in the current chat
|
||||||
|
// Command syntax : /unpublish [publication ID]
|
||||||
|
func Unpublish(m *tb.Message) {
|
||||||
|
parsedCommand := strings.Split(m.Text, " ")
|
||||||
|
if len(parsedCommand) < 2 {
|
||||||
|
shared.Bot.Send(m.Chat, "syntaxe : /unpublish [publication ID]")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
index, err := strconv.Atoi(parsedCommand[1])
|
||||||
|
if err != nil {
|
||||||
|
shared.Bot.Send(m.Chat, "ID de publication invalide")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
savedMessages, exists := shared.ChatData.Get(m.Chat.ID, "published_messages")
|
||||||
|
if !exists || len(savedMessages.([]interface{})) == 0 {
|
||||||
|
shared.Bot.Send(m.Chat, "Aucun message publié")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(savedMessages.([]interface{})) <= index || index < 0 {
|
||||||
|
shared.Bot.Send(m.Chat, "Aucun message avec cet ID de publication n'existe")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
savedMessages = append(savedMessages.([]interface{})[:index], savedMessages.([]interface{})[index+1:]...)
|
||||||
|
shared.ChatData.Set(m.Chat.ID, "published_messages", savedMessages)
|
||||||
|
shared.Bot.Send(m.Chat, "Message supprimé des publication")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Retrieve If performed in MP : retrieve all messages from all subscribed sources for the user
|
||||||
|
// If performed in Group Chat : retrieved all published messages for this chat
|
||||||
|
// Command syntax : /retrieve
|
||||||
|
func Retrieve(m *tb.Message) {
|
||||||
|
if m.Chat.Type == "group" || m.Chat.Type == "supergroup" {
|
||||||
|
savedMessages, exists := shared.ChatData.Get(m.Chat.ID, "published_messages")
|
||||||
|
fmt.Println(savedMessages)
|
||||||
|
if !exists || len(savedMessages.([]interface{})) == 0 {
|
||||||
|
shared.Bot.Send(m.Chat, "Aucun message publié")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
|
for index, message := range savedMessages.([]interface{}) {
|
||||||
|
shared.Bot.Send(m.Chat, strconv.Itoa(index)+" : "+message.(string))
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if m.Chat.Type == "private" {
|
||||||
|
userSubscribedChats, exists := shared.Users.Get(m.Sender.Username, "subscribed_chats")
|
||||||
|
if !exists || len(userSubscribedChats) == 0 {
|
||||||
|
shared.Bot.Send(m.Chat, "Aucun abonnement")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
for _, chat := range strings.Split(userSubscribedChats, ":") {
|
||||||
|
chatID, _ := strconv.ParseInt(chat, 10, 64)
|
||||||
|
savedMessages, _ := shared.ChatData.Get(chatID, "published_messages")
|
||||||
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
|
for index, message := range savedMessages.([]interface{}) {
|
||||||
|
shared.Bot.Send(m.Chat, strconv.Itoa(index)+" : "+message.(string))
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, "--- Messages publiés ---")
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
shared.Bot.Send(m.Chat, "Cette commande n'est pas autorisée pour ce type de chat")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get all users subscribed to the provided channel
|
||||||
|
func getSubscribers(chatID int64) []string {
|
||||||
|
var subscribers []string
|
||||||
|
for _, username := range shared.Users.GetUsernames() {
|
||||||
|
userSubscribedChats, exists := shared.Users.Get(username, "subscribed_chats")
|
||||||
|
if exists {
|
||||||
|
splittedChats := strings.Split(userSubscribedChats, ":")
|
||||||
|
for _, splittedChatID := range splittedChats {
|
||||||
|
if splittedChatID == strconv.FormatInt(chatID, 10) {
|
||||||
|
subscribers = append(subscribers, username)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return subscribers
|
||||||
|
}
|
65
doc/publish.md
Normal file
65
doc/publish.md
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
# Publish system overview
|
||||||
|
|
||||||
|
The publish module intend to be a "multi-pin" feature for chats, allowing users to retrieve importants messages in a crowded conversation.
|
||||||
|
|
||||||
|
## Commands
|
||||||
|
|
||||||
|
|
||||||
|
### Subscribe
|
||||||
|
|
||||||
|
**Description** : Subscribe to this group chat publications
|
||||||
|
|
||||||
|
**Usage location** : Group chat only
|
||||||
|
|
||||||
|
**Command syntax** : /subscribe
|
||||||
|
|
||||||
|
|
||||||
|
### Unsubscribe
|
||||||
|
|
||||||
|
**Description** : Unsubscribe [target chat member] from this group chat publications. If no member is provided, unsubscribe yourself.
|
||||||
|
|
||||||
|
**Usage location** : Group chat
|
||||||
|
|
||||||
|
**Command syntax** : /unsubscribe [target chat member]
|
||||||
|
|
||||||
|
*note* : parameter [target chat member] not implemented
|
||||||
|
|
||||||
|
|
||||||
|
### ListSubscribers
|
||||||
|
|
||||||
|
**Description** : List all subscribers of this group chat
|
||||||
|
|
||||||
|
**Usage location** : Group chat
|
||||||
|
|
||||||
|
**Command syntax** : /listsubscribers
|
||||||
|
|
||||||
|
|
||||||
|
### Publish
|
||||||
|
|
||||||
|
**Description** : Publish a message to Alfred for this group chat and sends this message via MP to every subscriber of the group chat. The message can then be retrieved using the *retrieve* command.
|
||||||
|
|
||||||
|
**Usage location** : Group chat only
|
||||||
|
|
||||||
|
**Usage conditions** : Reply to the message to publish
|
||||||
|
|
||||||
|
**Command syntax** : /publish
|
||||||
|
|
||||||
|
*note* : MP not implemented
|
||||||
|
|
||||||
|
### Unpublish
|
||||||
|
|
||||||
|
**Description** : Remove a published message from Alfred for this group chat
|
||||||
|
|
||||||
|
**Usage location** : Group chat only
|
||||||
|
|
||||||
|
**Command syntax** : /unpublish [publication ID]
|
||||||
|
|
||||||
|
|
||||||
|
### Retrieve
|
||||||
|
|
||||||
|
**Description** : if MP, retrieve all messages from subscribed sources for user, if Group Chat, retrieve all published messages for this chat
|
||||||
|
|
||||||
|
**Usage location** : Group Chat or MP
|
||||||
|
|
||||||
|
**Command syntax** : /retrieve
|
||||||
|
|
@ -61,6 +61,17 @@ func (u users) Set(username string, key, data string) {
|
|||||||
go uf.write()
|
go uf.write()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetUsernames all usernames stored in settings
|
||||||
|
func (u users) GetUsernames() []string {
|
||||||
|
u.mutex.Lock()
|
||||||
|
defer u.mutex.Unlock()
|
||||||
|
var usernames []string
|
||||||
|
for username, _ := range u.data {
|
||||||
|
usernames = append(usernames, username)
|
||||||
|
}
|
||||||
|
return usernames
|
||||||
|
}
|
||||||
|
|
||||||
func (u usersFile) read() {
|
func (u usersFile) read() {
|
||||||
u.mutex.Lock()
|
u.mutex.Lock()
|
||||||
defer u.mutex.Unlock()
|
defer u.mutex.Unlock()
|
||||||
|
Loading…
Reference in New Issue
Block a user