about summary refs log tree commit diff
path: root/src/db/schema.go
blob: 9d7e31ef903ca6b1cde9101f7fe9ff6bbb734321 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package db

import (
	"git.darknebu.la/chaosdorf/freitagsfoo/src/structs"
	pg "github.com/go-pg/pg/v9"
	orm "github.com/go-pg/pg/v9/orm"
	"github.com/sirupsen/logrus"
)

// CreateSchema creates the defined schemas in the database
func CreateSchema(db *pg.DB) error {
	// define the models
	models := []interface{}{
		(*structs.Talk)(nil),
	}

	// create a table for each model defined above
	for i, model := range models {

		err := db.CreateTable(model, &orm.CreateTableOptions{
			IfNotExists: true,
		})
		if err != nil {
			return err
		}
		logrus.Tracef("\t Created the %T table", models[i])
	}

	return nil
}

// DeleteAllTables deletes all tables in the given database
func DeleteAllTables(db *pg.DB) error {
	// define the models
	models := []interface{}{
		(*structs.Talk)(nil),
	}

	// delete all models
	for i, model := range models {
		err := db.DropTable(model, &orm.DropTableOptions{
			IfExists: true,
		})
		if err != nil {
			return err
		}
		logrus.Tracef("\t Deleted the %T table", models[i])
	}

	return nil
}