2024-09-25 18:05:04 -05:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2024-10-11 05:36:08 -05:00
|
|
|
"flag"
|
2024-09-25 18:05:04 -05:00
|
|
|
"fmt"
|
2024-09-26 01:11:22 -05:00
|
|
|
"log"
|
2024-09-25 18:05:04 -05:00
|
|
|
"net/http"
|
2024-09-26 01:11:22 -05:00
|
|
|
"github.com/gorilla/sessions"
|
2024-09-25 18:05:04 -05:00
|
|
|
)
|
|
|
|
|
2024-10-16 16:43:13 -05:00
|
|
|
const CANVAS_WIDTH = 1000
|
|
|
|
const CANVAS_HEIGHT = 1000
|
|
|
|
|
2024-09-26 01:11:22 -05:00
|
|
|
type Server struct {
|
2024-09-28 03:42:26 -05:00
|
|
|
// Registered user information
|
|
|
|
Users map[string]UserData
|
|
|
|
// Login sessions
|
2024-09-26 01:11:22 -05:00
|
|
|
Sessions *sessions.CookieStore
|
2024-09-25 19:05:33 -05:00
|
|
|
}
|
|
|
|
|
2024-11-13 18:29:40 -06:00
|
|
|
// Enable CORS for specific routes
|
|
|
|
func enableCORS(next http.Handler) http.Handler {
|
|
|
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
// Set the CORS headers to allow requests from your frontend
|
|
|
|
w.Header().Set("Access-Control-Allow-Origin", "http://127.0.0.1:8080") // Adjust if your frontend is on a different port
|
|
|
|
w.Header().Set("Access-Control-Allow-Methods", "POST, GET, OPTIONS")
|
|
|
|
w.Header().Set("Access-Control-Allow-Headers", "Content-Type")
|
|
|
|
|
|
|
|
// Handle preflight OPTIONS request
|
|
|
|
if r.Method == http.MethodOptions {
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process the actual request
|
|
|
|
next.ServeHTTP(w, r)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-09-26 01:11:22 -05:00
|
|
|
func main() {
|
2024-10-16 16:43:13 -05:00
|
|
|
// Grab command line arguments
|
2024-10-11 05:36:08 -05:00
|
|
|
ipFlag := flag.String("ip", "127.0.0.1", "IP address to receive traffic from")
|
|
|
|
portFlag := flag.String("port", "8080", "Port to receive traffic from")
|
|
|
|
flag.Parse()
|
|
|
|
address := *ipFlag
|
|
|
|
port := *portFlag
|
2024-11-13 18:29:40 -06:00
|
|
|
|
2024-09-26 01:11:22 -05:00
|
|
|
// Create server object
|
2024-09-27 14:37:49 -05:00
|
|
|
secret := []byte("super-secret-key")
|
2024-09-26 01:11:22 -05:00
|
|
|
server := Server{
|
|
|
|
Users: make(map[string]UserData),
|
|
|
|
Sessions: sessions.NewCookieStore(secret),
|
2024-09-25 19:05:33 -05:00
|
|
|
}
|
2024-10-16 16:43:13 -05:00
|
|
|
|
2024-09-25 18:05:04 -05:00
|
|
|
// Host static files
|
|
|
|
static_files := http.FileServer(http.Dir("static/"))
|
|
|
|
http.Handle("/", static_files)
|
2024-09-27 14:37:49 -05:00
|
|
|
// Redirect .html to clean URL
|
|
|
|
http.Handle("/register.html", http.RedirectHandler("/register", 301))
|
|
|
|
http.Handle("/login.html", http.RedirectHandler("/login", 301))
|
|
|
|
// Handle user authentication
|
|
|
|
http.HandleFunc("/register", server.handle_register)
|
|
|
|
http.HandleFunc("/login", server.handle_login)
|
|
|
|
http.HandleFunc("/logout", func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
server.handle_logout(w, r)
|
|
|
|
http.Redirect(w, r, "/", http.StatusFound)
|
|
|
|
})
|
2024-09-29 19:05:16 -05:00
|
|
|
http.HandleFunc("/secret", server.secret)
|
2024-10-23 16:44:49 -05:00
|
|
|
http.HandleFunc("/confirm-email", server.handle_confirmation)
|
2024-11-13 18:29:40 -06:00
|
|
|
|
|
|
|
// Apply CORS middleware to /savePixel handler
|
|
|
|
http.Handle("/savePixel", enableCORS(http.HandlerFunc(savePixelHandler)))
|
|
|
|
|
2024-09-25 18:05:04 -05:00
|
|
|
// Start web server at 127.0.0.1:8080
|
2024-10-11 05:36:08 -05:00
|
|
|
fmt.Printf("Listening to %s on port %s...\n", address, port)
|
|
|
|
err := http.ListenAndServe(address+":"+port, nil)
|
2024-09-25 18:05:04 -05:00
|
|
|
// Print any errors
|
2024-09-28 03:42:26 -05:00
|
|
|
if err != nil {
|
2024-09-26 01:11:22 -05:00
|
|
|
fmt.Println("Error starting server:")
|
2024-09-28 03:42:26 -05:00
|
|
|
log.Fatal(err)
|
2024-09-25 18:05:04 -05:00
|
|
|
}
|
|
|
|
}
|