fyp/logic/models/delete.go

86 lines
2.1 KiB
Go
Raw Normal View History

package models
import (
"net/http"
"os"
"path"
2024-04-14 14:51:16 +01:00
. "git.andr3h3nriqu3s.com/andr3/fyp/logic/db_types"
. "git.andr3h3nriqu3s.com/andr3/fyp/logic/utils"
)
func DeleteModel(c BasePack, id string) (err error) {
c.GetLogger().Warnf("Removing model with id: %s", id)
_, err = c.GetDb().Exec("delete from models where id=$1;", id)
if err != nil {
return
}
model_path := path.Join("./savedData", id)
c.GetLogger().Warnf("Removing folder of model with id: %s at %s", id, model_path)
err = os.RemoveAll(model_path)
if err != nil {
return
}
return
}
func deleteModelJSON(c *Context, id string) *Error {
err := DeleteModel(c, id)
if err != nil {
return c.E500M("Failed to delete models", err)
}
return c.SendJSON(id)
}
func handleDelete(handle *Handle) {
2024-04-14 15:19:32 +01:00
type DeleteModel struct {
Id string `json:"id" validate:"required"`
Name *string `json:"name,omitempty"`
}
DeleteAuthJson(handle, "/models/delete", User_Normal, func(c *Context, dat *DeleteModel) *Error {
2024-03-09 10:52:08 +00:00
var model struct {
Id string
Name string
Status int
}
2024-04-14 14:51:16 +01:00
err := GetDBOnce(c, &model, "models where id=$1 and user_id=$2;", dat.Id, c.User.Id)
2024-03-09 10:52:08 +00:00
if err == NotFoundError {
return c.SendJSONStatus(http.StatusNotFound, "Model not found!")
} else if err != nil {
2024-04-14 15:19:32 +01:00
return c.E500M("Faield to get model", err)
}
switch ModelStatus(model.Status) {
case FAILED_TRAINING:
fallthrough
case FAILED_PREPARING_ZIP_FILE:
fallthrough
case FAILED_PREPARING_TRAINING:
fallthrough
case FAILED_PREPARING:
2024-03-09 10:52:08 +00:00
return deleteModelJSON(c, dat.Id)
case READY:
fallthrough
2024-04-08 14:17:13 +01:00
case READY_RETRAIN_FAILED:
fallthrough
case READY_ALTERATION_FAILED:
fallthrough
case CONFIRM_PRE_TRAINING:
2024-03-09 10:52:08 +00:00
if dat.Name == nil {
return c.JsonBadRequest("Provided name does not match the model name")
}
2024-03-09 10:52:08 +00:00
if *dat.Name != model.Name {
return c.JsonBadRequest("Provided name does not match the model name")
}
2024-03-09 10:52:08 +00:00
return deleteModelJSON(c, dat.Id)
default:
2024-03-09 10:52:08 +00:00
c.Logger.Warn("Do not know how to handle model in status", "status", model.Status)
return c.JsonBadRequest("Model in invalid status")
}
})
}