2023-05-18 20:04:55 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"embed"
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"atri.dad/api"
|
2024-03-03 01:09:40 -07:00
|
|
|
"atri.dad/api/webhooks"
|
2023-05-18 20:04:55 -06:00
|
|
|
"atri.dad/lib"
|
|
|
|
"atri.dad/lib/pubsub"
|
|
|
|
"atri.dad/lib/pubsub/adapters"
|
|
|
|
"atri.dad/pages"
|
|
|
|
|
|
|
|
"github.com/joho/godotenv"
|
|
|
|
"github.com/labstack/echo/v4"
|
|
|
|
"github.com/labstack/echo/v4/middleware"
|
|
|
|
)
|
|
|
|
|
|
|
|
//go:embed public/*
|
|
|
|
var PublicFS embed.FS
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
// Load environment variables
|
|
|
|
godotenv.Load(".env")
|
|
|
|
|
|
|
|
// Initialize Redis client
|
2024-04-09 11:58:08 -06:00
|
|
|
redisClient, redisError := adapters.NewRedisClient()
|
2023-05-18 20:04:55 -06:00
|
|
|
|
|
|
|
// Initialize pubsub
|
|
|
|
var pubSub pubsub.PubSub
|
2024-04-09 11:58:08 -06:00
|
|
|
if redisError != nil {
|
|
|
|
lib.LogWarning.Printf("\n[PUBSUB/INIT] Failed to connect to Redis: %v\n", redisError)
|
2023-05-18 20:04:55 -06:00
|
|
|
lib.LogWarning.Printf("\n[PUBSUB/INIT] Falling back to LocalPubSub\n")
|
|
|
|
pubSub = &adapters.LocalPubSub{}
|
|
|
|
} else {
|
2024-04-09 12:04:28 -06:00
|
|
|
adapters.RedisClient = redisClient
|
2023-05-18 20:04:55 -06:00
|
|
|
pubSub = &adapters.RedisPubSub{
|
|
|
|
Client: adapters.RedisClient,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize Echo router
|
|
|
|
e := echo.New()
|
|
|
|
|
|
|
|
// Middleware
|
|
|
|
e.Use(middleware.Logger())
|
|
|
|
e.Use(middleware.Recover())
|
|
|
|
e.Pre(middleware.RemoveTrailingSlash())
|
|
|
|
e.Use(middleware.RequestID())
|
|
|
|
e.Use(middleware.Secure())
|
|
|
|
e.Use(middleware.GzipWithConfig(middleware.GzipConfig{
|
|
|
|
Level: 5,
|
|
|
|
}))
|
|
|
|
e.Use(middleware.RateLimiter(middleware.NewRateLimiterMemoryStore(50)))
|
|
|
|
|
|
|
|
// Static server
|
|
|
|
fs := http.FS(PublicFS)
|
2024-02-21 01:46:30 -07:00
|
|
|
e.GET("/public/*", echo.WrapHandler(http.FileServer(fs)))
|
2023-05-18 20:04:55 -06:00
|
|
|
|
|
|
|
// Page routes
|
|
|
|
e.GET("/", pages.Home)
|
|
|
|
e.GET("/projects", pages.Projects)
|
|
|
|
e.GET("/talks", pages.Talks)
|
2024-04-12 11:31:41 -06:00
|
|
|
e.GET("/testimonials", pages.Testimonials)
|
2023-05-18 20:04:55 -06:00
|
|
|
e.GET("/blog", pages.Blog)
|
|
|
|
e.GET("/post/:post", pages.Post)
|
2024-02-22 13:12:47 -07:00
|
|
|
e.GET("/tools", pages.Tools)
|
|
|
|
e.GET("/tools/resize", pages.Resize)
|
2024-03-27 14:52:28 -06:00
|
|
|
e.GET("/tools/ssedemo", pages.SSEDemo)
|
2023-05-18 20:04:55 -06:00
|
|
|
|
|
|
|
// API Routes:
|
|
|
|
apiGroup := e.Group("/api")
|
|
|
|
apiGroup.GET("/ping", api.Ping)
|
|
|
|
apiGroup.GET("/authed/ping", api.Authed)
|
|
|
|
apiGroup.POST("/pay", api.Pay)
|
2024-04-16 00:09:09 -06:00
|
|
|
apiGroup.GET("/rss", api.RSSFeedHandler)
|
2023-05-18 20:04:55 -06:00
|
|
|
apiGroup.GET("/post/copy", api.PostCopy)
|
|
|
|
|
|
|
|
apiGroup.GET("/sse", func(c echo.Context) error {
|
|
|
|
return api.SSE(c, pubSub)
|
|
|
|
})
|
|
|
|
|
2024-03-27 14:52:28 -06:00
|
|
|
apiGroup.POST("/tools/sendsse", func(c echo.Context) error {
|
2023-05-18 20:04:55 -06:00
|
|
|
return api.SSEDemoSend(c, pubSub)
|
|
|
|
})
|
|
|
|
|
2024-03-27 14:52:28 -06:00
|
|
|
apiGroup.POST("/tools/resize", api.ResizeHandler)
|
2023-05-18 20:04:55 -06:00
|
|
|
|
|
|
|
// Webhook Routes:
|
|
|
|
webhookGroup := e.Group("/webhook")
|
|
|
|
webhookGroup.POST("/clerk", webhooks.ClerkWebhookHandler)
|
|
|
|
|
|
|
|
// Parse command-line arguments for IP and port
|
|
|
|
ip := flag.String("ip", "", "IP address to bind the server to")
|
|
|
|
port := flag.String("port", "3000", "Port to bind the server to")
|
|
|
|
flag.Parse()
|
|
|
|
|
|
|
|
// Start server with HTTP/2 support
|
|
|
|
s := &http.Server{
|
|
|
|
Addr: fmt.Sprintf("%s:%s", *ip, *port),
|
|
|
|
Handler: e,
|
|
|
|
}
|
|
|
|
e.Logger.Fatal(e.StartServer(s))
|
2024-05-08 14:43:57 -06:00
|
|
|
lib.LogSuccess.Println("Server started on port", *port)
|
2023-05-18 20:04:55 -06:00
|
|
|
}
|