-
Notifications
You must be signed in to change notification settings - Fork 499
/
migrate.go
60 lines (50 loc) · 1.23 KB
/
migrate.go
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
52
53
54
55
56
57
58
59
60
package client
import (
"context"
"fmt"
"github.com/cloudquery/plugin-sdk/v4/message"
"github.com/cloudquery/plugin-sdk/v4/schema"
)
func (c *Client) MigrateTables(ctx context.Context, messages message.WriteMigrateTables) error {
c.logger.Info().Msg("Migrate")
have, err := c.indexes()
if err != nil {
return err
}
tables := make(schema.Tables, len(messages))
for i, msg := range messages {
tables[i] = msg.Table
}
want := tablesIndexSchemas(tables)
var recreate, create, update []*indexSchema
for uid, need := range want {
got := have[uid]
switch {
case got == nil:
create = append(create, need)
case got.canMigrate(need):
update = append(update, need)
default:
recreate = append(recreate, need)
if !messages[need.Index].MigrateForce {
return fmt.Errorf("index %s requires force migration. Migrate manually or consider using 'migrate_mode: forced'", uid)
}
}
}
for _, index := range create {
if err := c.createIndex(ctx, index); err != nil {
return err
}
}
for _, index := range update {
if err := c.configureIndex(ctx, index); err != nil {
return err
}
}
for _, index := range recreate {
if err := c.recreateIndex(ctx, index); err != nil {
return err
}
}
return nil
}