gorm/callback_delete.go

43 lines
1.4 KiB
Go
Raw Normal View History

2014-01-26 08:41:37 +04:00
package gorm
import "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 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.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() {
2015-03-12 10:01:59 +03:00
if !scope.Search.Unscoped && scope.HasColumn("DeletedAt") {
2014-01-26 15:34:06 +04:00
scope.Raw(
fmt.Sprintf("UPDATE %v SET deleted_at=%v %v",
2014-06-03 13:15:05 +04:00
scope.QuotedTableName(),
scope.AddToVars(NowFunc()),
2014-01-26 15:34:06 +04:00
scope.CombinedConditionSql(),
2016-01-17 15:51:11 +03:00
)).Exec()
2014-01-26 15:34:06 +04:00
} else {
2016-01-17 15:51:11 +03:00
scope.Raw(fmt.Sprintf("DELETE FROM %v %v", scope.QuotedTableName(), scope.CombinedConditionSql())).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
}