change to stupid.app interface
changed darkstormtech requests to url instead of query
This commit is contained in:
@@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
@@ -25,29 +26,17 @@ func setupStupid(keyPath, mongoStr string) error {
|
|||||||
log.Println("Issues connecting to mongo:", err)
|
log.Println("Issues connecting to mongo:", err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
swApp := &stupid.App{
|
swApp := NewDefaultApp("swassistant", client)
|
||||||
Logs: db.NewMongoTable(client.Database("swassistant").Collection("log")),
|
cdrApp := NewDefaultApp("cdr", client)
|
||||||
Crashes: db.NewMongoTable(client.Database("swassistant").Collection("crash")),
|
webApp := NewDarkstormtech(client)
|
||||||
}
|
stupid := stupid.NewStupidBackend(db.NewMongoTable(client.Database("stupid").Collection("keys")), func(app string) stupid.App {
|
||||||
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 {
|
switch app {
|
||||||
case "swassistant":
|
case "swassistant":
|
||||||
return swApp
|
return swApp
|
||||||
case "cdr":
|
case "cdr":
|
||||||
return cdrApp
|
return cdrApp
|
||||||
case "darkstormtech":
|
case "darkstormtech":
|
||||||
return websiteApp
|
return webApp
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
@@ -82,37 +71,69 @@ func setupStupid(keyPath, mongoStr string) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type page struct {
|
type defaultApp struct {
|
||||||
Page string
|
d *mongo.Database
|
||||||
Contents string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func websiteRequest(d mongo.Database, r *stupid.Request) bool {
|
func NewDefaultApp(name string, c *mongo.Client) *defaultApp {
|
||||||
if len(r.Path) > 0 {
|
return &defaultApp{
|
||||||
r.Resp.WriteHeader(http.StatusBadRequest)
|
d: c.Database(name),
|
||||||
return true
|
|
||||||
}
|
}
|
||||||
if pag, ok := r.Query["page"]; ok {
|
}
|
||||||
res := d.Collection("pages").FindOne(context.TODO(), bson.M{"page": pag})
|
|
||||||
|
func (d *defaultApp) Logs() db.Table {
|
||||||
|
return db.NewMongoTable(d.d.Collection("logs"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *defaultApp) Crashes() db.CrashTable {
|
||||||
|
return db.NewMongoTable(d.d.Collection("crashes"))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *defaultApp) Extension(*stupid.Request) bool {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
type darkstormtech struct {
|
||||||
|
*defaultApp
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewDarkstormtech(c *mongo.Client) *darkstormtech {
|
||||||
|
return &darkstormtech{
|
||||||
|
defaultApp: NewDefaultApp("darkstormtech", c),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (d *darkstormtech) Extension(r *stupid.Request) bool {
|
||||||
|
if len(r.Path) != 2 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if r.Path[0] != "page" {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
res := d.d.Collection("pages").FindOne(context.TODO(), bson.M{"page": r.Path[1]})
|
||||||
if res.Err() == mongo.ErrNoDocuments {
|
if res.Err() == mongo.ErrNoDocuments {
|
||||||
r.Resp.WriteHeader(http.StatusNotFound)
|
r.Resp.WriteHeader(http.StatusNotFound)
|
||||||
return true
|
return true
|
||||||
}
|
} else if res.Err() != nil {
|
||||||
var p page
|
log.Println("Error while finding darkstorm.tech page:", res.Err())
|
||||||
err := res.Decode(&p)
|
|
||||||
if err != nil {
|
|
||||||
r.Resp.WriteHeader(http.StatusInternalServerError)
|
r.Resp.WriteHeader(http.StatusInternalServerError)
|
||||||
log.Print("page decode:", err)
|
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
_, err = r.Resp.Write([]byte(p.Contents))
|
darkstormPage := struct {
|
||||||
|
Content string
|
||||||
|
}{}
|
||||||
|
err := res.Decode(&darkstormPage)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Println("Error while decoding darkstorm.tech page:", err)
|
||||||
|
r.Resp.WriteHeader(http.StatusInternalServerError)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
fmt.Println(darkstormPage)
|
||||||
|
_, err = r.Resp.Write([]byte(darkstormPage.Content))
|
||||||
|
if err != nil {
|
||||||
|
log.Println("Error while sending darkstorm.tech page:", err)
|
||||||
r.Resp.WriteHeader(http.StatusInternalServerError)
|
r.Resp.WriteHeader(http.StatusInternalServerError)
|
||||||
log.Print("content send:", err)
|
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
r.Resp.WriteHeader(http.StatusBadRequest)
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user