Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Model Col. SchemaVersions and migrations on Cols #2286

Merged
merged 17 commits into from
Feb 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions cli/cli.go
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ func NewDefraCommand(cfg *config.Config) *cobra.Command {
schema_migrate := MakeSchemaMigrationCommand()
schema_migrate.AddCommand(
MakeSchemaMigrationSetCommand(),
MakeSchemaMigrationGetCommand(),
MakeSchemaMigrationSetRegistryCommand(),
MakeSchemaMigrationReloadCommand(),
MakeSchemaMigrationUpCommand(),
MakeSchemaMigrationDownCommand(),
Expand All @@ -58,7 +58,7 @@ func NewDefraCommand(cfg *config.Config) *cobra.Command {
schema.AddCommand(
MakeSchemaAddCommand(),
MakeSchemaPatchCommand(),
MakeSchemaSetDefaultCommand(),
MakeSchemaSetActiveCommand(),
MakeSchemaDescribeCommand(),
schema_migrate,
)
Expand Down
4 changes: 3 additions & 1 deletion cli/collection_describe.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import (
)

func MakeCollectionDescribeCommand() *cobra.Command {
var getInactive bool
var cmd = &cobra.Command{
Use: "describe",
Short: "View collection description.",
Expand All @@ -42,7 +43,7 @@ Example: view collection by version id
return writeJSON(cmd, col.Definition())
}
// if no collection specified list all collections
cols, err := store.GetAllCollections(cmd.Context())
cols, err := store.GetAllCollections(cmd.Context(), getInactive)
if err != nil {
return err
}
Expand All @@ -53,5 +54,6 @@ Example: view collection by version id
return writeJSON(cmd, colDesc)
},
}
cmd.Flags().BoolVar(&getInactive, "get-inactive", false, "Get inactive collections as well as active")
return cmd
}
19 changes: 10 additions & 9 deletions cli/schema_migration_down.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,21 +23,21 @@ import (

func MakeSchemaMigrationDownCommand() *cobra.Command {
var file string
var schemaVersionID string
var collectionID uint32
var cmd = &cobra.Command{
Use: "down --version <version> <documents>",
Short: "Reverses the migration from the specified schema version.",
Long: `Reverses the migration from the specified schema version.
Use: "down --collection <collectionID> <documents>",
Short: "Reverses the migration to the specified collection version.",
Long: `Reverses the migration to the specified collection version.
Documents is a list of documents to reverse the migration from.

Example: migrate from string
defradb client schema migration down --version bae123 '[{"name": "Bob"}]'
defradb client schema migration down --collection 2 '[{"name": "Bob"}]'

Example: migrate from file
defradb client schema migration down --version bae123 -f documents.json
defradb client schema migration down --collection 2 -f documents.json

Example: migrate from stdin
cat documents.json | defradb client schema migration down --version bae123 -
cat documents.json | defradb client schema migration down --collection 2 -
`,
Args: cobra.RangeArgs(0, 1),
RunE: func(cmd *cobra.Command, args []string) error {
Expand Down Expand Up @@ -71,7 +71,8 @@ Example: migrate from stdin
if tx, ok := cmd.Context().Value(txContextKey).(datastore.Txn); ok {
lens = lens.WithTxn(tx)
}
out, err := lens.MigrateDown(cmd.Context(), enumerable.New(src), schemaVersionID)

out, err := lens.MigrateDown(cmd.Context(), enumerable.New(src), collectionID)
if err != nil {
return err
}
Expand All @@ -86,6 +87,6 @@ Example: migrate from stdin
},
}
cmd.Flags().StringVarP(&file, "file", "f", "", "File containing document(s)")
cmd.Flags().StringVar(&schemaVersionID, "version", "", "Schema version id")
cmd.Flags().Uint32Var(&collectionID, "collection", 0, "Collection id")
return cmd
}
38 changes: 0 additions & 38 deletions cli/schema_migration_get.go

This file was deleted.

5 changes: 3 additions & 2 deletions cli/schema_migration_set.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@ func MakeSchemaMigrationSetCommand() *cobra.Command {
var cmd = &cobra.Command{
Use: "set [src] [dst] [cfg]",
Short: "Set a schema migration within DefraDB",
Long: `Set a migration between two schema versions within the local DefraDB node.
Long: `Set a migration from a source schema version to a destination schema version for
all collections that are on the given source schema version within the local DefraDB node.

Example: set from an argument string:
defradb client schema migration set bae123 bae456 '{"lenses": [...'
Expand Down Expand Up @@ -80,7 +81,7 @@ Learn more about the DefraDB GraphQL Schema Language on https://docs.source.netw
Lens: lensCfg,
}

return store.LensRegistry().SetMigration(cmd.Context(), migrationCfg)
return store.SetMigration(cmd.Context(), migrationCfg)
},
}
cmd.Flags().StringVarP(&lensFile, "file", "f", "", "Lens configuration file")
Expand Down
54 changes: 54 additions & 0 deletions cli/schema_migration_set_registry.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
// Copyright 2023 Democratized Data Foundation
//
// Use of this software is governed by the Business Source License
// included in the file licenses/BSL.txt.
//
// As of the Change Date specified in that file, in accordance with
// the Business Source License, use of this software will be governed
// by the Apache License, Version 2.0, included in the file
// licenses/APL.txt.

package cli

import (
"encoding/json"
"strconv"
"strings"

"github.com/lens-vm/lens/host-go/config/model"
"github.com/spf13/cobra"
)

func MakeSchemaMigrationSetRegistryCommand() *cobra.Command {
var cmd = &cobra.Command{
Use: "set-registry [collectionID] [cfg]",
Short: "Set a schema migration within the DefraDB LensRegistry",
Long: `Set a migration to a collection within the LensRegistry of the local DefraDB node.
Does not persist the migration after restart.

Example: set from an argument string:
defradb client schema migration set-registry 2 '{"lenses": [...'

Learn more about the DefraDB GraphQL Schema Language on https://docs.source.network.`,
Args: cobra.ExactArgs(2),
RunE: func(cmd *cobra.Command, args []string) error {
store := mustGetStoreContext(cmd)

decoder := json.NewDecoder(strings.NewReader(args[1]))
decoder.DisallowUnknownFields()

var lensCfg model.Lens
if err := decoder.Decode(&lensCfg); err != nil {
return NewErrInvalidLensConfig(err)
}

collectionID, err := strconv.ParseUint(args[0], 10, 64)
if err != nil {
return err
}

return store.LensRegistry().SetMigration(cmd.Context(), uint32(collectionID), lensCfg)
},
}
return cmd
}
19 changes: 10 additions & 9 deletions cli/schema_migration_up.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,21 +23,21 @@ import (

func MakeSchemaMigrationUpCommand() *cobra.Command {
var file string
var schemaVersionID string
var collectionID uint32
var cmd = &cobra.Command{
Use: "up --version <version> <documents>",
Short: "Applies the migration to the specified schema version.",
Long: `Applies the migration to the specified schema version.
Use: "up --collection <collectionID> <documents>",
Short: "Applies the migration to the specified collection version.",
Long: `Applies the migration to the specified collection version.
Documents is a list of documents to apply the migration to.

Example: migrate from string
defradb client schema migration up --version bae123 '[{"name": "Bob"}]'
defradb client schema migration up --collection 2 '[{"name": "Bob"}]'

Example: migrate from file
defradb client schema migration up --version bae123 -f documents.json
defradb client schema migration up --collection 2 -f documents.json

Example: migrate from stdin
cat documents.json | defradb client schema migration up --version bae123 -
cat documents.json | defradb client schema migration up --collection 2 -
`,
Args: cobra.RangeArgs(0, 1),
RunE: func(cmd *cobra.Command, args []string) error {
Expand Down Expand Up @@ -71,7 +71,8 @@ Example: migrate from stdin
if tx, ok := cmd.Context().Value(txContextKey).(datastore.Txn); ok {
lens = lens.WithTxn(tx)
}
out, err := lens.MigrateUp(cmd.Context(), enumerable.New(src), schemaVersionID)

out, err := lens.MigrateUp(cmd.Context(), enumerable.New(src), collectionID)
if err != nil {
return err
}
Expand All @@ -86,6 +87,6 @@ Example: migrate from stdin
},
}
cmd.Flags().StringVarP(&file, "file", "f", "", "File containing document(s)")
cmd.Flags().StringVar(&schemaVersionID, "version", "", "Schema version id")
cmd.Flags().Uint32Var(&collectionID, "collection", 0, "Collection id")
return cmd
}
45 changes: 38 additions & 7 deletions cli/schema_patch.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,25 +11,30 @@
package cli

import (
"encoding/json"
"fmt"
"io"
"os"
"strings"

"github.com/lens-vm/lens/host-go/config/model"
"github.com/sourcenetwork/immutable"
"github.com/spf13/cobra"
)

func MakeSchemaPatchCommand() *cobra.Command {
var patchFile string
var setDefault bool
var lensFile string
var setActive bool
var cmd = &cobra.Command{
Use: "patch [schema]",
Use: "patch [schema] [migration]",
Short: "Patch an existing schema type",
Long: `Patch an existing schema.

Uses JSON Patch to modify schema types.

Example: patch from an argument string:
defradb client schema patch '[{ "op": "add", "path": "...", "value": {...} }]'
defradb client schema patch '[{ "op": "add", "path": "...", "value": {...} }]' '{"lenses": [...'

Example: patch from file:
defradb client schema patch -f patch.json
Expand All @@ -55,16 +60,42 @@ To learn more about the DefraDB GraphQL Schema Language, refer to https://docs.s
return err
}
patch = string(data)
case len(args) > 0:
case len(args) >= 1:
patch = args[0]
default:
return fmt.Errorf("patch cannot be empty")
}

return store.PatchSchema(cmd.Context(), patch, setDefault)
var lensCfgJson string
switch {
case lensFile != "":
data, err := os.ReadFile(lensFile)
if err != nil {
return err
}
patch = string(data)
case len(args) == 2:
lensCfgJson = args[1]
}

decoder := json.NewDecoder(strings.NewReader(lensCfgJson))
decoder.DisallowUnknownFields()

var migration immutable.Option[model.Lens]
if lensCfgJson != "" {
var lensCfg model.Lens
if err := decoder.Decode(&lensCfg); err != nil {
return NewErrInvalidLensConfig(err)
}
migration = immutable.Some(lensCfg)
}

return store.PatchSchema(cmd.Context(), patch, migration, setActive)
},
}
cmd.Flags().BoolVar(&setDefault, "set-default", false, "Set default schema version")
cmd.Flags().StringVarP(&patchFile, "file", "f", "", "File to load a patch from")
cmd.Flags().BoolVar(&setActive, "set-active", false,
"Set the active schema version for all collections using the root schem")
cmd.Flags().StringVarP(&patchFile, "patch-file", "p", "", "File to load a patch from")
cmd.Flags().StringVarP(&lensFile, "lens-file", "t", "", "File to load a lens config from")
return cmd
}
13 changes: 7 additions & 6 deletions cli/schema_set_default.go → cli/schema_set_active.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,16 @@ import (
"github.com/spf13/cobra"
)

func MakeSchemaSetDefaultCommand() *cobra.Command {
func MakeSchemaSetActiveCommand() *cobra.Command {
var cmd = &cobra.Command{
Use: "set-default [versionID]",
Short: "Set the default schema version",
Long: `Set the default schema version`,
Args: cobra.ExactArgs(1),
Use: "set-active [versionID]",
Short: "Set the active collection version",
Long: `Activates all collection versions with the given schema version, and deactivates all
those without it (if they share the same schema root).`,
Args: cobra.ExactArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
store := mustGetStoreContext(cmd)
return store.SetDefaultSchemaVersion(cmd.Context(), args[0])
return store.SetActiveSchemaVersion(cmd.Context(), args[0])
},
}
return cmd
Expand Down
Loading
Loading