2020-10-16 22:27:16 +02:00
|
|
|
package sqlstore
|
|
|
|
|
|
|
|
import (
|
2021-04-17 09:06:57 +02:00
|
|
|
"bytes"
|
2020-10-22 13:34:42 +02:00
|
|
|
"errors"
|
2021-04-17 09:06:57 +02:00
|
|
|
"fmt"
|
|
|
|
"io"
|
|
|
|
"io/ioutil"
|
2020-11-19 17:51:39 +01:00
|
|
|
"os"
|
2021-04-17 09:06:57 +02:00
|
|
|
"text/template"
|
2020-10-22 13:34:42 +02:00
|
|
|
|
2020-10-16 22:27:16 +02:00
|
|
|
"github.com/golang-migrate/migrate/v4"
|
|
|
|
"github.com/golang-migrate/migrate/v4/database"
|
|
|
|
"github.com/golang-migrate/migrate/v4/database/postgres"
|
|
|
|
"github.com/golang-migrate/migrate/v4/database/sqlite3"
|
2021-04-17 09:06:57 +02:00
|
|
|
"github.com/golang-migrate/migrate/v4/source"
|
2020-10-16 22:27:16 +02:00
|
|
|
_ "github.com/golang-migrate/migrate/v4/source/file"
|
2020-10-18 01:09:12 +02:00
|
|
|
bindata "github.com/golang-migrate/migrate/v4/source/go_bindata"
|
2020-10-16 22:27:16 +02:00
|
|
|
_ "github.com/lib/pq"
|
2021-04-20 11:27:20 +02:00
|
|
|
"github.com/mattermost/focalboard/server/services/store/sqlstore/migrations"
|
2020-10-16 22:27:16 +02:00
|
|
|
)
|
|
|
|
|
2021-04-17 09:06:57 +02:00
|
|
|
type PrefixedMigration struct {
|
|
|
|
*bindata.Bindata
|
2021-04-20 11:27:20 +02:00
|
|
|
prefix string
|
|
|
|
postgres bool
|
|
|
|
sqlite bool
|
2021-04-17 09:06:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
source.Register("prefixed-migrations", &PrefixedMigration{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (pm *PrefixedMigration) ReadUp(version uint) (io.ReadCloser, string, error) {
|
|
|
|
r, identifier, err := pm.Bindata.ReadUp(version)
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
data, err := ioutil.ReadAll(r)
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
tmpl, err := template.New("sql").Parse(string(data))
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
buffer := bytes.NewBufferString("")
|
2021-04-20 11:27:20 +02:00
|
|
|
err = tmpl.Execute(buffer, map[string]interface{}{"prefix": pm.prefix, "postgres": pm.postgres, "sqlite": pm.sqlite})
|
2021-04-17 09:06:57 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
2021-04-17 10:05:07 +02:00
|
|
|
return ioutil.NopCloser(bytes.NewReader(buffer.Bytes())), identifier, nil
|
2021-04-17 09:06:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (pm *PrefixedMigration) ReadDown(version uint) (io.ReadCloser, string, error) {
|
|
|
|
r, identifier, err := pm.Bindata.ReadDown(version)
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
data, err := ioutil.ReadAll(r)
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
tmpl, err := template.New("sql").Parse(string(data))
|
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
|
|
|
buffer := bytes.NewBufferString("")
|
2021-04-20 11:27:20 +02:00
|
|
|
err = tmpl.Execute(buffer, map[string]interface{}{"prefix": pm.prefix, "postgres": pm.postgres, "sqlite": pm.sqlite})
|
2021-04-17 09:06:57 +02:00
|
|
|
if err != nil {
|
|
|
|
return nil, "", err
|
|
|
|
}
|
2021-04-17 10:05:07 +02:00
|
|
|
return ioutil.NopCloser(bytes.NewReader(buffer.Bytes())), identifier, nil
|
2021-04-17 09:06:57 +02:00
|
|
|
}
|
|
|
|
|
2020-10-16 22:27:16 +02:00
|
|
|
func (s *SQLStore) Migrate() error {
|
|
|
|
var driver database.Driver
|
|
|
|
var err error
|
2021-04-17 09:06:57 +02:00
|
|
|
migrationsTable := fmt.Sprintf("%sschema_migrations", s.tablePrefix)
|
2020-10-22 13:34:42 +02:00
|
|
|
|
2020-10-16 22:27:16 +02:00
|
|
|
if s.dbType == "sqlite3" {
|
2021-04-17 09:06:57 +02:00
|
|
|
driver, err = sqlite3.WithInstance(s.db, &sqlite3.Config{MigrationsTable: migrationsTable})
|
2020-10-18 02:07:35 +02:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-10-16 22:27:16 +02:00
|
|
|
}
|
2020-10-22 13:34:42 +02:00
|
|
|
|
2020-10-16 22:27:16 +02:00
|
|
|
if s.dbType == "postgres" {
|
2021-04-17 09:06:57 +02:00
|
|
|
driver, err = postgres.WithInstance(s.db, &postgres.Config{MigrationsTable: migrationsTable})
|
2020-10-18 02:07:35 +02:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2020-10-18 01:09:12 +02:00
|
|
|
}
|
|
|
|
|
2021-04-20 11:27:20 +02:00
|
|
|
bresource := bindata.Resource(migrations.AssetNames(), migrations.Asset)
|
|
|
|
|
2020-10-18 01:09:12 +02:00
|
|
|
d, err := bindata.WithInstance(bresource)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2020-10-16 22:27:16 +02:00
|
|
|
}
|
2021-04-17 09:06:57 +02:00
|
|
|
prefixedData := &PrefixedMigration{
|
2021-04-20 11:27:20 +02:00
|
|
|
Bindata: d.(*bindata.Bindata),
|
|
|
|
prefix: s.tablePrefix,
|
|
|
|
postgres: s.dbType == "postgres",
|
|
|
|
sqlite: s.dbType == "sqlite3",
|
2021-04-17 09:06:57 +02:00
|
|
|
}
|
2020-10-18 01:09:12 +02:00
|
|
|
|
2021-04-17 09:06:57 +02:00
|
|
|
m, err := migrate.NewWithInstance("prefixed-migration", prefixedData, s.dbType, driver)
|
2020-10-16 22:27:16 +02:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
err = m.Up()
|
2020-11-19 17:51:39 +01:00
|
|
|
if err != nil && !errors.Is(err, migrate.ErrNoChange) && !errors.Is(err, os.ErrNotExist) {
|
2020-10-16 22:27:16 +02:00
|
|
|
return err
|
|
|
|
}
|
2020-10-22 13:34:42 +02:00
|
|
|
|
2020-10-16 22:27:16 +02:00
|
|
|
return nil
|
|
|
|
}
|