ability to delete vehicle

This commit is contained in:
Akhil Gupta
2021-06-01 22:30:21 +05:30
parent 1ca98cec24
commit 567bad1cf6
5 changed files with 99 additions and 7 deletions

View File

@@ -1,6 +1,7 @@
package controllers
import (
"errors"
"net/http"
"github.com/akhilrex/hammond/common"
@@ -14,6 +15,7 @@ func RegisterVehicleController(router *gin.RouterGroup) {
router.GET("/vehicles", getAllVehicles)
router.GET("/vehicles/:id", getVehicleById)
router.PUT("/vehicles/:id", updateVehicle)
router.DELETE("/vehicles/:id", deleteVehicle)
router.GET("/vehicles/:id/stats", getVehicleStats)
router.GET("/vehicles/:id/users", getVehicleUsers)
router.POST("/vehicles/:id/users/:subId", shareVehicle)
@@ -366,6 +368,31 @@ func getVehicleUsers(c *gin.Context) {
c.JSON(http.StatusUnprocessableEntity, common.NewValidatorError(err))
}
}
func deleteVehicle(c *gin.Context) {
var searchByIdQuery models.SearchByIdQuery
if err := c.ShouldBindUri(&searchByIdQuery); err == nil {
canDelete, err := service.CanDeleteVehicle(searchByIdQuery.Id, c.MustGet("userId").(string))
if err != nil {
c.JSON(http.StatusUnprocessableEntity, common.NewError("shareVehicle", err))
return
}
if !canDelete {
c.JSON(http.StatusUnprocessableEntity, common.NewError("shareVehicle", errors.New("You are not allowed to delete this vehicle.")))
return
}
err = service.DeleteVehicle(searchByIdQuery.Id)
if err != nil {
c.JSON(http.StatusUnprocessableEntity, common.NewError("shareVehicle", err))
return
}
c.JSON(http.StatusOK, gin.H{})
} else {
c.JSON(http.StatusUnprocessableEntity, common.NewValidatorError(err))
}
}
func shareVehicle(c *gin.Context) {
var searchByIdQuery models.SubItemQuery

View File

@@ -62,7 +62,7 @@ func GetVehicleOwner(vehicleId string) (string, error) {
if tx.Error != nil {
return "", tx.Error
}
return mapping.ID, nil
return mapping.UserID, nil
}
func GetVehicleUsers(vehicleId string) (*[]UserVehicle, error) {
@@ -176,6 +176,11 @@ func GetExpenseById(id string) (*Expense, error) {
return &obj, result.Error
}
func DeleteVehicleById(id string) error {
result := DB.Where("id=?", id).Delete(&Vehicle{})
return result.Error
}
func DeleteFillupById(id string) error {
result := DB.Where("id=?", id).Delete(&Fillup{})
@@ -186,6 +191,16 @@ func DeleteExpenseById(id string) error {
return result.Error
}
func DeleteFillupByVehicleId(id string) error {
result := DB.Where("vehicle_id=?", id).Delete(&Fillup{})
return result.Error
}
func DeleteExpenseByVehicleId(id string) error {
result := DB.Where("vehicle_id=?", id).Delete(&Expense{})
return result.Error
}
func GetAllQuickEntries(sorting string) (*[]QuickEntry, error) {
if sorting == "" {
sorting = "created_at desc"

View File

@@ -42,6 +42,20 @@ func GetVehicleOwner(vehicleId string) (string, error) {
func GetVehicleUsers(vehicleId string) (*[]db.UserVehicle, error) {
return db.GetVehicleUsers(vehicleId)
}
func CanDeleteVehicle(vehicleId, userId string) (bool, error) {
owner, err := db.GetVehicleOwner(vehicleId)
if err != nil {
return false, err
}
return owner == userId, nil
}
func DeleteVehicle(vehicleId string) error {
db.DeleteExpenseByVehicleId(vehicleId)
db.DeleteFillupByVehicleId(vehicleId)
return db.DeleteVehicleById(vehicleId)
}
func ShareVehicle(vehicleId, userId string) error {
return db.ShareVehicle(vehicleId, userId)
}