Redmage/server/routes/device_validate_slug.go

51 lines
1.4 KiB
Go
Raw Normal View History

2024-05-07 16:48:15 +07:00
package routes
import (
"net/http"
2024-05-07 20:51:00 +07:00
"github.com/gosimple/slug"
2024-05-07 16:48:15 +07:00
"github.com/tigorlazuardi/redmage/pkg/errs"
"github.com/tigorlazuardi/redmage/pkg/log"
"github.com/tigorlazuardi/redmage/views/devicesview/adddevice"
)
func (routes *Routes) DevicesValidateSlugHTMX(rw http.ResponseWriter, req *http.Request) {
ctx, span := tracer.Start(req.Context(), "*Routes.ValidateSlugHTMX")
defer span.End()
var data adddevice.SlugInputData
2024-05-07 20:51:00 +07:00
data.Value = slug.Make(req.FormValue("slug"))
2024-05-07 16:48:15 +07:00
if data.Value == "" {
if err := adddevice.SlugInput(data).Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render slug input")
}
return
}
exist, err := routes.API.DevicesValidateSlug(ctx, data.Value)
if err != nil {
log.New(ctx).Err(err).Error("failed to validate slug")
code, message := errs.HTTPMessage(err)
rw.WriteHeader(code)
data.Error = message
if err := adddevice.SlugInput(data).Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render slug input")
}
return
}
if exist {
data.Error = "Device with this identifier already exist"
rw.WriteHeader(http.StatusConflict)
if err := adddevice.SlugInput(data).Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render slug input")
}
return
}
data.Valid = "Identifier is available"
if err := adddevice.SlugInput(data).Render(ctx, rw); err != nil {
log.New(ctx).Err(err).Error("failed to render slug input")
}
}