141 lines
4.5 KiB
Go
141 lines
4.5 KiB
Go
package controllers
|
|
|
|
import (
|
|
"GoMembership/internal/constants"
|
|
"GoMembership/internal/models"
|
|
"GoMembership/internal/services"
|
|
"GoMembership/internal/utils"
|
|
"strings"
|
|
|
|
"net/http"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
"GoMembership/pkg/errors"
|
|
"GoMembership/pkg/logger"
|
|
)
|
|
|
|
type MembershipController struct {
|
|
Service services.MembershipServiceInterface
|
|
UserService services.UserServiceInterface
|
|
}
|
|
|
|
type MembershipData struct {
|
|
// APIKey string `json:"api_key"`
|
|
Subscription models.SubscriptionModel `json:"subscription"`
|
|
}
|
|
|
|
func (mc *MembershipController) RegisterSubscription(c *gin.Context) {
|
|
var regData MembershipData
|
|
|
|
requestUser, err := mc.UserService.FromContext(c)
|
|
if err != nil {
|
|
utils.RespondWithError(c, err, "Error extracting user from context in subscription registrationHandler", http.StatusBadRequest, errors.Responses.Fields.User, errors.Responses.Keys.NoAuthToken)
|
|
return
|
|
}
|
|
|
|
if !requestUser.HasPrivilege(constants.Priviliges.Create) {
|
|
utils.RespondWithError(c, errors.ErrNotAuthorized, "Not allowed to register subscription", http.StatusUnauthorized, errors.Responses.Fields.User, errors.Responses.Keys.Unauthorized)
|
|
return
|
|
}
|
|
|
|
if err := c.ShouldBindJSON(®Data); err != nil {
|
|
utils.HandleValidationError(c, err)
|
|
return
|
|
}
|
|
|
|
// Register Subscription
|
|
id, err := mc.Service.RegisterSubscription(®Data.Subscription)
|
|
if err != nil {
|
|
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)
|
|
} else {
|
|
utils.RespondWithError(c, err, "Couldn't register Membershipmodel", http.StatusInternalServerError, errors.Responses.Fields.SubscriptionModel, errors.Responses.Keys.InternalServerError)
|
|
}
|
|
return
|
|
}
|
|
logger.Info.Printf("registering subscription: %+v", regData)
|
|
c.JSON(http.StatusCreated, gin.H{
|
|
"status": "success",
|
|
"id": id,
|
|
})
|
|
}
|
|
|
|
func (mc *MembershipController) UpdateHandler(c *gin.Context) {
|
|
var regData MembershipData
|
|
|
|
requestUser, err := mc.UserService.FromContext(c)
|
|
if err != nil {
|
|
utils.RespondWithError(c, err, "Error extracting user from context in subscription Updatehandler", http.StatusBadRequest, errors.Responses.Fields.User, errors.Responses.Keys.NoAuthToken)
|
|
return
|
|
}
|
|
|
|
if !requestUser.HasPrivilege(constants.Priviliges.Update) {
|
|
utils.RespondWithError(c, errors.ErrNotAuthorized, "Not allowed to update subscription", http.StatusUnauthorized, errors.Responses.Fields.User, errors.Responses.Keys.Unauthorized)
|
|
return
|
|
}
|
|
|
|
if err := c.ShouldBindJSON(®Data); err != nil {
|
|
utils.HandleValidationError(c, err)
|
|
return
|
|
}
|
|
|
|
// update Subscription
|
|
logger.Info.Printf("Updating subscription %v", regData.Subscription.Name)
|
|
id, err := mc.Service.UpdateSubscription(®Data.Subscription)
|
|
if err != nil {
|
|
utils.HandleSubscriptionUpdateError(c, err)
|
|
return
|
|
}
|
|
logger.Info.Printf("updating subscription: %+v", regData)
|
|
c.JSON(http.StatusAccepted, gin.H{
|
|
"status": "success",
|
|
"id": id,
|
|
})
|
|
}
|
|
|
|
func (mc *MembershipController) DeleteSubscription(c *gin.Context) {
|
|
type deleteData struct {
|
|
Subscription struct {
|
|
ID uint `json:"id"`
|
|
Name string `json:"name"`
|
|
} `json:"subscription"`
|
|
}
|
|
|
|
var data deleteData
|
|
requestUser, err := mc.UserService.FromContext(c)
|
|
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)
|
|
return
|
|
}
|
|
|
|
if !requestUser.HasPrivilege(constants.Priviliges.Delete) {
|
|
utils.RespondWithError(c, errors.ErrNotAuthorized, "Not allowed to update subscription", http.StatusUnauthorized, errors.Responses.Fields.User, errors.Responses.Keys.Unauthorized)
|
|
return
|
|
}
|
|
|
|
if err := c.ShouldBindJSON(&data); err != nil {
|
|
utils.HandleValidationError(c, err)
|
|
return
|
|
}
|
|
|
|
if err := mc.Service.DeleteSubscription(&data.Subscription.ID, &data.Subscription.Name); err != nil {
|
|
utils.HandleSubscriptionDeleteError(c, err)
|
|
return
|
|
}
|
|
|
|
c.JSON(http.StatusOK, gin.H{"message": "Subscription deleted successfully"})
|
|
}
|
|
|
|
func (mc *MembershipController) GetSubscriptions(c *gin.Context) {
|
|
subscriptions, err := mc.Service.GetSubscriptions(nil)
|
|
if err != nil {
|
|
utils.RespondWithError(c, err, "Error retrieving subscriptions", http.StatusInternalServerError, errors.Responses.Fields.SubscriptionModel, errors.Responses.Keys.InternalServerError)
|
|
return
|
|
}
|
|
|
|
c.JSON(http.StatusOK, gin.H{
|
|
"subscriptions": subscriptions,
|
|
})
|
|
}
|