sum7/warehost
sum7
/
warehost
Archived
1
0
Fork 0
This repository has been archived on 2020-09-27. You can view files and clone it, but cannot push or open issues or pull requests.
warehost/system/api.go

126 lines
3.8 KiB
Go
Raw Normal View History

2016-08-13 11:03:03 +02:00
package system
import (
"encoding/json"
"net/http"
"github.com/astaxie/session"
"github.com/go-xorm/xorm"
"github.com/julienschmidt/httprouter"
libconfig "dev.sum7.de/sum7/warehost/config"
libapi "dev.sum7.de/sum7/warehost/lib/api"
2016-08-14 15:29:54 +02:00
log "dev.sum7.de/sum7/warehost/lib/log"
2016-08-13 11:03:03 +02:00
libpassword "dev.sum7.de/sum7/warehost/lib/password"
)
2016-08-14 18:29:25 +02:00
//MODULNAME to get global name for the modul
const MODULNAME = "system"
2016-08-13 11:03:03 +02:00
//API keep data in module global
type API struct {
config *libconfig.Config
sessions *session.Manager
dbconnection *xorm.Engine
2016-08-14 18:29:25 +02:00
log *log.ModulLog
2016-08-13 11:03:03 +02:00
}
// NewAPI sets the routes to the api functions
func NewAPI(config *libconfig.Config, sessions *session.Manager, dbconnection *xorm.Engine, router *httprouter.Router, prefix string) {
2016-08-14 18:29:25 +02:00
api := &API{
config: config,
sessions: sessions,
dbconnection: dbconnection,
log: log.NewModulLog(MODULNAME),
}
2016-08-16 08:30:02 +02:00
router.GET(prefix+"/status", libapi.SessionHandler(api.Status, sessions))
router.POST(prefix+"/login", libapi.SessionHandler(api.Login, sessions))
router.GET(prefix+"/logout", libapi.LoginHandler(api.Logout, sessions))
router.POST(prefix+"/password", libapi.LoginHandler(api.Password, sessions))
router.GET(prefix+"/delete", libapi.LoginHandler(api.Status, sessions))
2016-08-13 11:03:03 +02:00
}
// Status to get Login and Server status
2016-08-16 08:30:02 +02:00
func (api *API) Status(w http.ResponseWriter, r *http.Request, _ httprouter.Params, sess session.Session) (returndata interface{}, returnerr *libapi.ErrorResult) {
returndata = false
2016-08-14 18:29:25 +02:00
logger := api.log.GetLog(r, "status")
2016-08-13 11:03:03 +02:00
result, err := api.dbconnection.Count(new(Login))
if err != nil {
2016-08-16 08:30:02 +02:00
returnerr = &libapi.ErrorResult{Message: "Affe"}
2016-08-14 15:29:54 +02:00
logger.Error("get login count: ", err)
2016-08-13 11:03:03 +02:00
} else {
if result > 0 {
2016-08-16 08:30:02 +02:00
returndata = true
2016-08-13 11:03:03 +02:00
}
}
2016-08-14 15:29:54 +02:00
logger.Info("status")
2016-08-16 08:30:02 +02:00
return
2016-08-13 11:03:03 +02:00
}
// Logout current user
2016-08-16 08:30:02 +02:00
func (api *API) Logout(w http.ResponseWriter, r *http.Request, _ httprouter.Params, sess session.Session) (returndata interface{}, returnerr *libapi.ErrorResult) {
2016-08-13 11:03:03 +02:00
api.sessions.SessionDestroy(w, r)
2016-08-14 18:29:25 +02:00
logger := api.log.GetLog(r, "logout")
2016-08-14 15:29:54 +02:00
if login := sess.Get("login"); login != nil {
logger = logger.WithField("user", login.(Login).Username)
}
sess.Delete("login")
sess.Delete("profil")
logger.Info("logout")
2016-08-16 08:30:02 +02:00
returndata = true
return
2016-08-13 11:03:03 +02:00
}
// Login of system
2016-08-16 08:30:02 +02:00
func (api *API) Login(w http.ResponseWriter, r *http.Request, _ httprouter.Params, sess session.Session) (returndata interface{}, returnerr *libapi.ErrorResult) {
2016-08-14 18:29:25 +02:00
logger := api.log.GetLog(r, "login")
2016-08-13 11:03:03 +02:00
var requestlogin RequestLogin
err := json.NewDecoder(r.Body).Decode(&requestlogin)
if err != nil {
2016-08-14 15:29:54 +02:00
logger.Error("fetch request")
2016-08-14 13:33:53 +02:00
http.Error(w, err.Error(), http.StatusInternalServerError)
2016-08-16 08:30:02 +02:00
returndata = false
2016-08-13 11:03:03 +02:00
return
}
2016-08-14 15:29:54 +02:00
logger = logger.WithField("user", requestlogin.Username)
2016-08-13 11:03:03 +02:00
var login = Login{Username: requestlogin.Username}
_, err = api.dbconnection.Get(&login)
if err != nil {
2016-08-14 15:29:54 +02:00
logger.Error("fetch database")
2016-08-16 08:30:02 +02:00
returndata = false
2016-08-14 15:29:54 +02:00
return
}
if login.Id <= 0 {
logger.Warn("user not found")
2016-08-16 08:30:02 +02:00
returndata = false
2016-08-14 13:33:53 +02:00
return
2016-08-13 11:03:03 +02:00
}
2016-08-16 08:30:02 +02:00
returndata = false
2016-08-14 13:33:53 +02:00
if login.Active {
output, _ := libpassword.Validate(login.Password, requestlogin.Password)
if output {
2016-08-16 08:30:02 +02:00
returndata = true
2016-08-14 13:33:53 +02:00
sess.Set("login", login)
2016-08-14 15:29:54 +02:00
logger.Info("logged in")
} else {
logger.Warn("wrong password")
2016-08-14 13:33:53 +02:00
}
2016-08-14 15:29:54 +02:00
} else {
logger.Warn("not active")
2016-08-13 11:03:03 +02:00
}
2016-08-14 15:29:54 +02:00
2016-08-16 08:30:02 +02:00
return
}
func (api *API) Password(w http.ResponseWriter, r *http.Request, _ httprouter.Params, sess session.Session) (returndata interface{}, returnerr *libapi.ErrorResult) {
logger := api.log.GetLog(r, "password")
logger.Warn("not implemented")
returndata = false
return
}
func (api *API) Delete(w http.ResponseWriter, r *http.Request, _ httprouter.Params, sess session.Session) (returndata interface{}, returnerr *libapi.ErrorResult) {
logger := api.log.GetLog(r, "delete")
logger.Warn("not implemented")
returndata = false
return
2016-08-13 11:03:03 +02:00
}