mirror of
https://github.com/thomiceli/opengist.git
synced 2025-01-05 17:02:39 +00:00
Decrement fork counter on gist/user delete
This commit is contained in:
parent
1607d8fc93
commit
0f42ef01b0
3 changed files with 48 additions and 20 deletions
|
@ -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").
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue