Redmage/server/routes/device_validate_name.go

68 lines
1.9 KiB
Go
Raw Permalink Normal View History

2024-05-07 20:51:00 +07:00
package routes
import (
"net/http"
"github.com/gosimple/slug"
"github.com/tigorlazuardi/redmage/pkg/errs"
"github.com/tigorlazuardi/redmage/pkg/log"
"github.com/tigorlazuardi/redmage/views/devices/put"
2024-05-07 20:51:00 +07:00
)
func (routes *Routes) DevicesValidateNameHTMX(rw http.ResponseWriter, req *http.Request) {
ctx, span := tracer.Start(req.Context(), "*Routes.ValidateName")
defer span.End()
2024-05-08 10:10:23 +07:00
var nameData put.NameInputData
2024-05-07 20:51:00 +07:00
nameData.Value = req.FormValue("name")
2024-05-08 10:10:23 +07:00
nameComponent := put.NameInput(nameData)
2024-05-07 20:51:00 +07:00
s := req.FormValue("slug")
if s != "" || nameData.Value == "" {
if err := nameComponent.Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render name input")
}
return
}
s = slug.Make(nameData.Value)
2024-05-08 10:10:23 +07:00
slugData := put.SlugInputData{
2024-05-07 20:51:00 +07:00
Value: s,
HXSwapOOB: true,
}
if s == "" {
slugData.Error = "Identifier resolves to empty value. Please set a valid identifier manually."
_ = nameComponent.Render(ctx, rw)
2024-05-08 10:10:23 +07:00
if err := put.SlugInput(slugData).Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render name input")
}
return
}
2024-05-07 20:51:00 +07:00
exist, err := routes.API.DevicesValidateSlug(ctx, s)
if err != nil {
log.New(ctx).Err(err).Error("failed to validate slug")
_, message := errs.HTTPMessage(err)
slugData.Error = message
_ = nameComponent.Render(ctx, rw)
2024-05-08 10:10:23 +07:00
if err := put.SlugInput(slugData).Render(ctx, rw); err != nil {
2024-05-07 20:51:00 +07:00
log.New(ctx).Err(err).Error("failed to render name input")
}
}
if exist {
slugData.Error = "Device with this identifier already exist. Please change the value manually."
_ = nameComponent.Render(ctx, rw)
2024-05-08 10:10:23 +07:00
if err := put.SlugInput(slugData).Render(ctx, rw); err != nil {
2024-05-07 20:51:00 +07:00
log.New(ctx).Err(err).Error("failed to render name input")
}
return
}
slugData.Valid = "Identifier is available."
2024-05-07 20:51:00 +07:00
_ = nameComponent.Render(ctx, rw)
2024-05-08 10:10:23 +07:00
if err := put.SlugInput(slugData).Render(ctx, rw); err != nil {
2024-05-07 20:51:00 +07:00
log.New(ctx).Err(err).Error("failed to render name input")
}
}