2014-02-12 21:49:46 +04:00
// Copyright 2014 The Gogs Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package models
2014-02-13 19:23:23 +04:00
2014-02-19 02:48:02 +04:00
import (
"fmt"
"os"
2014-03-21 09:09:22 +04:00
"path"
2014-02-19 02:48:02 +04:00
_ "github.com/go-sql-driver/mysql"
2014-03-17 22:03:58 +04:00
_ "github.com/lib/pq"
2014-02-19 02:48:02 +04:00
"github.com/lunny/xorm"
2014-03-31 00:01:50 +04:00
// _ "github.com/mattn/go-sqlite3"
2014-02-19 02:48:02 +04:00
2014-03-08 02:22:15 +04:00
"github.com/gogits/gogs/modules/base"
2014-02-19 02:48:02 +04:00
)
2014-02-13 19:23:23 +04:00
2014-03-21 09:48:10 +04:00
var (
2014-03-30 18:47:08 +04:00
orm * xorm . Engine
HasEngine bool
2014-03-21 09:48:10 +04:00
2014-03-21 11:27:59 +04:00
DbCfg struct {
2014-03-21 09:48:10 +04:00
Type , Host , Name , User , Pwd , Path , SslMode string
}
2014-03-31 00:01:50 +04:00
UseSQLite3 bool
2014-03-21 09:48:10 +04:00
)
func LoadModelsConfig ( ) {
2014-03-21 11:27:59 +04:00
DbCfg . Type = base . Cfg . MustValue ( "database" , "DB_TYPE" )
2014-03-31 00:01:50 +04:00
if DbCfg . Type == "sqlite3" {
UseSQLite3 = true
}
2014-03-21 11:27:59 +04:00
DbCfg . Host = base . Cfg . MustValue ( "database" , "HOST" )
DbCfg . Name = base . Cfg . MustValue ( "database" , "NAME" )
DbCfg . User = base . Cfg . MustValue ( "database" , "USER" )
DbCfg . Pwd = base . Cfg . MustValue ( "database" , "PASSWD" )
DbCfg . SslMode = base . Cfg . MustValue ( "database" , "SSL_MODE" )
DbCfg . Path = base . Cfg . MustValue ( "database" , "PATH" , "data/gogs.db" )
2014-03-21 09:48:10 +04:00
}
2014-02-19 02:48:02 +04:00
2014-03-30 18:47:08 +04:00
func NewTestEngine ( x * xorm . Engine ) ( err error ) {
switch DbCfg . Type {
case "mysql" :
x , err = xorm . NewEngine ( "mysql" , fmt . Sprintf ( "%s:%s@tcp(%s)/%s?charset=utf8" ,
DbCfg . User , DbCfg . Pwd , DbCfg . Host , DbCfg . Name ) )
case "postgres" :
x , err = xorm . NewEngine ( "postgres" , fmt . Sprintf ( "user=%s password=%s dbname=%s sslmode=%s" ,
DbCfg . User , DbCfg . Pwd , DbCfg . Name , DbCfg . SslMode ) )
2014-03-30 19:09:59 +04:00
// case "sqlite3":
// os.MkdirAll(path.Dir(DbCfg.Path), os.ModePerm)
// x, err = xorm.NewEngine("sqlite3", DbCfg.Path)
2014-03-30 18:47:08 +04:00
default :
return fmt . Errorf ( "Unknown database type: %s\n" , DbCfg . Type )
}
if err != nil {
return fmt . Errorf ( "models.init(fail to conntect database): %v\n" , err )
}
return x . Sync ( new ( User ) , new ( PublicKey ) , new ( Repository ) , new ( Watch ) ,
new ( Action ) , new ( Access ) , new ( Issue ) , new ( Comment ) )
}
2014-03-30 01:50:51 +04:00
func SetEngine ( ) ( err error ) {
2014-03-21 11:27:59 +04:00
switch DbCfg . Type {
2014-02-19 02:48:02 +04:00
case "mysql" :
2014-03-29 09:40:22 +04:00
orm , err = xorm . NewEngine ( "mysql" , fmt . Sprintf ( "%s:%s@tcp(%s)/%s?charset=utf8" ,
2014-03-21 11:27:59 +04:00
DbCfg . User , DbCfg . Pwd , DbCfg . Host , DbCfg . Name ) )
2014-03-17 22:03:58 +04:00
case "postgres" :
orm , err = xorm . NewEngine ( "postgres" , fmt . Sprintf ( "user=%s password=%s dbname=%s sslmode=%s" ,
2014-03-21 11:27:59 +04:00
DbCfg . User , DbCfg . Pwd , DbCfg . Name , DbCfg . SslMode ) )
2014-03-21 09:09:22 +04:00
case "sqlite3" :
2014-03-21 11:27:59 +04:00
os . MkdirAll ( path . Dir ( DbCfg . Path ) , os . ModePerm )
orm , err = xorm . NewEngine ( "sqlite3" , DbCfg . Path )
2014-02-19 02:48:02 +04:00
default :
2014-03-30 01:50:51 +04:00
return fmt . Errorf ( "Unknown database type: %s\n" , DbCfg . Type )
2014-02-19 02:48:02 +04:00
}
if err != nil {
2014-03-30 01:50:51 +04:00
return fmt . Errorf ( "models.init(fail to conntect database): %v\n" , err )
2014-02-19 02:48:02 +04:00
}
2014-03-21 00:04:56 +04:00
// WARNNING: for serv command, MUST remove the output to os.stdout,
// so use log file to instead print to stdout.
2014-03-31 17:26:15 +04:00
execDir , _ := base . ExecDir ( )
logPath := execDir + "/log/xorm.log"
os . MkdirAll ( path . Dir ( logPath ) , os . ModePerm )
2014-02-25 10:01:52 +04:00
2014-03-31 17:26:15 +04:00
f , err := os . Create ( logPath )
2014-03-17 22:03:58 +04:00
if err != nil {
2014-03-30 01:50:51 +04:00
return fmt . Errorf ( "models.init(fail to create xorm.log): %v\n" , err )
2014-03-17 22:03:58 +04:00
}
2014-02-25 11:28:04 +04:00
orm . Logger = f
2014-03-31 17:26:15 +04:00
2014-02-25 11:28:04 +04:00
orm . ShowSQL = true
2014-03-31 17:26:15 +04:00
orm . ShowDebug = true
orm . ShowErr = true
2014-03-30 01:50:51 +04:00
return nil
2014-02-19 02:48:02 +04:00
}
2014-03-30 01:50:51 +04:00
func NewEngine ( ) ( err error ) {
if err = SetEngine ( ) ; err != nil {
return err
} else if err = orm . Sync ( new ( User ) , new ( PublicKey ) , new ( Repository ) , new ( Watch ) ,
2014-03-26 20:31:01 +04:00
new ( Action ) , new ( Access ) , new ( Issue ) , new ( Comment ) ) ; err != nil {
2014-03-30 01:50:51 +04:00
return fmt . Errorf ( "sync database struct error: %v\n" , err )
2014-02-19 13:50:53 +04:00
}
2014-03-30 01:50:51 +04:00
return nil
2014-02-19 02:48:02 +04:00
}
2014-03-21 00:04:56 +04:00
type Statistic struct {
Counter struct {
User , PublicKey , Repo , Watch , Action , Access int64
}
}
func GetStatistic ( ) ( stats Statistic ) {
stats . Counter . User , _ = orm . Count ( new ( User ) )
stats . Counter . PublicKey , _ = orm . Count ( new ( PublicKey ) )
stats . Counter . Repo , _ = orm . Count ( new ( Repository ) )
stats . Counter . Watch , _ = orm . Count ( new ( Watch ) )
stats . Counter . Action , _ = orm . Count ( new ( Action ) )
stats . Counter . Access , _ = orm . Count ( new ( Access ) )
2014-03-23 12:31:13 +04:00
return
2014-03-21 00:04:56 +04:00
}