bb44e26dd4
Fixed some minor bugs Added cors
119 lines
3.5 KiB
Go
119 lines
3.5 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"crypto/tls"
|
|
"flag"
|
|
"log"
|
|
"net/http"
|
|
"net/http/httputil"
|
|
"net/url"
|
|
"os"
|
|
"path"
|
|
"path/filepath"
|
|
"strings"
|
|
|
|
"github.com/CalebQ42/darkstorm-server/internal/backend"
|
|
"github.com/CalebQ42/darkstorm-server/internal/backend/db"
|
|
"github.com/CalebQ42/darkstorm-server/internal/blog"
|
|
"github.com/CalebQ42/darkstorm-server/internal/cdr"
|
|
"github.com/CalebQ42/darkstorm-server/internal/swassistant"
|
|
"go.mongodb.org/mongo-driver/mongo"
|
|
"go.mongodb.org/mongo-driver/mongo/options"
|
|
)
|
|
|
|
var (
|
|
mongoClient *mongo.Client
|
|
back *backend.Backend
|
|
blogApp *blog.BlogApp
|
|
webRoot *string
|
|
)
|
|
|
|
func main() {
|
|
mongoURL := flag.String("mongo", "", "Enables MongoDB usage for Darkstorm backend.")
|
|
webRoot = flag.String("web-root", "", "Sets root directory of web server.")
|
|
addr := flag.String("addr", ":443", "Set listen address. Defaults to \":443\"")
|
|
flag.Parse()
|
|
if flag.NArg() != 1 {
|
|
log.Fatal("You must specify key directory. ex: darkstorm-server /etc/web-keys")
|
|
}
|
|
if *mongoURL == "" || *webRoot == "" {
|
|
log.Fatal("SPECIFY MONGO AND WEB-ROOT OR I WILL DIE, OH NO, THEY'RE COMING FOR ME.... **DEATH NOISES**")
|
|
}
|
|
go func() {
|
|
log.Println("error redirecting http traffice:",
|
|
http.ListenAndServe(":80", http.RedirectHandler("https://darkstorm.tech", http.StatusPermanentRedirect)))
|
|
}()
|
|
mux := http.NewServeMux()
|
|
setupMongo(*mongoURL)
|
|
setupBackend(mux)
|
|
setupWebsite(mux)
|
|
serv := &http.Server{
|
|
Addr: *addr,
|
|
Handler: mux,
|
|
}
|
|
err := serv.ListenAndServeTLS(filepath.Join(flag.Arg(0), "cert.pem"), filepath.Join(flag.Arg(0), "key.pem"))
|
|
log.Println("webserver closed:", err)
|
|
}
|
|
|
|
func setupMongo(uri string) {
|
|
mongoCert, err := tls.LoadX509KeyPair(filepath.Join(flag.Arg(0), "mongo.pem"), filepath.Join(flag.Arg(0), "key.pem"))
|
|
if err != nil {
|
|
log.Fatal("error loading mongo keys:", err)
|
|
}
|
|
mongoClient, err = mongo.Connect(context.Background(), options.Client().ApplyURI(uri).SetTLSConfig(&tls.Config{
|
|
Certificates: []tls.Certificate{mongoCert},
|
|
}))
|
|
if err != nil {
|
|
log.Fatal("error connecting to mongo:", err)
|
|
}
|
|
}
|
|
|
|
func setupBackend(mux *http.ServeMux) {
|
|
blogApp = blog.NewBlogApp(back, mongoClient.Database("blog"))
|
|
swApp := swassistant.NewSWBackend(back, mongoClient.Database("swassistant"))
|
|
cdrApp := cdr.NewBackend(back, mongoClient.Database("cdr"))
|
|
var err error
|
|
back, err = backend.NewBackend(db.NewMongoTable[backend.ApiKey](
|
|
mongoClient.Database("darkstorm").Collection("keys")),
|
|
blogApp,
|
|
swApp,
|
|
cdrApp,
|
|
)
|
|
back.AddCorsAddress("darkstorm.tech")
|
|
if err != nil {
|
|
log.Fatal("error setting up backend:", err)
|
|
}
|
|
mux.Handle("api.darkstorm.tech/", back)
|
|
}
|
|
|
|
func setupWebsite(mux *http.ServeMux) {
|
|
url, _ := url.Parse("https://localhost:30000")
|
|
mux.Handle("rpg.darkstorm.tech/", httputil.NewSingleHostReverseProxy(url))
|
|
mux.HandleFunc("GET /files", filesRequest)
|
|
mux.HandleFunc("GET /portfolio", portfolioRequest)
|
|
mux.HandleFunc("/", mainHandle)
|
|
}
|
|
|
|
func mainHandle(w http.ResponseWriter, r *http.Request) {
|
|
path := strings.TrimPrefix(path.Clean(r.URL.Path), "/")
|
|
if path == "/" || path == "" {
|
|
latestBlogsHandle(w, r)
|
|
return
|
|
}
|
|
stat, err := os.Stat(filepath.Join(*webRoot, path))
|
|
if err == nil && !stat.IsDir() {
|
|
http.ServeFile(w, r, filepath.Join(*webRoot, path))
|
|
return
|
|
}
|
|
spl := strings.Split(path, "/")
|
|
if len(spl) > 1 {
|
|
stat, err = os.Stat(filepath.Join(*webRoot, spl[0]))
|
|
if err == nil && stat.IsDir() {
|
|
http.ServeFile(w, r, filepath.Join(*webRoot, spl[0], "index.html"))
|
|
return
|
|
}
|
|
}
|
|
blogHandle(w, r, path)
|
|
}
|