2018-08-16 06:22:20 +00:00
|
|
|
// Statup
|
|
|
|
// Copyright (C) 2018. Hunter Long and the project contributors
|
|
|
|
// Written by Hunter Long <info@socialeck.com> and the project contributors
|
|
|
|
//
|
|
|
|
// https://github.com/hunterlong/statup
|
|
|
|
//
|
|
|
|
// The licenses for most software and other practical works are designed
|
|
|
|
// to take away your freedom to share and change the works. By contrast,
|
|
|
|
// the GNU General Public License is intended to guarantee your freedom to
|
|
|
|
// share and change all versions of a program--to make sure it remains free
|
|
|
|
// software for all its users.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2018-06-30 00:57:05 +00:00
|
|
|
package core
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2018-09-05 10:54:57 +00:00
|
|
|
_ "github.com/go-sql-driver/mysql"
|
2018-06-30 00:57:05 +00:00
|
|
|
"github.com/go-yaml/yaml"
|
2018-09-05 10:54:57 +00:00
|
|
|
"github.com/hunterlong/statup/notifiers"
|
2018-08-10 04:38:54 +00:00
|
|
|
"github.com/hunterlong/statup/source"
|
2018-06-30 00:57:05 +00:00
|
|
|
"github.com/hunterlong/statup/types"
|
|
|
|
"github.com/hunterlong/statup/utils"
|
2018-09-05 10:54:57 +00:00
|
|
|
"github.com/jinzhu/gorm"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/mssql"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/mysql"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/postgres"
|
|
|
|
_ "github.com/jinzhu/gorm/dialects/sqlite"
|
|
|
|
_ "github.com/lib/pq"
|
|
|
|
_ "github.com/mattn/go-sqlite3"
|
2018-06-30 00:57:05 +00:00
|
|
|
"os"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2018-09-05 10:54:57 +00:00
|
|
|
DbSession *gorm.DB
|
2018-07-06 03:01:03 +00:00
|
|
|
currentMigration int64
|
2018-06-30 00:57:05 +00:00
|
|
|
)
|
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func failuresDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Model(&types.Failure{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Model(&types.Failure{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Service) allHits() *gorm.DB {
|
|
|
|
var hits []*Hit
|
|
|
|
return servicesDB().Find(s).Related(&hits)
|
|
|
|
}
|
|
|
|
|
|
|
|
func hitsDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Model(&types.Hit{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Model(&types.Hit{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func servicesDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Model(&types.Service{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Model(&types.Service{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func coreDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Table("core").Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Table("core")
|
|
|
|
}
|
|
|
|
|
|
|
|
func usersDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Model(&types.User{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Model(&types.User{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func commDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Table("communication").Model(¬ifiers.Notification{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Table("communication").Model(¬ifiers.Notification{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func checkinDB() *gorm.DB {
|
|
|
|
if os.Getenv("GO_ENV") == "TEST" {
|
|
|
|
return DbSession.Model(&types.Checkin{}).Debug()
|
|
|
|
}
|
|
|
|
return DbSession.Model(&types.Checkin{})
|
|
|
|
}
|
|
|
|
|
2018-08-19 08:48:02 +00:00
|
|
|
type DbConfig struct {
|
|
|
|
*types.DbConfig
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (db *DbConfig) Close() error {
|
|
|
|
return DbSession.Close()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DbConfig) InsertCore() (*Core, error) {
|
|
|
|
CoreApp = &Core{Core: &types.Core{
|
|
|
|
Name: db.Project,
|
|
|
|
Description: db.Description,
|
|
|
|
Config: "config.yml",
|
|
|
|
ApiKey: utils.NewSHA1Hash(9),
|
|
|
|
ApiSecret: utils.NewSHA1Hash(16),
|
|
|
|
Domain: db.Domain,
|
|
|
|
MigrationId: time.Now().Unix(),
|
|
|
|
}}
|
|
|
|
CoreApp.DbConnection = db.DbConn
|
|
|
|
query := coreDB().Create(&CoreApp)
|
|
|
|
return CoreApp, query.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DbConfig) Connect(retry bool, location string) error {
|
2018-06-30 00:57:05 +00:00
|
|
|
var err error
|
2018-09-05 10:54:57 +00:00
|
|
|
if DbSession != nil {
|
|
|
|
DbSession = nil
|
|
|
|
}
|
|
|
|
switch Configs.DbConn {
|
|
|
|
case "sqlite":
|
|
|
|
DbSession, err = gorm.Open("sqlite3", utils.Directory+"/statup.db")
|
2018-06-30 00:57:05 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
case "mysql":
|
|
|
|
if Configs.DbPort == 0 {
|
|
|
|
Configs.DbPort = 3306
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
host := fmt.Sprintf("%v:%v", Configs.DbHost, Configs.DbPort)
|
|
|
|
conn := fmt.Sprintf("%v:%v@tcp(%v)/%v?charset=utf8&parseTime=True&loc=Local", Configs.DbUser, Configs.DbPass, host, Configs.DbData)
|
|
|
|
DbSession, err = gorm.Open("mysql", conn)
|
|
|
|
DbSession.DB().SetConnMaxLifetime(time.Minute * 5)
|
|
|
|
DbSession.DB().SetMaxIdleConns(0)
|
|
|
|
DbSession.DB().SetMaxOpenConns(5)
|
2018-06-30 00:57:05 +00:00
|
|
|
if err != nil {
|
2018-07-20 05:26:41 +00:00
|
|
|
if retry {
|
|
|
|
utils.Log(1, fmt.Sprintf("Database connection to '%v' is not available, trying again in 5 seconds...", host))
|
2018-09-05 10:54:57 +00:00
|
|
|
return db.waitForDb()
|
2018-07-20 05:26:41 +00:00
|
|
|
} else {
|
|
|
|
return err
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
case "postgres":
|
|
|
|
if Configs.DbPort == 0 {
|
|
|
|
Configs.DbPort = 5432
|
|
|
|
}
|
|
|
|
conn := fmt.Sprintf("host=%v port=%v user=%v dbname=%v password=%v sslmode=disable", Configs.DbHost, Configs.DbPort, Configs.DbUser, Configs.DbData, Configs.DbPass)
|
|
|
|
DbSession, err = gorm.Open("postgres", conn)
|
|
|
|
if err != nil {
|
|
|
|
if retry {
|
|
|
|
utils.Log(1, fmt.Sprintf("Database connection to '%v' is not available, trying again in 5 seconds...", Configs.DbHost))
|
|
|
|
return db.waitForDb()
|
|
|
|
} else {
|
|
|
|
fmt.Println("ERROR:", err)
|
|
|
|
return err
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
case "mssql":
|
|
|
|
if Configs.DbPort == 0 {
|
|
|
|
Configs.DbPort = 1433
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
host := fmt.Sprintf("%v:%v", Configs.DbHost, Configs.DbPort)
|
|
|
|
conn := fmt.Sprintf("sqlserver://%v:%v@%v?database=%v", Configs.DbUser, Configs.DbPass, host, Configs.DbData)
|
|
|
|
DbSession, err = gorm.Open("mssql", conn)
|
2018-06-30 00:57:05 +00:00
|
|
|
if err != nil {
|
2018-07-20 05:26:41 +00:00
|
|
|
if retry {
|
|
|
|
utils.Log(1, fmt.Sprintf("Database connection to '%v' is not available, trying again in 5 seconds...", host))
|
2018-09-05 10:54:57 +00:00
|
|
|
return db.waitForDb()
|
2018-07-20 05:26:41 +00:00
|
|
|
} else {
|
|
|
|
return err
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
err = DbSession.DB().Ping()
|
2018-07-06 03:01:03 +00:00
|
|
|
if err == nil {
|
2018-09-05 10:54:57 +00:00
|
|
|
utils.Log(1, fmt.Sprintf("Database connection to '%v' was successful.", Configs.DbData))
|
2018-07-06 03:01:03 +00:00
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (db *DbConfig) waitForDb() error {
|
2018-07-20 05:26:41 +00:00
|
|
|
time.Sleep(5 * time.Second)
|
2018-09-05 10:54:57 +00:00
|
|
|
return db.Connect(true, utils.Directory)
|
2018-07-20 05:26:41 +00:00
|
|
|
}
|
|
|
|
|
2018-06-30 00:57:05 +00:00
|
|
|
func DatabaseMaintence() {
|
2018-07-28 16:44:52 +00:00
|
|
|
for range time.Tick(60 * time.Minute) {
|
|
|
|
utils.Log(1, "Checking for database records older than 7 days...")
|
|
|
|
since := time.Now().AddDate(0, 0, -7)
|
|
|
|
DeleteAllSince("failures", since)
|
|
|
|
DeleteAllSince("hits", since)
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteAllSince(table string, date time.Time) {
|
|
|
|
sql := fmt.Sprintf("DELETE FROM %v WHERE created_at < '%v';", table, date.Format("2006-01-02"))
|
2018-09-05 10:54:57 +00:00
|
|
|
db := DbSession.Raw(sql)
|
|
|
|
defer db.Close()
|
|
|
|
if db.Error != nil {
|
|
|
|
utils.Log(2, db.Error)
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-30 04:49:44 +00:00
|
|
|
func (c *DbConfig) Update() error {
|
|
|
|
var err error
|
|
|
|
config, err := os.Create(utils.Directory + "/config.yml")
|
|
|
|
if err != nil {
|
|
|
|
utils.Log(4, err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
data, err := yaml.Marshal(c.DbConfig)
|
|
|
|
if err != nil {
|
|
|
|
utils.Log(3, err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
config.WriteString(string(data))
|
|
|
|
config.Close()
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (c *DbConfig) Save() (*DbConfig, error) {
|
2018-06-30 00:57:05 +00:00
|
|
|
var err error
|
2018-08-20 03:48:28 +00:00
|
|
|
config, err := os.Create(utils.Directory + "/config.yml")
|
2018-06-30 00:57:05 +00:00
|
|
|
if err != nil {
|
2018-07-01 10:24:35 +00:00
|
|
|
utils.Log(4, err)
|
2018-09-05 10:54:57 +00:00
|
|
|
return nil, err
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
c.ApiKey = utils.NewSHA1Hash(16)
|
|
|
|
c.ApiSecret = utils.NewSHA1Hash(16)
|
2018-08-19 20:07:32 +00:00
|
|
|
data, err := yaml.Marshal(c.DbConfig)
|
2018-06-30 00:57:05 +00:00
|
|
|
if err != nil {
|
2018-07-01 10:24:35 +00:00
|
|
|
utils.Log(3, err)
|
2018-09-05 10:54:57 +00:00
|
|
|
return nil, err
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
config.WriteString(string(data))
|
2018-09-05 10:54:57 +00:00
|
|
|
defer config.Close()
|
|
|
|
return c, err
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (c *DbConfig) CreateCore() *Core {
|
2018-07-17 09:18:20 +00:00
|
|
|
newCore := &types.Core{
|
2018-06-30 00:57:05 +00:00
|
|
|
Name: c.Project,
|
|
|
|
Description: c.Description,
|
|
|
|
Config: "config.yml",
|
2018-09-05 10:54:57 +00:00
|
|
|
ApiKey: c.ApiKey,
|
|
|
|
ApiSecret: c.ApiSecret,
|
2018-06-30 00:57:05 +00:00
|
|
|
Domain: c.Domain,
|
2018-07-06 03:01:03 +00:00
|
|
|
MigrationId: time.Now().Unix(),
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
db := coreDB().Create(&newCore)
|
|
|
|
if db.Error == nil {
|
2018-07-17 09:18:20 +00:00
|
|
|
CoreApp = &Core{Core: newCore}
|
2018-07-01 10:24:35 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
CoreApp, err := SelectCore()
|
2018-07-12 04:49:18 +00:00
|
|
|
if err != nil {
|
|
|
|
utils.Log(4, err)
|
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
return CoreApp
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
|
2018-07-06 03:01:03 +00:00
|
|
|
func versionHigher(migrate int64) bool {
|
|
|
|
if CoreApp.MigrationId < migrate {
|
2018-07-04 09:00:16 +00:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2018-07-06 03:01:03 +00:00
|
|
|
func reverseSlice(s []string) []string {
|
|
|
|
for i, j := 0, len(s)-1; i < j; i, j = i+1, j-1 {
|
|
|
|
s[i], s[j] = s[j], s[i]
|
|
|
|
}
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
2018-07-04 09:00:16 +00:00
|
|
|
func RunDatabaseUpgrades() error {
|
|
|
|
var err error
|
2018-07-06 03:01:03 +00:00
|
|
|
currentMigration, err = SelectLastMigration()
|
2018-07-07 05:02:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2018-07-06 03:01:03 +00:00
|
|
|
utils.Log(1, fmt.Sprintf("Checking for Database Upgrades since #%v", currentMigration))
|
2018-08-10 04:38:54 +00:00
|
|
|
upgrade, _ := source.SqlBox.String(CoreApp.DbConnection + "_upgrade.sql")
|
2018-07-04 09:00:16 +00:00
|
|
|
// parse db version and upgrade file
|
|
|
|
ups := strings.Split(upgrade, "=========================================== ")
|
2018-07-06 03:01:03 +00:00
|
|
|
ups = reverseSlice(ups)
|
2018-07-04 09:00:16 +00:00
|
|
|
var ran int
|
2018-07-06 03:01:03 +00:00
|
|
|
var lastMigration int64
|
2018-07-04 09:00:16 +00:00
|
|
|
for _, v := range ups {
|
|
|
|
if len(v) == 0 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
vers := strings.Split(v, "\n")
|
2018-07-06 03:01:03 +00:00
|
|
|
lastMigration = utils.StringInt(vers[0])
|
2018-07-04 09:00:16 +00:00
|
|
|
data := vers[1:]
|
2018-07-06 03:01:03 +00:00
|
|
|
|
2018-07-04 09:00:16 +00:00
|
|
|
//fmt.Printf("Checking Migration from v%v to v%v - %v\n", CoreApp.Version, version, versionHigher(version))
|
2018-07-06 03:01:03 +00:00
|
|
|
if currentMigration >= lastMigration {
|
2018-07-04 09:00:16 +00:00
|
|
|
continue
|
|
|
|
}
|
2018-07-06 03:01:03 +00:00
|
|
|
utils.Log(1, fmt.Sprintf("Migrating Database from #%v to #%v", currentMigration, lastMigration))
|
2018-07-04 09:00:16 +00:00
|
|
|
for _, m := range data {
|
|
|
|
if m == "" {
|
|
|
|
continue
|
|
|
|
}
|
2018-07-06 03:01:03 +00:00
|
|
|
utils.Log(1, fmt.Sprintf("Running Query: %v", m))
|
2018-09-05 10:54:57 +00:00
|
|
|
db := DbSession.Raw(m)
|
2018-07-06 03:01:03 +00:00
|
|
|
ran++
|
2018-09-05 10:54:57 +00:00
|
|
|
if db.Error != nil {
|
|
|
|
utils.Log(2, db.Error)
|
2018-07-04 09:00:16 +00:00
|
|
|
continue
|
|
|
|
}
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-07-06 03:01:03 +00:00
|
|
|
currentMigration = lastMigration
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-07-04 09:00:16 +00:00
|
|
|
if ran > 0 {
|
2018-07-06 03:01:03 +00:00
|
|
|
utils.Log(1, fmt.Sprintf("Database Upgraded %v queries ran, current #%v", ran, currentMigration))
|
2018-07-04 10:14:00 +00:00
|
|
|
CoreApp, err = SelectCore()
|
2018-07-06 03:01:03 +00:00
|
|
|
if err != nil {
|
2018-09-05 10:54:57 +00:00
|
|
|
return err
|
2018-07-06 03:01:03 +00:00
|
|
|
}
|
|
|
|
CoreApp.MigrationId = currentMigration
|
2018-07-17 09:18:20 +00:00
|
|
|
UpdateCore(CoreApp)
|
2018-07-04 09:00:16 +00:00
|
|
|
}
|
|
|
|
return err
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (db *DbConfig) SeedSchema() (string, string, error) {
|
|
|
|
utils.Log(1, "Seeding Schema Database with Dummy Data...")
|
|
|
|
dir := utils.Directory
|
|
|
|
var cmd string
|
|
|
|
switch db.DbConn {
|
|
|
|
case "sqlite":
|
|
|
|
cmd = fmt.Sprintf("cat %v/source/sql/sqlite_up.sql | sqlite3 %v/statup.db", dir, dir)
|
|
|
|
case "mysql":
|
|
|
|
cmd = fmt.Sprintf("mysql -h %v -P %v -u %v --password=%v %v < %v/source/sql/mysql_up.sql", Configs.DbHost, Configs.DbPort, Configs.DbUser, Configs.DbPass, Configs.DbData, dir)
|
|
|
|
case "postgres":
|
|
|
|
cmd = fmt.Sprintf("PGPASSWORD=%v psql -U %v -h %v -d %v -1 -f %v/source/sql/postgres_up.sql", db.DbPass, db.DbUser, db.DbHost, db.DbData, dir)
|
|
|
|
}
|
|
|
|
out, outErr, err := utils.Command(cmd)
|
2018-07-27 04:45:42 +00:00
|
|
|
if err != nil {
|
2018-09-05 10:54:57 +00:00
|
|
|
return out, outErr, err
|
2018-07-27 04:45:42 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
return out, outErr, err
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DbConfig) SeedDatabase() (string, string, error) {
|
|
|
|
utils.Log(1, "Seeding Database with Dummy Data...")
|
|
|
|
dir := utils.Directory
|
|
|
|
var cmd string
|
|
|
|
switch db.DbConn {
|
|
|
|
case "sqlite":
|
|
|
|
cmd = fmt.Sprintf("cat %v/dev/sqlite_seed.sql | sqlite3 %v/statup.db", dir, dir)
|
|
|
|
case "mysql":
|
|
|
|
cmd = fmt.Sprintf("mysql -h %v -P %v -u %v --password=%v %v < %v/dev/mysql_seed.sql", Configs.DbHost, Configs.DbPort, Configs.DbUser, Configs.DbPass, Configs.DbData, dir)
|
|
|
|
case "postgres":
|
|
|
|
cmd = fmt.Sprintf("PGPASSWORD=%v psql -U %v -h %v -d %v -1 -f %v/dev/postgres_seed.sql", db.DbPass, db.DbUser, db.DbHost, db.DbData, dir)
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
2018-09-05 10:54:57 +00:00
|
|
|
out, outErr, err := utils.Command(cmd)
|
|
|
|
return out, outErr, err
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
|
2018-09-05 10:54:57 +00:00
|
|
|
func (db *DbConfig) DropDatabase() error {
|
|
|
|
utils.Log(1, "Dropping Database Tables...")
|
|
|
|
err := DbSession.DropTableIfExists("checkins")
|
|
|
|
err = DbSession.DropTableIfExists("communication")
|
|
|
|
err = DbSession.DropTableIfExists("core")
|
|
|
|
err = DbSession.DropTableIfExists("failures")
|
|
|
|
err = DbSession.DropTableIfExists("hits")
|
|
|
|
err = DbSession.DropTableIfExists("services")
|
|
|
|
err = DbSession.DropTableIfExists("users")
|
|
|
|
return err.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DbConfig) CreateDatabase() error {
|
2018-07-12 04:49:18 +00:00
|
|
|
utils.Log(1, "Creating Database Tables...")
|
2018-09-05 10:54:57 +00:00
|
|
|
err := DbSession.CreateTable(&types.Checkin{})
|
|
|
|
err = DbSession.Table("communication").CreateTable(¬ifiers.Notification{})
|
|
|
|
err = DbSession.Table("core").CreateTable(&types.Core{})
|
|
|
|
err = DbSession.CreateTable(&types.Failure{})
|
|
|
|
err = DbSession.CreateTable(&types.Hit{})
|
|
|
|
err = DbSession.CreateTable(&types.Service{})
|
|
|
|
err = DbSession.CreateTable(&types.User{})
|
|
|
|
utils.Log(1, "Statup Database Created")
|
|
|
|
return err.Error
|
|
|
|
}
|
|
|
|
|
|
|
|
func (db *DbConfig) MigrateDatabase() error {
|
|
|
|
utils.Log(1, "Migrating Database Tables...")
|
|
|
|
err := DbSession.AutoMigrate(&types.Checkin{})
|
|
|
|
err = DbSession.Table("communication").AutoMigrate(¬ifiers.Notification{})
|
|
|
|
err = DbSession.Table("core").AutoMigrate(&types.Core{})
|
|
|
|
err = DbSession.AutoMigrate(&types.Failure{})
|
|
|
|
err = DbSession.AutoMigrate(&types.Hit{})
|
|
|
|
err = DbSession.AutoMigrate(&types.Service{})
|
|
|
|
err = DbSession.AutoMigrate(&types.User{})
|
|
|
|
utils.Log(1, "Statup Database Migrated")
|
|
|
|
return err.Error
|
2018-06-30 00:57:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *DbConfig) Clean() *DbConfig {
|
|
|
|
if os.Getenv("DB_PORT") != "" {
|
|
|
|
if c.DbConn == "postgres" {
|
|
|
|
c.DbHost = c.DbHost + ":" + os.Getenv("DB_PORT")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return c
|
|
|
|
}
|