gPanel/pkg/api/log/delete.go
2017-11-27 21:59:45 -06:00

66 lines
1.9 KiB
Go

// Package log is a child of package api to handle api calls concerning log files
package log
import (
"encoding/json"
"log"
"net/http"
"strconv"
"github.com/Ennovar/gPanel/pkg/file"
)
// Delete function is accessed from api/logs/delete and will attempt to
// delete a given log based off of request data.
func Delete(res http.ResponseWriter, req *http.Request, logger *log.Logger, dir string) bool {
if req.Method != "UPDATE" {
logger.Println(req.URL.Path + "::" + req.Method + "::" + strconv.Itoa(http.StatusMethodNotAllowed) + "::" + http.StatusText(http.StatusMethodNotAllowed))
http.Error(res, http.StatusText(http.StatusMethodNotAllowed), http.StatusMethodNotAllowed)
return false
}
var deleteLogRequestData struct {
Name string `json:"name"`
}
err := json.NewDecoder(req.Body).Decode(&deleteLogRequestData)
if err != nil {
logger.Println(req.URL.Path + "::" + err.Error())
http.Error(res, err.Error(), http.StatusBadRequest)
return false
}
var log string
switch deleteLogRequestData.Name {
case "public_errors":
log = dir + "logs/" + file.LOG_PUBLIC_ERRORS
case "account_errors":
log = dir + "logs/" + file.LOG_ACCOUNT_ERRORS
case "public_load_time":
log = dir + "logs/" + file.LOG_PUBLIC_LOAD
case "server_errors":
log = file.LOG_SERVER_ERRORS
default:
logger.Println(req.URL.Path + "::unknown log type requested")
http.Error(res, http.StatusText(http.StatusBadRequest), http.StatusBadRequest)
return false
}
handle, err := file.Open(log, true)
if err != nil {
logger.Println(req.URL.Path + "::" + err.Error())
http.Error(res, err.Error(), http.StatusBadRequest)
return false
}
closeErr, deleteErr := handle.Close(true)
if closeErr != nil || deleteErr != nil {
logger.Println(req.URL.Path + "::" + closeErr.Error() + " AND " + deleteErr.Error())
http.Error(res, closeErr.Error()+" AND "+deleteErr.Error(), http.StatusInternalServerError)
return false
}
res.WriteHeader(http.StatusNoContent)
return true
}