Organization for stupid-backend

This commit is contained in:
Caleb Gardner
2023-04-19 19:47:28 -05:00
parent 2cfa96d2e4
commit 4e79540051
3 changed files with 207 additions and 74 deletions
+2
View File
@@ -24,3 +24,5 @@ require (
golang.org/x/sys v0.5.0 // indirect golang.org/x/sys v0.5.0 // indirect
golang.org/x/text v0.7.0 // indirect golang.org/x/text v0.7.0 // indirect
) )
replace github.com/CalebQ42/stupid-backend => ../stupid-backend
+118
View File
@@ -0,0 +1,118 @@
package main
import (
"context"
"io"
"log"
"net/http"
"os"
"github.com/CalebQ42/stupid-backend"
"github.com/CalebQ42/stupid-backend/pkg/db"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
func setupStupid(keyPath, mongoStr string) error {
client, err := mongo.NewClient(options.Client().ApplyURI(mongoStr))
if err != nil {
log.Println("Issues connecting to mongo:", err)
return err
}
err = client.Connect(context.TODO())
if err != nil {
log.Println("Issues connecting to mongo:", err)
return err
}
swApp := &stupid.App{
Logs: db.NewMongoTable(client.Database("swassistant").Collection("log")),
Crashes: db.NewMongoTable(client.Database("swassistant").Collection("crash")),
}
cdrApp := &stupid.App{
Logs: db.NewMongoTable(client.Database("cdr").Collection("log")),
Crashes: db.NewMongoTable(client.Database("cdr").Collection("crash")),
}
websiteApp := &stupid.App{
Logs: db.NewMongoTable(client.Database("darkstormtech").Collection("log")),
Crashes: db.NewMongoTable(client.Database("darkstormtech").Collection("crash")),
Extension: func(r *stupid.Request) bool {
return websiteRequest(*client.Database("darkstormtech"), r)
},
}
stupid := stupid.NewStupidBackend(db.NewMongoTable(client.Database("stupid").Collection("keys")), func(app string) *stupid.App {
switch app {
case "swassistant":
return swApp
case "cdr":
return cdrApp
case "darkstormtech":
return websiteApp
}
return nil
})
users := true
var pub, priv []byte
stupidPubFil, err := os.Open(keyPath + "/stupid-pub.key")
if err != nil {
log.Println("Disabling API users:", err)
users = false
} else {
pub, err = io.ReadAll(stupidPubFil)
if err != nil {
log.Println("Disabling API users:", err)
users = false
}
}
stupidPrivFil, err := os.Open(keyPath + "/stupid-pub.key")
if err != nil {
log.Println("Disabling API users:", err)
users = false
} else {
priv, err = io.ReadAll(stupidPrivFil)
if err != nil {
log.Println("Disabling API users:", err)
users = false
}
}
if users {
stupid.EnableUserAuth(db.NewMongoTable(client.Database("stupid").Collection("keys")), pub, priv)
}
http.Handle("api.darkstorm.tech/", stupid)
return nil
}
type page struct {
Page string
Contents string
}
func websiteRequest(d mongo.Database, r *stupid.Request) bool {
if len(r.Path) > 0 {
r.Resp.WriteHeader(http.StatusBadRequest)
return true
}
if pag, ok := r.Query["page"]; ok {
res := d.Collection("pages").FindOne(context.TODO(), bson.M{"page": pag})
if res.Err() == mongo.ErrNoDocuments {
r.Resp.WriteHeader(http.StatusNotFound)
return true
}
var p page
err := res.Decode(&p)
if err != nil {
r.Resp.WriteHeader(http.StatusInternalServerError)
log.Print("page decode:", err)
return true
}
_, err = r.Resp.Write([]byte(p.Contents))
if err != nil {
r.Resp.WriteHeader(http.StatusInternalServerError)
log.Print("content send:", err)
return true
}
return true
}
r.Resp.WriteHeader(http.StatusBadRequest)
return true
}
+84 -71
View File
@@ -1,10 +1,9 @@
package main package main
import ( import (
"context"
"crypto/tls" "crypto/tls"
"flag" "flag"
"io" "fmt"
"log" "log"
"net/http" "net/http"
"net/http/httputil" "net/http/httputil"
@@ -12,11 +11,6 @@ import (
"os" "os"
"path" "path"
"strings" "strings"
"github.com/CalebQ42/stupid-backend"
"github.com/CalebQ42/stupid-backend/pkg/db"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
) )
func webserver(mongoStr string) { func webserver(mongoStr string) {
@@ -31,58 +25,13 @@ func webserver(mongoStr string) {
quitChan <- "web arg" quitChan <- "web arg"
return return
} }
var err error
if mongoStr != "" { if mongoStr != "" {
client, err := mongo.NewClient(options.Client().ApplyURI(mongoStr)) err = setupStupid(keyPath, mongoStr)
if err != nil { if err != nil {
log.Println("Issues connecting to mongo:", err)
quitChan <- "web err" quitChan <- "web err"
return return
} }
err = client.Connect(context.TODO())
if err != nil {
log.Println("Issues connecting to mongo:", err)
quitChan <- "web err"
return
}
stupid := stupid.NewStupidBackend(db.NewMongoTable(client.Database("stupid").Collection("keys")))
users := true
var pub, priv []byte
stupidPubFil, err := os.Open(keyPath + "/stupid-pub.key")
if err != nil {
log.Println("Disabling API users:", err)
users = false
} else {
pub, err = io.ReadAll(stupidPubFil)
if err != nil {
log.Println("Disabling API users:", err)
users = false
}
}
stupidPrivFil, err := os.Open(keyPath + "/stupid-pub.key")
if err != nil {
log.Println("Disabling API users:", err)
users = false
} else {
priv, err = io.ReadAll(stupidPrivFil)
if err != nil {
log.Println("Disabling API users:", err)
users = false
}
}
if users {
stupid.EnableUserAuth(db.NewMongoTable(client.Database("stupid").Collection("keys")), pub, priv)
}
stupid.SetApps(map[string]db.App{
"swassistant": {
Logs: db.NewMongoTable(client.Database("swassistant").Collection("log")),
Crashes: db.NewMongoTable(client.Database("swassistant").Collection("crash")),
},
"cdr": {
Logs: db.NewMongoTable(client.Database("cdr").Collection("log")),
Crashes: db.NewMongoTable(client.Database("cdr").Collection("crash")),
},
})
http.Handle("api.darkstorm.tech/", stupid)
} }
url, err := url.Parse("https://localhost:30000") url, err := url.Parse("https://localhost:30000")
if err != nil { if err != nil {
@@ -90,9 +39,17 @@ func webserver(mongoStr string) {
quitChan <- "web err" quitChan <- "web err"
return return
} }
http.Handle("/", http.FileServer(http.Dir(path))) // http.Handle("/", http.FileServer(http.Dir(path)))
http.Handle("/SWAssistant/", swaHandler{}) mainHandle := &fileOrIndexHandler{
http.Handle("/CDR/", cdrHandler{}) baseFolder: path,
appFolders: []string{
"SWAssistant",
"CDR",
},
}
http.Handle("/", mainHandle)
// http.Handle("/SWAssistant/", swaHandler{})
// http.Handle("/CDR/", cdrHandler{})
http.Handle("rpg.darkstorm.tech/", httputil.NewSingleHostReverseProxy(url)) http.Handle("rpg.darkstorm.tech/", httputil.NewSingleHostReverseProxy(url))
http.DefaultTransport.(*http.Transport).TLSClientConfig = &tls.Config{InsecureSkipVerify: true} http.DefaultTransport.(*http.Transport).TLSClientConfig = &tls.Config{InsecureSkipVerify: true}
err = http.ListenAndServeTLS(":443", keyPath+"/fullchain.pem", keyPath+"/key.pem", nil) err = http.ListenAndServeTLS(":443", keyPath+"/fullchain.pem", keyPath+"/key.pem", nil)
@@ -100,24 +57,80 @@ func webserver(mongoStr string) {
quitChan <- "web err" quitChan <- "web err"
} }
type swaHandler struct{} type fileOrIndexHandler struct {
baseFolder string
appFolders []string
}
func (swaHandler) ServeHTTP(writer http.ResponseWriter, req *http.Request) { func (f *fileOrIndexHandler) ServeHTTP(writer http.ResponseWriter, req *http.Request) {
if _, err := os.Open(path.Join(flag.Arg(0) + req.URL.EscapedPath())); strings.Contains(req.URL.EscapedPath(), "#") || err == nil { reqPath := strings.Split(strings.TrimPrefix(path.Clean(req.URL.Path), "/"), "/")
http.FileServer(http.Dir(flag.Arg(0))).ServeHTTP(writer, req) if len(reqPath) == 0 {
reqPath = []string{"index.html"}
}
fils, err := os.ReadDir(f.baseFolder)
if err != nil {
if os.IsNotExist(err) {
writer.WriteHeader(http.StatusNotFound)
} else { } else {
http.Redirect(writer, req, "https://darkstorm.tech/SWAssistant/#"+strings.TrimPrefix(req.URL.EscapedPath(), "/SWAssistant"), http.StatusFound) log.Println("Error while ReadDir:", err)
// log.Println("https://darkstorm.tech/SWAssistant/#" + strings.TrimPrefix(req.URL.EscapedPath(), "/SWAssistant")) writer.WriteHeader(http.StatusInternalServerError)
} }
return
} }
filename := path.Clean(f.baseFolder)
type cdrHandler struct{} var found bool
outer:
func (cdrHandler) ServeHTTP(writer http.ResponseWriter, req *http.Request) { for pathI := 0; pathI < len(reqPath); pathI++ {
if _, err := os.Open(path.Join(flag.Arg(0) + req.URL.EscapedPath())); strings.Contains(req.URL.EscapedPath(), "#") || err == nil { found = false
http.FileServer(http.Dir(flag.Arg(0))).ServeHTTP(writer, req) for filI := range fils {
if strings.EqualFold(strings.ToLower(fils[filI].Name()), reqPath[pathI]) {
found = true
filename = path.Join(filename, fils[filI].Name())
if pathI == len(reqPath)-1 {
if fils[filI].IsDir() {
reqPath = append(reqPath, "index.html")
}
break
} else if !fils[filI].IsDir() {
break outer
} else { } else {
http.Redirect(writer, req, "https://darkstorm.tech/CDR/#"+strings.TrimPrefix(req.URL.EscapedPath(), "/CDR"), http.StatusFound) fils, err = os.ReadDir(filename)
// log.Println("https://darkstorm.tech/SWAssistant/#" + strings.TrimPrefix(req.URL.EscapedPath(), "/SWAssistant")) if err != nil {
log.Println("Error while ReadDir:", err)
writer.WriteHeader(http.StatusInternalServerError)
return
} }
} }
break
}
}
if !found {
break
}
}
if !found {
for _, a := range f.appFolders {
if strings.EqualFold(reqPath[0], a) {
http.ServeFile(writer, req, path.Join(f.baseFolder, a, "index.html"))
return
}
}
}
fil, err := os.Open(filename)
if err != nil {
writer.WriteHeader(http.StatusInternalServerError)
return
}
st, _ := fil.Stat()
if st.IsDir() {
var subFil *os.File
subFil, err = os.Open(path.Join(filename, "index.html"))
if os.IsNotExist(err) {
fmt.Println("file server for", filename)
http.FileServer(http.Dir(filename)).ServeHTTP(writer, req)
return
}
fil = subFil
}
http.ServeFile(writer, req, fil.Name())
}