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/modul/host/apidomain.go

169 lines
4.6 KiB
Go
Raw Normal View History

2016-10-17 11:54:35 +02:00
package host
import (
"net/http"
"strconv"
"strings"
2016-10-17 11:54:35 +02:00
"goji.io/pat"
2016-10-17 11:54:35 +02:00
libapi "dev.sum7.eu/sum7/warehost/lib/api"
system "dev.sum7.eu/sum7/warehost/system"
2016-10-17 11:54:35 +02:00
)
2016-12-19 12:24:18 +01:00
func getDomain(w http.ResponseWriter, r *http.Request) (domain Domain, returnerr *libapi.ErrorResult) {
ctx := r.Context()
login := ctx.Value("login").(*system.Login)
profil := ctx.Value("profil").(*Profil)
2016-12-19 12:24:18 +01:00
id, err := strconv.ParseInt(pat.Param(r, "domainid"), 10, 64)
if err != nil {
returnerr = &libapi.ErrorResult{
Message: "Internal Request Error",
}
w.WriteHeader(http.StatusBadRequest)
return
}
2016-12-13 12:43:51 +01:00
2017-06-02 10:15:09 +02:00
domain = Domain{ID: id}
db := dbconnection.First(&domain)
2017-06-02 10:15:09 +02:00
if db.Error != nil || db.RecordNotFound() {
returnerr = &libapi.ErrorResult{Fields: []string{"domain"}, Message: "domain not found"}
2016-10-21 21:32:30 +02:00
w.WriteHeader(http.StatusNotFound)
}
2017-06-02 10:15:09 +02:00
if !login.Superadmin {
if profil.ID != domain.ProfilID {
returnerr = &libapi.ErrorResult{Fields: []string{"profil"}, Message: "not allowed to get domain"}
w.WriteHeader(http.StatusForbidden)
}
}
return
}
2016-12-19 12:24:18 +01:00
func domainList(w http.ResponseWriter, r *http.Request) {
ctx := r.Context()
login := ctx.Value("login").(*system.Login)
2016-10-17 11:54:35 +02:00
profil := ctx.Value("profil").(*Profil)
logger := log.GetLog(r, "domainlist")
2017-06-02 10:15:09 +02:00
logger = logger.WithField("pID", profil.ID)
2016-10-17 11:54:35 +02:00
var domain []*Domain
if login.Superadmin && r.URL.Query().Get("filter") == "all" {
2016-10-18 20:26:17 +02:00
dbconnection.Preload("Profil").Preload("Profil.Login").Find(&domain)
} else {
dbconnection.Where("profil = ?", profil.ID).Find(&domain)
}
2016-10-17 11:54:35 +02:00
logger.Info("done")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, domain, nil)
2016-10-17 11:54:35 +02:00
}
2016-12-19 12:24:18 +01:00
func domainShow(w http.ResponseWriter, r *http.Request) {
2016-12-13 12:43:51 +01:00
logger := log.GetLog(r, "domainshow")
2017-06-02 10:15:09 +02:00
logger = setProfilLog(r, logger)
2016-12-19 12:24:18 +01:00
domain, returnerr := getDomain(w, r)
2017-06-02 10:15:09 +02:00
logger = logger.WithField("dID", domain.ID)
2016-10-22 21:20:21 +02:00
if returnerr != nil {
2017-06-02 10:15:09 +02:00
logger.Info(returnerr.Message)
2016-12-19 12:52:43 +01:00
libapi.JSONWrite(w, r, false, returnerr)
2016-10-22 21:20:21 +02:00
return
}
logger.Info("done")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, domain, nil)
2016-10-22 21:20:21 +02:00
}
2016-12-19 12:24:18 +01:00
func domainAdd(w http.ResponseWriter, r *http.Request) {
ctx := r.Context()
2016-10-17 11:54:35 +02:00
profil := ctx.Value("profil").(*Profil)
2016-10-17 14:07:17 +02:00
logger := log.GetLog(r, "domainadd")
2017-06-02 10:15:09 +02:00
logger = setProfilLog(r, logger)
2016-10-17 14:07:17 +02:00
var domainRequest Domain
2016-12-19 12:24:18 +01:00
returnerr := libapi.JSONDecoder(w, r, logger, &domainRequest)
2016-10-17 14:07:17 +02:00
if returnerr != nil {
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, returnerr)
2016-10-17 14:07:17 +02:00
return
}
domain := &Domain{
ProfilID: profil.ID,
FQDN: domainRequest.FQDN,
Mail: domainRequest.Mail,
Web: domainRequest.Web,
}
if err := dbconnection.Create(domain).Error; err != nil {
2016-12-19 12:24:18 +01:00
w.WriteHeader(http.StatusInternalServerError)
if strings.Contains(err.Error(), "licate key") {
logger.Warning("exists already")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, &libapi.ErrorResult{Message: "already signup"})
return
}
logger.Error("database: during create host domain: ", err)
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, &libapi.ErrorResult{Message: "Internal Database Error with Database"})
return
}
logger.Info("done")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, true, nil)
}
2016-12-19 12:24:18 +01:00
func domainEdit(w http.ResponseWriter, r *http.Request) {
ctx := r.Context()
login := ctx.Value("login").(*system.Login)
logger := log.GetLog(r, "domainedit")
2017-06-02 10:15:09 +02:00
logger = setProfilLog(r, logger)
2016-12-19 12:24:18 +01:00
domain, returnerr := getDomain(w, r)
2017-06-02 10:15:09 +02:00
logger = logger.WithField("dID", domain.ID)
if returnerr != nil {
2017-06-02 10:15:09 +02:00
logger.Info(returnerr.Message)
2016-12-19 12:52:43 +01:00
libapi.JSONWrite(w, r, false, returnerr)
return
}
var domainRequest Domain
2016-12-19 12:24:18 +01:00
returnerr = libapi.JSONDecoder(w, r, logger, &domainRequest)
if returnerr != nil {
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, returnerr)
return
}
domain.FQDN = domainRequest.FQDN
domain.Mail = domainRequest.Mail
domain.Web = domainRequest.Web
if login.Superadmin {
domain.Active = domainRequest.Active
}
if err := dbconnection.Save(domain).Error; err != nil {
logger.Error("database: during modify host domain: ", err)
w.WriteHeader(http.StatusInternalServerError)
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, &libapi.ErrorResult{Message: "Internal Database Error with Database"})
return
}
logger.Info("done")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, true, nil)
}
2016-12-19 12:24:18 +01:00
func domainDelete(w http.ResponseWriter, r *http.Request) {
logger := log.GetLog(r, "domaindelete")
2017-06-02 10:15:09 +02:00
logger = setProfilLog(r, logger)
2016-12-19 12:24:18 +01:00
domain, returnerr := getDomain(w, r)
2017-06-02 10:15:09 +02:00
logger = logger.WithField("dID", domain.ID)
if returnerr != nil {
2017-06-02 10:15:09 +02:00
logger.Info(returnerr.Message)
2016-12-19 12:52:43 +01:00
libapi.JSONWrite(w, r, false, returnerr)
return
}
2016-12-13 11:35:44 +01:00
if err := dbconnection.Unscoped().Delete(domain).Error; err != nil {
2016-10-17 14:07:17 +02:00
logger.Error("database: during create host domain: ", err)
w.WriteHeader(http.StatusInternalServerError)
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, false, &libapi.ErrorResult{Message: "Internal Database Error with Database"})
2016-10-17 14:07:17 +02:00
return
}
2016-10-17 11:54:35 +02:00
logger.Info("done")
2016-12-19 12:24:18 +01:00
libapi.JSONWrite(w, r, true, nil)
2016-10-17 11:54:35 +02:00
}