Added the authentication interface and associated struct to better organise / escapsulate the authentication logic. Added the LogError function. We'll put together a custom logger at some point which will supersede this. Reorganised things a little. Moved two queries into the query generator and inlined four with the query builder. Added SimpleInsertLeftJoin to the query generator. Added SimpleInsertSelect, SimpleInsertLeftJoin, and SimpleInsertInnerJoin to the query builder. Removed the undocumented password reset mechanism for security reasons. We have a proper interface for this in the control panel. Made one of the template compiler errors less cryptic. Fixed the CSS on widget_simple. Fixed a glitch in the weak password detector regarding unique character detection. Moved the responsive CSS in media.partial.css for Tempra Conflux, and Tempra Simple. Added the CreateUser method to the UserStore. Users are no longer logged out on all devices when logging out. Took the first step towards SEO URLs.
194 lines
5.7 KiB
Go
194 lines
5.7 KiB
Go
package main
|
|
import "fmt"
|
|
import "log"
|
|
import "bytes"
|
|
import "net/http"
|
|
|
|
var error_internal []byte
|
|
var error_notfound []byte
|
|
func init_errors() error {
|
|
var b bytes.Buffer
|
|
user := User{0,"Guest","",0,false,false,false,false,false,false,GuestPerms,"",false,"","","","","",0,0,"0.0.0.0.0"}
|
|
pi := Page{"Internal Server Error",user,hvars,tList,"A problem has occurred in the system."}
|
|
err := templates.ExecuteTemplate(&b,"error.html", pi)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
error_internal = b.Bytes()
|
|
|
|
b.Reset()
|
|
pi = Page{"Not Found",user,hvars,tList,"The requested page doesn't exist."}
|
|
err = templates.ExecuteTemplate(&b,"error.html", pi)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
error_notfound = b.Bytes()
|
|
return nil
|
|
}
|
|
|
|
func LogError(err error) {
|
|
log.Fatal(err)
|
|
}
|
|
|
|
func InternalError(err error, w http.ResponseWriter, r *http.Request) {
|
|
w.Write(error_internal)
|
|
log.Fatal(err)
|
|
}
|
|
|
|
func InternalErrorJSQ(err error, w http.ResponseWriter, r *http.Request, is_js string) {
|
|
w.WriteHeader(500)
|
|
if is_js == "0" {
|
|
w.Write(error_internal)
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"A problem has occured in the system."}`))
|
|
}
|
|
log.Fatal(err)
|
|
}
|
|
|
|
func InternalErrorJS(err error, w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(500)
|
|
w.Write([]byte(`{"errmsg":"A problem has occured in the system."}`))
|
|
log.Fatal(err)
|
|
}
|
|
|
|
func PreError(errmsg string, w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(500)
|
|
user := User{ID:0,Group:6,Perms:GuestPerms,}
|
|
pi := Page{"Error",user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html",pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func LocalError(errmsg string, w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(500)
|
|
pi := Page{"Local Error",user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html",pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func LoginRequired(w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(401)
|
|
pi := Page{"Local Error",user,hvars,tList,"You need to login to do that."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html",pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func PreErrorJSQ(errmsg string, w http.ResponseWriter, r *http.Request, is_js string) {
|
|
w.WriteHeader(500)
|
|
if is_js == "0" {
|
|
user := User{ID:0,Group:6,Perms:GuestPerms,}
|
|
pi := Page{"Local Error",user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"` + errmsg + `"}`))
|
|
}
|
|
}
|
|
|
|
func LocalErrorJSQ(errmsg string, w http.ResponseWriter, r *http.Request, user User, is_js string) {
|
|
w.WriteHeader(500)
|
|
if is_js == "0" {
|
|
pi := Page{"Local Error",user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"` + errmsg + `"}`))
|
|
}
|
|
}
|
|
|
|
func LocalErrorJS(errmsg string, w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(500)
|
|
w.Write([]byte(`{'errmsg': '` + errmsg + `'}`))
|
|
}
|
|
|
|
func NoPermissions(w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(403)
|
|
pi := Page{"Local Error",user,hvars,tList,"You don't have permission to do that."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
errpage := b.String()
|
|
fmt.Fprintln(w,errpage)
|
|
}
|
|
|
|
func NoPermissionsJSQ(w http.ResponseWriter, r *http.Request, user User, is_js string) {
|
|
w.WriteHeader(403)
|
|
if is_js == "0" {
|
|
pi := Page{"Local Error",user,hvars,tList,"You don't have permission to do that."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"You don't have permission to do that."}`))
|
|
}
|
|
}
|
|
|
|
func Banned(w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(403)
|
|
pi := Page{"Banned",user,hvars,tList,"You have been banned from this site."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func BannedJSQ(w http.ResponseWriter, r *http.Request, user User, is_js string) {
|
|
w.WriteHeader(403)
|
|
if is_js == "0" {
|
|
pi := Page{"Banned",user,hvars,tList,"You have been banned from this site."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"You have been banned from this site."}`))
|
|
}
|
|
}
|
|
|
|
func LoginRequiredJSQ(w http.ResponseWriter, r *http.Request, user User, is_js string) {
|
|
w.WriteHeader(401)
|
|
if is_js == "0" {
|
|
pi := Page{"Local Error",user,hvars,tList,"You need to login to do that."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"You need to login to do that."}`))
|
|
}
|
|
}
|
|
|
|
func SecurityError(w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(403)
|
|
pi := Page{"Security Error",user,hvars,tList,"There was a security issue with your request."}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func NotFound(w http.ResponseWriter, r *http.Request) {
|
|
w.WriteHeader(404)
|
|
w.Write(error_notfound)
|
|
}
|
|
|
|
func CustomError(errmsg string, errcode int, errtitle string, w http.ResponseWriter, r *http.Request, user User) {
|
|
w.WriteHeader(errcode)
|
|
pi := Page{errtitle,user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
}
|
|
|
|
func CustomErrorJSQ(errmsg string, errcode int, errtitle string, w http.ResponseWriter, r *http.Request, user User, is_js string) {
|
|
w.WriteHeader(errcode)
|
|
if is_js == "0" {
|
|
pi := Page{errtitle,user,hvars,tList,errmsg}
|
|
var b bytes.Buffer
|
|
templates.ExecuteTemplate(&b,"error.html", pi)
|
|
fmt.Fprintln(w,b.String())
|
|
} else {
|
|
w.Write([]byte(`{"errmsg":"` + errmsg + `"}`))
|
|
}
|
|
}
|