Compare commits
2 Commits
57ae3cfb06
...
430127c0f1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
430127c0f1 | ||
|
|
9f2448dacf |
BIN
Portifolio
BIN
Portifolio
Binary file not shown.
26
main.go
26
main.go
@@ -6,6 +6,7 @@ import (
|
||||
"Portifolio/internal/shell"
|
||||
"bufio"
|
||||
"database/sql"
|
||||
"flag"
|
||||
"fmt"
|
||||
"log"
|
||||
"net/http"
|
||||
@@ -20,15 +21,29 @@ var db *sql.DB
|
||||
func corsMiddleware(next http.Handler) http.Handler {
|
||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||
log.Printf("Incoming request: %s %s from %s", r.Method, r.URL.Path, r.Header.Get("Origin"))
|
||||
|
||||
w.Header().Set("Access-Control-Allow-Origin", "http://localhost:8081")
|
||||
w.Header().Set("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE, OPTIONS")
|
||||
w.Header().Set("Access-Control-Allow-Headers", "Content-Type, Authorization")
|
||||
|
||||
if r.Method == http.MethodOptions {
|
||||
w.WriteHeader(http.StatusNoContent)
|
||||
return
|
||||
}
|
||||
|
||||
next.ServeHTTP(w, r)
|
||||
})
|
||||
}
|
||||
|
||||
func main() {
|
||||
// --- CLI flags ---
|
||||
port := flag.String("port", "8080", "Port to listen on")
|
||||
host := flag.String("host", "", "Host/IP to listen on (default: all interfaces)")
|
||||
flag.Parse()
|
||||
|
||||
addr := fmt.Sprintf("%s:%s", *host, *port)
|
||||
|
||||
// --- Database ---
|
||||
var err error
|
||||
db, err = sql.Open("sqlite3", "./app.db?_foreign_keys=on")
|
||||
if err != nil {
|
||||
@@ -43,11 +58,11 @@ func main() {
|
||||
database.InitDB(db)
|
||||
fmt.Println("Connected to SQLite database")
|
||||
|
||||
// --- Routes ---
|
||||
mux := http.NewServeMux()
|
||||
|
||||
mux.HandleFunc("/health", handlers.HealthHandler(db))
|
||||
|
||||
//Trades
|
||||
mux.HandleFunc("POST /trade/add", handlers.AddTradeHandler(db))
|
||||
mux.HandleFunc("GET /trade/list", handlers.GetTradeListHandler(db))
|
||||
mux.HandleFunc("GET /trade/search", handlers.GetTradeListHandler(db)) // new
|
||||
@@ -62,19 +77,16 @@ func main() {
|
||||
mux.HandleFunc("POST /company/S-O/add", handlers.GetCompaniesHandler(db)) // new
|
||||
mux.HandleFunc("GET /company/S-O/list", handlers.GetCompaniesHandler(db)) // new
|
||||
|
||||
// Currency
|
||||
mux.HandleFunc("GET /currency/list", handlers.GetCurrenciesHandler(db))
|
||||
mux.HandleFunc("POST /currency/add", handlers.AddCurrencyHandler(db))
|
||||
|
||||
// Revenue
|
||||
mux.HandleFunc("POST /add/revenue/entry", handlers.AddRevenueEntryHandler(db))
|
||||
mux.HandleFunc("POST /api/v1/revenue/add", handlers.AddRevenueEntryHandler(db))
|
||||
|
||||
//http.HandleFunc("GET /revenue/report", handlers.GetRevenueReportHandler(db))
|
||||
|
||||
fmt.Println("Server running on :8080")
|
||||
// --- Start server ---
|
||||
fmt.Printf("Server running on %s\n", addr)
|
||||
go func() {
|
||||
log.Fatal(http.ListenAndServe(":8080", corsMiddleware(mux)))
|
||||
log.Fatal(http.ListenAndServe(addr, corsMiddleware(mux)))
|
||||
}()
|
||||
|
||||
runShell(db)
|
||||
|
||||
Reference in New Issue
Block a user