feat: shelf creation
This commit is contained in:
@@ -2,7 +2,6 @@ package api
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"log"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
@@ -94,7 +93,6 @@ func (s *APIServer) deleteAsset(w http.ResponseWriter, r *http.Request) error {
|
|||||||
func (s *APIServer) createAsset(w http.ResponseWriter, r *http.Request) error {
|
func (s *APIServer) createAsset(w http.ResponseWriter, r *http.Request) error {
|
||||||
data := &types.CreateAssetRequest{}
|
data := &types.CreateAssetRequest{}
|
||||||
if err := render.Bind(r, data); err != nil {
|
if err := render.Bind(r, data); err != nil {
|
||||||
log.Printf("ERR: %v\n", err)
|
|
||||||
return render.Render(w, r, errBadRequest(err))
|
return render.Render(w, r, errBadRequest(err))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ import (
|
|||||||
func (s *APIServer) setupShelfRoutes() func(chi.Router) {
|
func (s *APIServer) setupShelfRoutes() func(chi.Router) {
|
||||||
return func(r chi.Router) {
|
return func(r chi.Router) {
|
||||||
r.Get("/", makeHandler(s.getShelves))
|
r.Get("/", makeHandler(s.getShelves))
|
||||||
//r.Post("/", makeHandler(s.createShelf))
|
r.Post("/", makeHandler(s.createShelf))
|
||||||
|
|
||||||
r.Route("/{shelfID}", func(r chi.Router) {
|
r.Route("/{shelfID}", func(r chi.Router) {
|
||||||
r.Use(s.ShelfCtx)
|
r.Use(s.ShelfCtx)
|
||||||
@@ -94,3 +94,29 @@ func (s *APIServer) deleteShelf(w http.ResponseWriter, r *http.Request) error {
|
|||||||
ShelfLocation: shelf,
|
ShelfLocation: shelf,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *APIServer) createShelf(w http.ResponseWriter, r *http.Request) error {
|
||||||
|
data := &types.CreateShelfRequest{}
|
||||||
|
if err := render.Bind(r, data); err != nil {
|
||||||
|
return render.Render(w, r, errBadRequest(err))
|
||||||
|
}
|
||||||
|
|
||||||
|
shelf := &types.ShelfLocation{
|
||||||
|
Name: data.Name,
|
||||||
|
RoomNumber: data.RoomNumber,
|
||||||
|
Description: data.Description,
|
||||||
|
BuildingID: data.BuildingID,
|
||||||
|
}
|
||||||
|
|
||||||
|
err := s.db.CreateShelfLocation(shelf)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return render.Render(w, r, &types.ShelfResponse{
|
||||||
|
Response: &types.Response{
|
||||||
|
HTTPStatusCode: http.StatusOK,
|
||||||
|
},
|
||||||
|
ShelfLocation: shelf,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package types
|
package types
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"net/http"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
@@ -23,6 +24,12 @@ type Building struct {
|
|||||||
Requests
|
Requests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
type CreateBuildingRequest struct {
|
||||||
|
Name string `json:"name"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c CreateBuildingRequest) Bind(r *http.Request) error { return nil }
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Responses
|
Responses
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package types
|
package types
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"net/http"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
@@ -27,6 +28,15 @@ type ShelfLocation struct {
|
|||||||
Requests
|
Requests
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
type CreateShelfRequest struct {
|
||||||
|
Name string `json:"name"`
|
||||||
|
RoomNumber string `json:"room_number,omitempty"`
|
||||||
|
Description string `json:"description,omitempty"`
|
||||||
|
BuildingID uint64 `json:"building_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c CreateShelfRequest) Bind(r *http.Request) error { return nil }
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Responses
|
Responses
|
||||||
*/
|
*/
|
||||||
|
|||||||
Reference in New Issue
Block a user