mirror of
https://github.com/ehrudxo/GoMap.git
synced 2025-05-03 05:59:53 +00:00
58 lines
1.2 KiB
Go
58 lines
1.2 KiB
Go
package controllers
|
|
import (
|
|
"database/sql"
|
|
"github.com/jinzhu/gorm"
|
|
_ "github.com/lib/pq"
|
|
"github.com/revel/revel"
|
|
"github.com/ehrudxo/revel_test1/app/models"
|
|
)
|
|
type GormController struct {
|
|
*revel.Controller
|
|
Tx *gorm.DB
|
|
}
|
|
var Db gorm.DB
|
|
func InitDB() {
|
|
var err error
|
|
Db, err = gorm.Open("postgres", "user=gouser dbname=postgres password=go1234 sslmode=disable")
|
|
if err != nil {
|
|
revel.ERROR.Println("FATAL", err)
|
|
panic(err)
|
|
}
|
|
tab := &models.User{}
|
|
Db.AutoMigrate(tab)
|
|
Db.Model(tab).AddUniqueIndex("idx_user__mail", "mail")
|
|
}
|
|
func (c *GormController) Begin() revel.Result {
|
|
txn := Db.Begin()
|
|
if txn.Error != nil {
|
|
panic(txn.Error)
|
|
}
|
|
c.Tx = txn
|
|
revel.INFO.Println("c.Tx init", c.Tx)
|
|
return nil
|
|
}
|
|
func (c *GormController) Commit() revel.Result {
|
|
if c.Tx == nil {
|
|
return nil
|
|
}
|
|
c.Tx.Commit()
|
|
if err := c.Tx.Error; err != nil && err != sql.ErrTxDone {
|
|
panic(err)
|
|
}
|
|
c.Tx = nil
|
|
revel.INFO.Println("c.Tx commited (nil)")
|
|
return nil
|
|
}
|
|
|
|
func (c *GormController) Rollback() revel.Result {
|
|
if c.Tx == nil {
|
|
return nil
|
|
}
|
|
c.Tx.Rollback()
|
|
if err := c.Tx.Error; err != nil && err != sql.ErrTxDone {
|
|
panic(err)
|
|
}
|
|
c.Tx = nil
|
|
return nil
|
|
}
|