moved to flat json handling
This commit is contained in:
@@ -20,13 +20,7 @@ type MembershipController struct {
|
|||||||
UserService services.UserServiceInterface
|
UserService services.UserServiceInterface
|
||||||
}
|
}
|
||||||
|
|
||||||
type MembershipData struct {
|
|
||||||
// APIKey string `json:"api_key"`
|
|
||||||
Subscription models.SubscriptionModel `json:"subscription"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
||||||
var regData MembershipData
|
|
||||||
|
|
||||||
requestUser, err := mc.UserService.FromContext(c)
|
requestUser, err := mc.UserService.FromContext(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -39,13 +33,14 @@ func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := c.ShouldBindJSON(®Data); err != nil {
|
var subscription models.SubscriptionModel
|
||||||
|
if err := c.ShouldBindJSON(&subscription); err != nil {
|
||||||
utils.HandleValidationError(c, err)
|
utils.HandleValidationError(c, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Register Subscription
|
// Register Subscription
|
||||||
id, err := mc.Service.RegisterSubscription(®Data.Subscription)
|
id, err := mc.Service.RegisterSubscription(&subscription)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if strings.Contains(err.Error(), "UNIQUE constraint failed") {
|
if strings.Contains(err.Error(), "UNIQUE constraint failed") {
|
||||||
utils.RespondWithError(c, err, "Subscription already exists", http.StatusConflict, errors.Responses.Fields.SubscriptionModel, errors.Responses.Keys.Duplicate)
|
utils.RespondWithError(c, err, "Subscription already exists", http.StatusConflict, errors.Responses.Fields.SubscriptionModel, errors.Responses.Keys.Duplicate)
|
||||||
@@ -54,7 +49,7 @@ func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
logger.Info.Printf("registering subscription: %+v", regData)
|
logger.Info.Printf("registering subscription: %+v", subscription)
|
||||||
c.JSON(http.StatusCreated, gin.H{
|
c.JSON(http.StatusCreated, gin.H{
|
||||||
"status": "success",
|
"status": "success",
|
||||||
"id": id,
|
"id": id,
|
||||||
@@ -62,7 +57,6 @@ func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (mc *MembershipController) UpdateHandler(c *gin.Context) {
|
func (mc *MembershipController) UpdateHandler(c *gin.Context) {
|
||||||
var regData MembershipData
|
|
||||||
|
|
||||||
requestUser, err := mc.UserService.FromContext(c)
|
requestUser, err := mc.UserService.FromContext(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -75,19 +69,19 @@ func (mc *MembershipController) UpdateHandler(c *gin.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := c.ShouldBindJSON(®Data); err != nil {
|
var subscription models.SubscriptionModel
|
||||||
|
if err := c.ShouldBindJSON(&subscription); err != nil {
|
||||||
utils.HandleValidationError(c, err)
|
utils.HandleValidationError(c, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// update Subscription
|
// update Subscription
|
||||||
logger.Info.Printf("Updating subscription %v", regData.Subscription.Name)
|
logger.Info.Printf("Updating subscription %v", subscription.Name)
|
||||||
id, err := mc.Service.UpdateSubscription(®Data.Subscription)
|
id, err := mc.Service.UpdateSubscription(&subscription)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
utils.HandleSubscriptionUpdateError(c, err)
|
utils.HandleSubscriptionUpdateError(c, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
logger.Info.Printf("updating subscription: %+v", regData)
|
|
||||||
c.JSON(http.StatusAccepted, gin.H{
|
c.JSON(http.StatusAccepted, gin.H{
|
||||||
"status": "success",
|
"status": "success",
|
||||||
"id": id,
|
"id": id,
|
||||||
@@ -96,13 +90,11 @@ func (mc *MembershipController) UpdateHandler(c *gin.Context) {
|
|||||||
|
|
||||||
func (mc *MembershipController) DeleteSubscription(c *gin.Context) {
|
func (mc *MembershipController) DeleteSubscription(c *gin.Context) {
|
||||||
type deleteData struct {
|
type deleteData struct {
|
||||||
Subscription struct {
|
ID uint `json:"id" binding:"required,numeric,safe_content"`
|
||||||
ID uint `json:"id"`
|
Name string `json:"name" binding:"required,safe_content"`
|
||||||
Name string `json:"name"`
|
|
||||||
} `json:"subscription"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var data deleteData
|
var subscription deleteData
|
||||||
requestUser, err := mc.UserService.FromContext(c)
|
requestUser, err := mc.UserService.FromContext(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
utils.RespondWithError(c, err, "Error extracting user from context in subscription deleteSubscription", http.StatusBadRequest, errors.Responses.Fields.User, errors.Responses.Keys.NoAuthToken)
|
utils.RespondWithError(c, err, "Error extracting user from context in subscription deleteSubscription", http.StatusBadRequest, errors.Responses.Fields.User, errors.Responses.Keys.NoAuthToken)
|
||||||
@@ -114,12 +106,12 @@ func (mc *MembershipController) DeleteSubscription(c *gin.Context) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := c.ShouldBindJSON(&data); err != nil {
|
if err := c.ShouldBindJSON(&subscription); err != nil {
|
||||||
utils.HandleValidationError(c, err)
|
utils.HandleValidationError(c, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := mc.Service.DeleteSubscription(&data.Subscription.ID, &data.Subscription.Name); err != nil {
|
if err := mc.Service.DeleteSubscription(&subscription.ID, &subscription.Name); err != nil {
|
||||||
utils.HandleSubscriptionDeleteError(c, err)
|
utils.HandleSubscriptionDeleteError(c, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user