gorm/callback_delete.go

64 lines
1.9 KiB
Go
Raw Normal View History

2014-01-26 08:41:37 +04:00
package gorm
import (
"errors"
"fmt"
)
2014-01-26 08:41:37 +04:00
2016-01-17 15:51:11 +03:00
// Define callbacks for deleting
2016-01-17 11:28:32 +03:00
func init() {
DefaultCallback.Delete().Register("gorm:begin_transaction", beginTransactionCallback)
DefaultCallback.Delete().Register("gorm:before_delete", beforeDeleteCallback)
DefaultCallback.Delete().Register("gorm:delete", deleteCallback)
DefaultCallback.Delete().Register("gorm:after_delete", afterDeleteCallback)
DefaultCallback.Delete().Register("gorm:commit_or_rollback_transaction", commitOrRollbackTransactionCallback)
2016-01-17 11:28:32 +03:00
}
2016-01-17 15:51:11 +03:00
// beforeDeleteCallback will invoke `BeforeDelete` method before deleting
2016-01-17 10:30:42 +03:00
func beforeDeleteCallback(scope *Scope) {
if scope.DB().HasBlockGlobalUpdate() && !scope.hasConditions() {
2019-09-12 17:16:52 +03:00
scope.Err(errors.New("missing WHERE clause while deleting"))
return
}
if !scope.HasError() {
scope.CallMethod("BeforeDelete")
}
2014-01-26 08:41:37 +04:00
}
2016-01-17 15:51:11 +03:00
// deleteCallback used to delete data from database or set deleted_at to current time (when using with soft delete)
2016-01-17 10:30:42 +03:00
func deleteCallback(scope *Scope) {
2014-01-26 15:34:06 +04:00
if !scope.HasError() {
var extraOption string
if str, ok := scope.Get("gorm:delete_option"); ok {
extraOption = fmt.Sprint(str)
}
2017-02-01 16:33:36 +03:00
deletedAtField, hasDeletedAtField := scope.FieldByName("DeletedAt")
if !scope.Search.Unscoped && hasDeletedAtField {
scope.Raw(fmt.Sprintf(
2017-02-01 16:33:36 +03:00
"UPDATE %v SET %v=%v%v%v",
scope.QuotedTableName(),
2017-02-01 16:33:36 +03:00
scope.Quote(deletedAtField.DBName),
scope.AddToVars(scope.db.nowFunc()),
addExtraSpaceIfExist(scope.CombinedConditionSql()),
addExtraSpaceIfExist(extraOption),
)).Exec()
2014-01-26 15:34:06 +04:00
} else {
scope.Raw(fmt.Sprintf(
"DELETE FROM %v%v%v",
scope.QuotedTableName(),
addExtraSpaceIfExist(scope.CombinedConditionSql()),
addExtraSpaceIfExist(extraOption),
)).Exec()
2014-01-26 15:34:06 +04:00
}
2014-01-26 08:41:37 +04:00
}
}
2016-01-17 15:51:11 +03:00
// afterDeleteCallback will invoke `AfterDelete` method after deleting
2016-01-17 10:30:42 +03:00
func afterDeleteCallback(scope *Scope) {
if !scope.HasError() {
scope.CallMethod("AfterDelete")
}
2014-01-26 08:41:37 +04:00
}