log101-dot-dev-services/main.go

81 lines
1.8 KiB
Go
Raw Normal View History

2024-05-17 16:01:33 +00:00
package main
import (
2024-05-28 19:19:30 +00:00
"database/sql"
"fmt"
"log"
2024-05-28 17:17:30 +00:00
"net/http"
2024-05-28 19:19:30 +00:00
"os"
"github.com/go-sql-driver/mysql"
2024-05-17 16:01:33 +00:00
2024-05-28 17:17:30 +00:00
"github.com/gin-contrib/cors"
"github.com/gin-gonic/gin"
2024-05-17 16:01:33 +00:00
)
2024-05-28 19:19:30 +00:00
var db *sql.DB
2024-05-17 16:01:33 +00:00
func main() {
2024-05-28 19:19:30 +00:00
cfg := mysql.Config{
User: os.Getenv("DBUSER"),
Passwd: os.Getenv("DBPASS"),
Net: "tcp",
Addr: "127.0.0.1:3306",
DBName: "emojis",
}
// Get a database handle.
var err error
db, err = sql.Open("mysql", cfg.FormatDSN())
if err != nil {
log.Fatal(err)
}
pingErr := db.Ping()
if pingErr != nil {
log.Fatal(pingErr)
}
fmt.Println("Connected!")
2024-05-28 17:17:30 +00:00
r := gin.Default()
r.LoadHTMLGlob("templates/*")
2024-05-17 16:01:33 +00:00
2024-05-28 17:17:30 +00:00
corsConfig := cors.DefaultConfig()
corsConfig.AllowOrigins = []string{"*"}
corsConfig.AllowHeaders = []string{"hx-current-url", "hx-request"}
r.Use(cors.New(corsConfig))
2024-05-17 16:01:33 +00:00
2024-05-28 17:17:30 +00:00
r.GET("/forms/emoji", func(c *gin.Context) {
2024-05-28 19:19:30 +00:00
c.HTML(http.StatusOK, "emoji_form.tmpl", gin.H{
"postId": c.Query("postId"),
})
2024-05-28 17:17:30 +00:00
})
2024-05-17 16:01:33 +00:00
2024-05-28 17:17:30 +00:00
r.POST("/forms/emoji/post", func(c *gin.Context) {
2024-05-28 19:19:30 +00:00
postID := c.PostForm("postId")
emoji := c.PostForm("emojiInput")
if postID == "" || emoji == "" {
c.HTML(http.StatusOK, "emoji_form.tmpl", gin.H{"error": "missing parameters", "postId": postID})
return
}
_, err := db.Exec("INSERT INTO emoji_clicks (post_id, emoji) VALUES (?, ?)", postID, emoji)
if err != nil {
c.HTML(http.StatusOK, "emoji_form.tmpl", gin.H{"error": "error writing to database", "postId": postID})
return
}
var totalCount int
err = db.QueryRow("SELECT COUNT(*) AS total_count FROM emoji_clicks WHERE post_id = ?;", postID).Scan(&totalCount)
if err != nil {
c.HTML(http.StatusOK, "emoji_form.tmpl", gin.H{"error": "error writing to database", "postId": postID})
return
}
c.HTML(http.StatusOK, "emoji_form.tmpl", gin.H{"postId": postID, "thumbsUpCount": totalCount})
2024-05-28 17:17:30 +00:00
})
2024-05-17 16:01:33 +00:00
2024-05-28 17:17:30 +00:00
r.Run(":8000")
2024-05-17 16:01:33 +00:00
}