package main import ( "fmt" "upper.io/db.v3/lib/sqlbuilder" "upper.io/db.v3/mysql" "upper.io/db.v3/postgresql" "upper.io/db.v3/sqlite" ) var ( dbServer string sqliteSettings sqlite.ConnectionURL postgresSettings postgresql.ConnectionURL mysqlSettings mysql.ConnectionURL dbSession sqlbuilder.Database ) func DbConnection(dbType string) error { var err error if dbType == "sqlite" { sqliteSettings = sqlite.ConnectionURL{ Database: "statup.db", } dbSession, err = sqlite.Open(sqliteSettings) if err != nil { return err } } else if dbType == "mysql" { if configs.Port == "" { configs.Port = "3306" } mysqlSettings = mysql.ConnectionURL{ Database: configs.Database, Host: configs.Host, User: configs.User, Password: configs.Password, } dbSession, err = mysql.Open(mysqlSettings) if err != nil { return err } } else { if configs.Port == "" { configs.Port = "5432" } host := fmt.Sprintf("%v:%v", configs.Host, configs.Port) postgresSettings = postgresql.ConnectionURL{ Database: configs.Database, Host: host, User: configs.User, Password: configs.Password, } dbSession, err = postgresql.Open(postgresSettings) if err != nil { return err } } //dbSession.SetLogging(true) dbServer = dbType OnLoad(dbSession) return err }