gogmagog/routes/plans.go
Deepak c3be0b8e54
All checks were successful
gitea-deepak/gogmagog/pipeline/head This commit looks good
Adds put plan route
2021-02-07 15:27:12 -06:00

189 lines
4.1 KiB
Go

package routes
import (
"encoding/json"
"gitea.deepak.science/deepak/gogmagog/models"
"gitea.deepak.science/deepak/gogmagog/tokens"
"github.com/go-chi/chi"
"io"
"net/http"
"strconv"
)
// NewPlanRouter returns the http.Handler for the passed in model to route plan methods.
func NewPlanRouter(m *models.Model) http.Handler {
router := chi.NewRouter()
router.Get("/", getAllPlansFunc(m))
router.Post("/", postPlanFunc(m))
router.Get("/{planid}", getPlanByIDFunc(m))
router.Put("/{planid}", putPlanFunc(m))
return router
}
func getAllPlansFunc(m *models.Model) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
userID, err := tokens.GetUserID(r.Context())
if err != nil {
unauthorizedHandler(w, r)
return
}
plans, err := m.Plans(userID)
if err != nil {
serverError(w, err)
return
}
w.Header().Add("Content-Type", "application/json")
if err := json.NewEncoder(w).Encode(plans); err != nil {
serverError(w, err)
}
}
}
func getPlanByIDFunc(m *models.Model) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
userID, err := tokens.GetUserID(r.Context())
if err != nil {
unauthorizedHandler(w, r)
return
}
id, err := strconv.Atoi(chi.URLParam(r, "planid"))
if err != nil {
notFoundHandler(w, r)
return
}
// todo get real user id
plan, err := m.Plan(id, userID)
if err != nil {
if models.IsNotFoundError(err) {
notFoundHandler(w, r)
return
}
serverError(w, err)
return
}
w.Header().Add("Content-Type", "application/json")
if err := json.NewEncoder(w).Encode(plan); err != nil {
serverError(w, err)
}
}
}
type createPlanResponse struct {
CreatedPlan *models.Plan `json:"created_plan"`
ID int64 `json:"id"`
}
func postPlanFunc(m *models.Model) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
userID, err := tokens.GetUserID(r.Context())
if err != nil {
unauthorizedHandler(w, r)
return
}
r.Body = http.MaxBytesReader(w, r.Body, 1024)
dec := json.NewDecoder(r.Body)
dec.DisallowUnknownFields()
var p models.Plan
err = dec.Decode(&p)
if err != nil {
badRequestError(w, err)
return
}
err = dec.Decode(&struct{}{})
if err != io.EOF {
badRequestError(w, err)
return
}
// Map the fields we allow to be set to the plan to be created.
plan := &models.Plan{PlanDescription: p.PlanDescription, UserID: p.UserID}
id, err := m.AddPlan(plan, userID)
if err != nil {
serverError(w, err)
return
}
plan, err = m.Plan(id, userID)
if err != nil {
serverError(w, err)
return
}
response := &createPlanResponse{
CreatedPlan: plan,
ID: int64(id),
}
w.WriteHeader(http.StatusCreated)
w.Header().Add("Content-Type", "application/json")
if err := json.NewEncoder(w).Encode(response); err != nil {
serverError(w, err)
}
}
}
type updatePlanResponse struct {
UpdatedPlan *models.Plan `json:"updated_plan"`
ID int64 `json:"id"`
}
func putPlanFunc(m *models.Model) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
userID, err := tokens.GetUserID(r.Context())
if err != nil {
unauthorizedHandler(w, r)
return
}
id, err := strconv.Atoi(chi.URLParam(r, "planid"))
if err != nil {
notFoundHandler(w, r)
return
}
r.Body = http.MaxBytesReader(w, r.Body, 1024)
dec := json.NewDecoder(r.Body)
dec.DisallowUnknownFields()
var p models.Plan
err = dec.Decode(&p)
if err != nil {
badRequestError(w, err)
return
}
err = dec.Decode(&struct{}{})
if err != io.EOF {
badRequestError(w, err)
return
}
plan := &models.Plan{
PlanDescription: p.PlanDescription,
PlanID: int64(id),
}
err = m.SavePlan(plan, userID)
if err != nil {
serverError(w, err)
return
}
plan, err = m.Plan(id, userID)
if err != nil {
serverError(w, err)
return
}
response := &updatePlanResponse{
UpdatedPlan: plan,
ID: int64(id),
}
w.Header().Add("Content-Type", "application/json")
w.WriteHeader(http.StatusOK)
if err := json.NewEncoder(w).Encode(response); err != nil {
serverError(w, err)
}
}
}