201 lines
5.3 KiB
Go
201 lines
5.3 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"html/template"
|
|
"net/http"
|
|
)
|
|
|
|
type dashboard struct {
|
|
Services []Service
|
|
Users []User
|
|
Core *Core
|
|
}
|
|
|
|
func RunHTTPServer() {
|
|
fmt.Println("Fusioner HTTP Server running on http://localhost:8080")
|
|
css := http.StripPrefix("/css/", http.FileServer(cssBox.HTTPBox()))
|
|
js := http.StripPrefix("/js/", http.FileServer(jsBox.HTTPBox()))
|
|
http.Handle("/", http.HandlerFunc(IndexHandler))
|
|
http.Handle("/css/", css)
|
|
http.Handle("/js/", js)
|
|
http.Handle("/setup", http.HandlerFunc(SetupHandler))
|
|
http.Handle("/setup/save", http.HandlerFunc(ProcessSetupHandler))
|
|
http.Handle("/dashboard", http.HandlerFunc(DashboardHandler))
|
|
http.Handle("/login", http.HandlerFunc(LoginHandler))
|
|
http.Handle("/logout", http.HandlerFunc(LogoutHandler))
|
|
//http.Handle("/auth", http.HandlerFunc(AuthenticateHandler))
|
|
http.Handle("/user/create", http.HandlerFunc(CreateUserHandler))
|
|
http.Handle("/token/create", http.HandlerFunc(CreateServiceHandler))
|
|
http.Handle("/tokens", http.HandlerFunc(ServicesHandler))
|
|
http.Handle("/users", http.HandlerFunc(UsersHandler))
|
|
http.ListenAndServe(":8080", nil)
|
|
}
|
|
|
|
func LogoutHandler(w http.ResponseWriter, r *http.Request) {
|
|
session, _ := store.Get(r, "apizer_auth")
|
|
session.Values["authenticated"] = false
|
|
session.Save(r, w)
|
|
http.Redirect(w, r, "/", http.StatusSeeOther)
|
|
}
|
|
|
|
func LoginHandler(w http.ResponseWriter, r *http.Request) {
|
|
session, _ := store.Get(r, "apizer_auth")
|
|
r.ParseForm()
|
|
username := r.PostForm.Get("username")
|
|
password := r.PostForm.Get("password")
|
|
_, auth := AuthUser(username, password)
|
|
if auth {
|
|
session.Values["authenticated"] = true
|
|
session.Save(r, w)
|
|
http.Redirect(w, r, "/dashboard", http.StatusSeeOther)
|
|
} else {
|
|
w.WriteHeader(502)
|
|
w.Header().Set("Content-Type", "plain/text")
|
|
fmt.Fprintln(w, "bad")
|
|
}
|
|
}
|
|
|
|
//func AuthenticateHandler(w http.ResponseWriter, r *http.Request) {
|
|
// r.ParseForm()
|
|
// key := r.PostForm.Get("key")
|
|
// secret := r.PostForm.Get("secret")
|
|
// token := SelectToken(key, secret)
|
|
// if token.Id != 0 {
|
|
// go token.Hit(r)
|
|
// w.WriteHeader(200)
|
|
// w.Header().Set("Content-Type", "plain/text")
|
|
// fmt.Fprintln(w, token.Id)
|
|
// } else {
|
|
// w.WriteHeader(502)
|
|
// w.Header().Set("Content-Type", "plain/text")
|
|
// fmt.Fprintln(w, "bad")
|
|
// }
|
|
//}
|
|
|
|
func CreateUserHandler(w http.ResponseWriter, r *http.Request) {
|
|
r.ParseForm()
|
|
username := r.PostForm.Get("username")
|
|
password := r.PostForm.Get("password")
|
|
user := &User{
|
|
Username: username,
|
|
Password: password,
|
|
}
|
|
user.Create()
|
|
http.Redirect(w, r, "/users", http.StatusSeeOther)
|
|
}
|
|
|
|
func CreateServiceHandler(w http.ResponseWriter, r *http.Request) {
|
|
token := &Service{}
|
|
token.Create()
|
|
http.Redirect(w, r, "/services", http.StatusSeeOther)
|
|
}
|
|
|
|
func SetupHandler(w http.ResponseWriter, r *http.Request) {
|
|
setupFile, err := tmplBox.String("setup.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
setupTmpl, err := template.New("message").Parse(setupFile)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
setupTmpl.Execute(w, nil)
|
|
}
|
|
|
|
type index struct {
|
|
Services []Service
|
|
}
|
|
|
|
func IndexHandler(w http.ResponseWriter, r *http.Request) {
|
|
if core == nil {
|
|
http.Redirect(w, r, "/setup", http.StatusSeeOther)
|
|
return
|
|
}
|
|
|
|
indexFile, err := tmplBox.String("index.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
indexTmpl, err := template.New("message").Funcs(template.FuncMap{
|
|
"js": func(html string) template.JS {
|
|
return template.JS(html)
|
|
},
|
|
}).Parse(indexFile)
|
|
out := index{SelectAllServices()}
|
|
indexTmpl.Execute(w, out)
|
|
}
|
|
|
|
func DashboardHandler(w http.ResponseWriter, r *http.Request) {
|
|
//session, _ := store.Get(r, "apizer_auth")
|
|
//if auth, ok := session.Values["authenticated"].(bool); !ok || !auth {
|
|
// http.Redirect(w, r, "/", http.StatusSeeOther)
|
|
// return
|
|
//}
|
|
|
|
dashboardFile, err := tmplBox.String("dashboard.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
dashboardTmpl, err := template.New("message").Parse(dashboardFile)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
out := dashboard{SelectAllServices(), SelectAllUsers(), core}
|
|
|
|
dashboardTmpl.Execute(w, out)
|
|
}
|
|
|
|
func ServicesHandler(w http.ResponseWriter, r *http.Request) {
|
|
session, _ := store.Get(r, "apizer_auth")
|
|
if auth, ok := session.Values["authenticated"].(bool); !ok || !auth {
|
|
http.Redirect(w, r, "/", http.StatusSeeOther)
|
|
return
|
|
}
|
|
tokensFile, err := tmplBox.String("services.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
tokensTmpl, err := template.New("message").Parse(tokensFile)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
tokensTmpl.Execute(w, SelectAllServices())
|
|
}
|
|
|
|
func UsersHandler(w http.ResponseWriter, r *http.Request) {
|
|
session, _ := store.Get(r, "apizer_auth")
|
|
if auth, ok := session.Values["authenticated"].(bool); !ok || !auth {
|
|
http.Redirect(w, r, "/", http.StatusSeeOther)
|
|
return
|
|
}
|
|
usersFile, err := tmplBox.String("users.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
usersTmpl, err := template.New("message").Parse(usersFile)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
usersTmpl.Execute(w, SelectAllUsers())
|
|
}
|
|
|
|
func PermissionsHandler(w http.ResponseWriter, r *http.Request) {
|
|
session, _ := store.Get(r, "apizer_auth")
|
|
if auth, ok := session.Values["authenticated"].(bool); !ok || !auth {
|
|
http.Redirect(w, r, "/", http.StatusSeeOther)
|
|
return
|
|
}
|
|
permsFile, err := tmplBox.String("permissions.html")
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
permsTmpl, err := template.New("message").Parse(permsFile)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
permsTmpl.Execute(w, SelectAllUsers())
|
|
}
|