78 lines
1.7 KiB
Go
78 lines
1.7 KiB
Go
|
package controllers
|
||
|
|
||
|
import (
|
||
|
"errors"
|
||
|
"go-backend-starter-project/initializers"
|
||
|
"go-backend-starter-project/models"
|
||
|
token "go-backend-starter-project/tokens"
|
||
|
"net/http"
|
||
|
|
||
|
"github.com/gin-gonic/gin"
|
||
|
"github.com/google/uuid"
|
||
|
"gorm.io/gorm"
|
||
|
)
|
||
|
|
||
|
func GetUserById(c *gin.Context) {
|
||
|
userId := c.Param("id")
|
||
|
|
||
|
uniqueId, err := uuid.Parse(userId)
|
||
|
if err != nil {
|
||
|
c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid user ID format"})
|
||
|
return
|
||
|
}
|
||
|
|
||
|
var user models.User
|
||
|
result := initializers.DB.First(&user, "id = ?", uniqueId)
|
||
|
|
||
|
if result.Error != nil {
|
||
|
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||
|
c.JSON(http.StatusNotFound, gin.H{"error": "User not found"})
|
||
|
} else {
|
||
|
c.JSON(http.StatusInternalServerError, gin.H{"error": "Unknown database error"})
|
||
|
}
|
||
|
return
|
||
|
}
|
||
|
|
||
|
c.JSON(http.StatusOK, user)
|
||
|
}
|
||
|
|
||
|
func GetUsers(c *gin.Context) {
|
||
|
var users []models.User
|
||
|
|
||
|
result := initializers.DB.Find(&users)
|
||
|
if result.Error != nil {
|
||
|
c.Status(http.StatusBadRequest)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
c.JSON(http.StatusAccepted, gin.H{
|
||
|
"users": users,
|
||
|
})
|
||
|
}
|
||
|
|
||
|
func DeleteUser(c *gin.Context) {
|
||
|
|
||
|
session, err := token.ParseToken(c)
|
||
|
if err != nil {
|
||
|
c.Status(http.StatusInternalServerError)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
var user models.User
|
||
|
result := initializers.DB.First(&user, "id = ?", session.Bearer)
|
||
|
if result.Error != nil {
|
||
|
c.JSON(http.StatusInternalServerError, gin.H{"error": "Unknown database error"})
|
||
|
return
|
||
|
}
|
||
|
result = initializers.DB.Delete(&user)
|
||
|
if result.Error != nil {
|
||
|
c.JSON(http.StatusInternalServerError, gin.H{"error": "Unknown database error"})
|
||
|
return
|
||
|
}
|
||
|
|
||
|
c.SetCookie("Authorization", "", -1, "", "", false, true)
|
||
|
c.JSON(http.StatusAccepted, gin.H{
|
||
|
"success": "Account deleted.",
|
||
|
})
|
||
|
}
|