2018-06-24 16:40:48 +03:00
|
|
|
package database
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
import (
|
|
|
|
"sort"
|
|
|
|
|
2021-06-16 14:44:15 +03:00
|
|
|
"github.com/hasura/graphql-engine/cli/v2/internal/statestore"
|
2021-02-17 07:20:19 +03:00
|
|
|
|
2021-06-16 14:44:15 +03:00
|
|
|
"github.com/hasura/graphql-engine/cli/v2/internal/hasura"
|
2021-01-18 20:11:05 +03:00
|
|
|
)
|
2018-06-24 16:40:48 +03:00
|
|
|
|
|
|
|
// Migrations wraps Migration and has an internal index
|
|
|
|
// to keep track of Migration order in database.
|
|
|
|
type Migrations struct {
|
2021-01-18 20:11:05 +03:00
|
|
|
index migrationVersions
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewMigrations() *Migrations {
|
|
|
|
return &Migrations{
|
2021-01-18 20:11:05 +03:00
|
|
|
index: make(migrationVersions, 0),
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) Append(migrationVersion MigrationVersion) {
|
|
|
|
if m.findPos(migrationVersion.Version) > 0 {
|
2018-06-24 16:40:48 +03:00
|
|
|
return
|
|
|
|
}
|
2021-01-18 20:11:05 +03:00
|
|
|
m.index = append(m.index, migrationVersion)
|
|
|
|
|
|
|
|
sort.Slice(m.index, func(i, j int) bool {
|
|
|
|
return m.index[i].Version < m.index[j].Version
|
|
|
|
})
|
|
|
|
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) First() (migrationVersion *MigrationVersion, ok bool) {
|
|
|
|
if len(m.index) == 0 {
|
|
|
|
return nil, false
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
2021-01-18 20:11:05 +03:00
|
|
|
return &m.index[0], true
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) Last() (*MigrationVersion, bool) {
|
|
|
|
if len(m.index) == 0 {
|
|
|
|
return nil, false
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
return &m.index[len(m.index)-1], true
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) Prev(version uint64) (prevVersion *MigrationVersion, ok bool) {
|
|
|
|
pos := m.findPos(version)
|
|
|
|
if pos >= 1 && len(m.index) > pos-1 {
|
|
|
|
return &m.index[pos-1], true
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
2021-01-18 20:11:05 +03:00
|
|
|
return nil, false
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) Next(version uint64) (migrationVersion *MigrationVersion, ok bool) {
|
|
|
|
pos := m.findPos(version)
|
|
|
|
if pos >= 0 && len(m.index) > pos+1 {
|
|
|
|
return &m.index[pos+1], true
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
2021-01-18 20:11:05 +03:00
|
|
|
return nil, false
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) Read(version uint64) (ok bool) {
|
|
|
|
pos := m.findPos(version)
|
2021-10-13 17:38:07 +03:00
|
|
|
return pos >= 0
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (m *Migrations) findPos(version uint64) int {
|
|
|
|
if len(m.index) > 0 {
|
|
|
|
ix := m.index.Search(version)
|
|
|
|
if ix < len(m.index) && m.index[ix].Version == version {
|
2018-06-24 16:40:48 +03:00
|
|
|
return ix
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1
|
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
type MigrationVersion struct {
|
|
|
|
Version uint64
|
|
|
|
Dirty bool
|
|
|
|
}
|
2018-06-24 16:40:48 +03:00
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
type migrationVersions []MigrationVersion
|
|
|
|
|
|
|
|
func (s migrationVersions) Len() int {
|
2018-06-24 16:40:48 +03:00
|
|
|
return len(s)
|
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (s migrationVersions) Swap(i, j int) {
|
2018-06-24 16:40:48 +03:00
|
|
|
s[i], s[j] = s[j], s[i]
|
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
func (s migrationVersions) Less(i, j int) bool {
|
|
|
|
return s[i].Version < s[j].Version
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s migrationVersions) Search(x uint64) int {
|
|
|
|
return sort.Search(len(s), func(i int) bool { return s[i].Version >= x })
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|
|
|
|
|
2021-01-18 20:11:05 +03:00
|
|
|
type HasuraOpts struct {
|
|
|
|
HasMetadataV3 bool
|
2021-03-08 14:59:35 +03:00
|
|
|
SourceName string
|
|
|
|
SourceKind hasura.SourceKind
|
|
|
|
|
|
|
|
Client *hasura.Client
|
|
|
|
|
|
|
|
PGSourceOps hasura.PGSourceOps
|
|
|
|
MSSQLSourceOps hasura.MSSQLSourceOps
|
2021-06-21 17:34:10 +03:00
|
|
|
CitusSourceOps hasura.CitusSourceOps
|
2021-03-08 14:59:35 +03:00
|
|
|
MetadataOps hasura.CommonMetadataOperations
|
|
|
|
V2MetadataOps hasura.V2CommonMetadataOperations
|
|
|
|
GenericQueryRequest hasura.GenericSend
|
2022-02-04 14:10:33 +03:00
|
|
|
PGDumpClient hasura.PGDump
|
2021-02-17 07:20:19 +03:00
|
|
|
|
|
|
|
MigrationsStateStore statestore.MigrationsStateStore
|
|
|
|
SettingsStateStore statestore.SettingsStateStore
|
2018-06-24 16:40:48 +03:00
|
|
|
}
|