Decrement fork counter on gist/user delete

This commit is contained in:
Thomas Miceli 2023-03-15 00:52:24 +01:00
parent 1607d8fc93
commit 0f42ef01b0
No known key found for this signature in database
GPG key ID: D86C6F6390AF050F
3 changed files with 48 additions and 20 deletions

View file

@ -1,6 +1,7 @@
package models package models
import ( import (
"gorm.io/gorm"
"time" "time"
) )
@ -41,6 +42,15 @@ type Commit struct {
Files []File Files []File
} }
func (g *Gist) BeforeDelete(tx *gorm.DB) error {
// Decrement fork counter if the gist was forked
err := tx.Model(&Gist{}).
Omit("updated_at").
Where("id = ?", g.ForkedID).
UpdateColumn("nb_forks", gorm.Expr("nb_forks - 1")).Error
return err
}
func GetGist(user string, gistUuid string) (*Gist, error) { func GetGist(user string, gistUuid string) (*Gist, error) {
gist := new(Gist) gist := new(Gist)
err := db.Preload("User").Preload("Forked.User"). err := db.Preload("User").Preload("Forked.User").
@ -141,10 +151,6 @@ func IncrementGistForkCount(gist *Gist) error {
return db.Model(&gist).Omit("updated_at").Update("nb_forks", gist.NbForks+1).Error return db.Model(&gist).Omit("updated_at").Update("nb_forks", gist.NbForks+1).Error
} }
func DecrementGistForkCount(gist *Gist) error {
return db.Model(&gist).Omit("updated_at").Update("nb_forks", gist.NbForks-1).Error
}
func GetForkedGist(gist *Gist, user *User) (*Gist, error) { func GetForkedGist(gist *Gist, user *User) (*Gist, error) {
fork := new(Gist) fork := new(Gist)
err := db.Preload("User"). err := db.Preload("User").

View file

@ -1,6 +1,9 @@
package models package models
import "gorm.io/gorm" import (
"gorm.io/gorm"
"strconv"
)
type User struct { type User struct {
ID uint `gorm:"primaryKey"` ID uint `gorm:"primaryKey"`
@ -14,6 +17,34 @@ type User struct {
Liked []Gist `gorm:"many2many:likes;constraint:OnUpdate:CASCADE,OnDelete:CASCADE"` Liked []Gist `gorm:"many2many:likes;constraint:OnUpdate:CASCADE,OnDelete:CASCADE"`
} }
func (u *User) BeforeDelete(tx *gorm.DB) error {
// Decrement likes counter for all gists liked by this user
// The likes will be automatically deleted by the foreign key constraint
err := tx.Model(&Gist{}).
Omit("updated_at").
Where("id IN (?)", tx.
Select("gist_id").
Table("likes").
Where("user_id = ?", u.ID),
).
UpdateColumn("nb_likes", gorm.Expr("nb_likes - 1")).
Error
if err != nil {
return err
}
// Decrement forks counter for all gists forked by this user
return tx.Model(&Gist{}).
Omit("updated_at").
Where("id IN (?)", tx.
Select("forked_id").
Table("gists").
Where("user_id = ?", u.ID),
).
UpdateColumn("nb_forks", gorm.Expr("nb_forks - 1")).
Error
}
func DoesUserExists(userName string, count *int64) error { func DoesUserExists(userName string, count *int64) error {
return db.Table("users"). return db.Table("users").
Where("username like ?", userName). Where("username like ?", userName).
@ -47,23 +78,14 @@ func CreateUser(user *User) error {
return db.Create(&user).Error return db.Create(&user).Error
} }
func DeleteUserByID(userid string) error { func DeleteUser(userid string) error {
// Decrement likes counter for all gists liked by this user // trigger hook with a user ID
// The likes will be automatically deleted by the foreign key constraint intId, err := strconv.ParseUint(userid, 10, 64)
err := db.Model(&Gist{}).
Omit("updated_at").
Where("id IN (?)", db.
Select("gist_id").
Table("likes").
Where("user_id = ?", userid),
).
UpdateColumn("nb_likes", gorm.Expr("nb_likes - 1")).
Error
if err != nil { if err != nil {
return err return err
} }
var user = &User{ID: uint(intId)}
return db.Delete(&User{}, "id = ?", userid).Error return db.Where("id = ?", userid).Delete(&user).Error
} }
func SetAdminUser(user *User) error { func SetAdminUser(user *User) error {

View file

@ -78,7 +78,7 @@ func adminGists(ctx echo.Context) error {
} }
func adminUserDelete(ctx echo.Context) error { func adminUserDelete(ctx echo.Context) error {
if err := models.DeleteUserByID(ctx.Param("user")); err != nil { if err := models.DeleteUser(ctx.Param("user")); err != nil {
return errorRes(500, "Cannot delete this user", err) return errorRes(500, "Cannot delete this user", err)
} }