continued form command

This commit is contained in:
2024-02-25 21:10:06 +01:00
parent e337901a0e
commit 998c8cf1c7
4 changed files with 151 additions and 53 deletions

View File

@@ -1,20 +1,24 @@
[ {
{ "form_id": "DO_NOT_USE_THE_SAME_ID_TWICE",
"label": "This is a simple textline", "title": "Demo form",
"is_paragraph": false, "form": [
"placeholder": "...and it is required!", {
"value": "", "label": "This is a simple textline",
"required": true, "is_paragraph": false,
"min_length": 0, "placeholder": "...and it is required!",
"max_length": 20 "value": "",
}, "required": true,
{ "min_length": 0,
"label": "This is a paragraph", "max_length": 20
"is_paragraph": true, },
"placeholder": "...and it is not required!", {
"value": "We already have some input here", "label": "This is a paragraph",
"required": false, "is_paragraph": true,
"min_length": 0, "placeholder": "...and it is not required!",
"max_length": 2000 "value": "We already have some input here",
} "required": false,
] "min_length": 0,
"max_length": 2000
}
]
}

View File

@@ -5,6 +5,7 @@ import (
"os" "os"
"github.com/bwmarrin/discordgo" "github.com/bwmarrin/discordgo"
"github.com/google/uuid"
) )
var fileData []byte var fileData []byte
@@ -49,12 +50,35 @@ var form_command Command = Command{
Name: "add", Name: "add",
Description: "Adds existing forms to this channel", Description: "Adds existing forms to this channel",
Options: []*discordgo.ApplicationCommandOption{ Options: []*discordgo.ApplicationCommandOption{
{
Type: discordgo.ApplicationCommandOptionChannel,
Name: "result_channel",
Description: "Where the form results should appear",
ChannelTypes: []discordgo.ChannelType{discordgo.ChannelTypeGuildText},
Required: true,
},
{ {
Type: discordgo.ApplicationCommandOptionString, Type: discordgo.ApplicationCommandOptionString,
Name: "type", Name: "type",
Description: "Which type of form you want to add", Description: "Which type of form you want to add",
Autocomplete: true, Autocomplete: true,
}, },
{
Type: discordgo.ApplicationCommandOptionString,
Name: "title",
Description: "The title the form should have",
},
{
Type: discordgo.ApplicationCommandOptionChannel,
Name: "accept_channel_id",
Description: "Channel for results that need to be accepted by a moderator before sending it to the result channel",
ChannelTypes: []discordgo.ChannelType{discordgo.ChannelTypeGuildText},
},
{
Type: discordgo.ApplicationCommandOptionBoolean,
Name: "mods_can_comment",
Description: "Moderators can open a new channel on the form result, which then pings the user who submitted it",
},
}, },
}, },
}, },
@@ -101,14 +125,16 @@ var form_command Command = Command{
}, },
}) })
case "add": case "add":
var title string var title, formID, overwriteTitle, acceptChannelID string
var optionValue string var modsCanComment bool
if len(i.ApplicationCommandData().Options[0].Options) == 0 { options := i.ApplicationCommandData().Options[0]
optionValue = "template_general"
if len(options.Options) <= 1 {
formID = "template_general"
} else { } else {
optionValue = i.ApplicationCommandData().Options[0].Options[0].StringValue() formID = options.Options[1].StringValue()
} }
switch optionValue { switch formID {
case "template_feedback": case "template_feedback":
title = "Submit Feedback" title = "Submit Feedback"
case "template_ticket": case "template_ticket":
@@ -118,7 +144,26 @@ var form_command Command = Command{
case "template_general": case "template_general":
title = "Form" title = "Form"
} }
s.ChannelMessageSendComplex(i.ChannelID, &discordgo.MessageSend{
var exists bool = true
formManageID := uuid.New()
for exists {
formManageID = uuid.New()
exists = getFormManageIdExists(i.GuildID, formManageID)
}
if !(len(options.Options) <= 2) {
overwriteTitle = options.Options[2].StringValue()
title = overwriteTitle
}
if !(len(options.Options) <= 3) {
acceptChannelID = options.Options[3].ChannelValue(s).ID
}
if !(len(options.Options) <= 4) {
modsCanComment = options.Options[4].BoolValue()
}
message, _ := s.ChannelMessageSendComplex(i.ChannelID, &discordgo.MessageSend{
Embed: &discordgo.MessageEmbed{ Embed: &discordgo.MessageEmbed{
Color: hexToDecimal(color["primary"]), Color: hexToDecimal(color["primary"]),
Title: title, Title: title,
@@ -128,7 +173,8 @@ var form_command Command = Command{
discordgo.ActionsRow{ discordgo.ActionsRow{
Components: []discordgo.MessageComponent{ Components: []discordgo.MessageComponent{
discordgo.Button{ discordgo.Button{
CustomID: "form:", //add formID CustomID: "form:" + formManageID.String(),
Style: discordgo.SuccessButton,
Label: "Submit", Label: "Submit",
Emoji: discordgo.ComponentEmoji{ Emoji: discordgo.ComponentEmoji{
Name: "📥", Name: "📥",
@@ -138,6 +184,7 @@ var form_command Command = Command{
}, },
}, },
}) })
addFormButton(i.GuildID, i.ChannelID, message.ID, formManageID.String(), formID, options.Options[0].ChannelValue(s).ID, overwriteTitle, acceptChannelID, modsCanComment)
s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{ s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{
Type: discordgo.InteractionResponseChannelMessageWithSource, Type: discordgo.InteractionResponseChannelMessageWithSource,
Data: &discordgo.InteractionResponseData{ Data: &discordgo.InteractionResponseData{
@@ -147,7 +194,7 @@ var form_command Command = Command{
}) })
} }
}, },
ComponentIDs: getFormIDs(), ComponentIDs: getFormButtonIDs(),
ComponentInteract: func(s *discordgo.Session, i *discordgo.InteractionCreate) { ComponentInteract: func(s *discordgo.Session, i *discordgo.InteractionCreate) {
if i.Interaction.MessageComponentData().CustomID == "form_demo" { if i.Interaction.MessageComponentData().CustomID == "form_demo" {
s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{ s.InteractionRespond(i.Interaction, &discordgo.InteractionResponse{
@@ -228,6 +275,15 @@ var form_command Command = Command{
} }
func getFormIDs() []string { func getFormIDs() []string {
//needs databank support //needs custom IDs from databank
return []string{"form_demo"} return []string{"form_demo", "template_feedback", "template_ticket", "template_url", "template_general"}
}
func getFormButtonIDs() []string {
var IDs []string = []string{"form_demo"}
var formButtonIDs []string = getFormManageIDs()
for _, buttonID := range formButtonIDs {
IDs = append(IDs, "form:"+buttonID)
}
return IDs
} }

15
main.go
View File

@@ -25,12 +25,7 @@ func main() {
godotenv.Load() godotenv.Load()
var err error var err error
connStr := "postgresql://" + os.Getenv("DB_USER") + ":" + url.QueryEscape(os.Getenv("DB_PASSWORD")) + "@" + os.Getenv("DB_SERVER") + ":" + string(os.Getenv("DB_PORT")) + "/" + os.Getenv("DB_NAME") + "?sslmode=disable"
db, err = sql.Open("postgres", connStr)
if err != nil {
log.Fatal(err)
}
initTables()
discord, err := discordgo.New("Bot " + os.Getenv("BOT_TOKEN")) discord, err := discordgo.New("Bot " + os.Getenv("BOT_TOKEN"))
if err != nil { if err != nil {
fmt.Println("error creating Discord session,", err) fmt.Println("error creating Discord session,", err)
@@ -47,7 +42,13 @@ func main() {
fmt.Println("error opening connection,", err) fmt.Println("error opening connection,", err)
return return
} }
fmt.Printf("Bot is now running as \"%s\"!", discord.State.User.Username) connStr := "postgresql://" + os.Getenv("DB_USER") + ":" + url.QueryEscape(os.Getenv("DB_PASSWORD")) + "@" + os.Getenv("DB_SERVER") + ":" + string(os.Getenv("DB_PORT")) + "/" + os.Getenv("DB_NAME") + "?sslmode=disable&application_name=" + discord.State.User.Username
db, err = sql.Open("postgres", connStr)
if err != nil {
log.Fatal(err)
}
initTables()
fmt.Printf("\nBot is now running as \"%s\"!", discord.State.User.Username)
sc := make(chan os.Signal, 1) sc := make(chan os.Signal, 1)
signal.Notify(sc, syscall.SIGINT, syscall.SIGTERM, os.Interrupt) signal.Notify(sc, syscall.SIGINT, syscall.SIGTERM, os.Interrupt)
<-sc <-sc

View File

@@ -21,22 +21,23 @@ func initTables() {
guild_id TEXT NOT NULL, guild_id TEXT NOT NULL,
PRIMARY KEY (channel_id, guild_id) PRIMARY KEY (channel_id, guild_id)
); );
CREATE TABLE IF NOT EXISTS forms ( CREATE TABLE IF NOT EXISTS custom_forms (
form_id TEXT NOT NULL, form_id TEXT NOT NULL,
title TEXT NOT NULL, title TEXT NOT NULL,
json TEXT NOT NULL, json JSON NOT NULL,
guild_id TEXT NOT NULL, guild_id TEXT NOT NULL,
PRIMARY KEY (form_id, guild_id) PRIMARY KEY (form_id, guild_id)
); );
CREATE TABLE IF NOT EXISTS formbuttons ( CREATE TABLE IF NOT EXISTS form_buttons (
form_manage_id TEXT NOT NULL, form_manage_id TEXT NOT NULL,
form_id TEXT NOT NULL, form_id TEXT NOT NULL,
overwrite_title TEXT NOT NULL, overwrite_title TEXT,
message_id TEXT NOT NULL, message_id TEXT NOT NULL,
channel_id TEXT NOT NULL, channel_id TEXT NOT NULL,
guild_id TEXT NOT NULL, guild_id TEXT NOT NULL,
result_channel_id TEXT NOT NULL, result_channel_id TEXT NOT NULL,
accept_channel_id TEXT NOT NULL, accept_channel_id TEXT,
mods_can_comment BOOL,
PRIMARY KEY (form_manage_id, form_id) PRIMARY KEY (form_manage_id, form_id)
); );
` `
@@ -48,21 +49,17 @@ func initTables() {
} }
func addTag(guildID, tagName, tagContent string) bool { func addTag(guildID, tagName, tagContent string) bool {
var exists bool var exists bool = true
//TODO: add modify command
id := uuid.New() id := uuid.New()
err := db.QueryRow("SELECT EXISTS (SELECT 1 FROM tags WHERE guild_id = $1 AND tag_id = $2)", guildID, id).Scan(&exists)
if err != nil {
log.Println(err)
}
// TODO: add modify command
for exists { for exists {
id = uuid.New() id = uuid.New()
err = db.QueryRow("SELECT EXISTS (SELECT 1 FROM tags WHERE guild_id = $1 AND tag_id = $2)", guildID, id).Scan(&exists) err := db.QueryRow("SELECT EXISTS (SELECT 1 FROM tags WHERE guild_id = $1 AND tag_id = $2)", guildID, id).Scan(&exists)
if err != nil { if err != nil {
log.Println(err) log.Println(err)
} }
} }
_, err = db.Exec("INSERT INTO tags (guild_id, tag_name, tag_content, tag_id) VALUES ($1, $2, $3, $4)", guildID, tagName, tagContent, id) _, err := db.Exec("INSERT INTO tags (guild_id, tag_name, tag_content, tag_id) VALUES ($1, $2, $3, $4)", guildID, tagName, tagContent, id)
if err != nil { if err != nil {
log.Println(err) log.Println(err)
} }
@@ -180,6 +177,46 @@ func removeSticky(guildID string, channelID string) {
} }
} }
func addTemplateForm(guildID string, channelID string, formID string, overwriteChannelID string, resultChannelID string, acceptChannelID string) { func getFormManageIdExists(guildID string, id uuid.UUID) bool {
var exists bool
err := db.QueryRow("SELECT EXISTS (SELECT 1 FROM form_buttons WHERE guild_id = $1 AND form_manage_id = $2)", guildID, id).Scan(&exists)
if err != nil {
log.Println(err)
}
return exists
}
func addFormButton(guildID string, channelID string, messageID string, formManageID string, formID string, resultChannelID string, overwriteTitle string, acceptChannelID string, modsCanComment bool) {
_, err := db.Exec("INSERT INTO form_buttons (guild_id, form_manage_id, channel_id, message_id, form_id, result_channel_id, overwrite_title, accept_channel_id, mods_can_comment) VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9)", guildID, formManageID, channelID, messageID, formID, resultChannelID, overwriteTitle, acceptChannelID, modsCanComment)
if err != nil {
log.Println(err)
}
}
func getFormManageIDs() []string {
if db == nil {
return nil
}
var IDs []string
rows, err := db.Query("SELECT form_manage_id FROM form_buttons")
if err != nil {
log.Println(err)
return nil
}
defer rows.Close()
for rows.Next() {
var id string
if err := rows.Scan(&id); err != nil {
log.Println(err)
return nil
}
IDs = append(IDs, id)
}
if err := rows.Err(); err != nil {
log.Println(err)
return nil
}
return IDs
} }