Skip to content

Commit

Permalink
atlasaction: refactor monitor/schema
Browse files Browse the repository at this point in the history
  • Loading branch information
giautm committed Jan 13, 2025
1 parent 0c3d8ed commit d59f823
Showing 1 changed file with 25 additions and 30 deletions.
55 changes: 25 additions & 30 deletions atlasaction/action.go
Original file line number Diff line number Diff line change
Expand Up @@ -816,52 +816,47 @@ func (a *Actions) SchemaApply(ctx context.Context) error {

// MonitorSchema runs the Action for "ariga/atlas-action/monitor/schema"
func (a *Actions) MonitorSchema(ctx context.Context) error {
db, err := a.GetURLInput("url")
if err != nil {
if err := a.RequiredInputs("cloud-token", "slug"); err != nil {
return err
}
var (
config = a.GetInput("config")
env = a.GetInput("env")
)
if (config != "" || env != "") && db.String() != "" {
return errors.New("only one of the inputs 'config' or 'url' must be given")
}
var (
id = cloud.ScopeIdent{
ExtID: a.GetInput("slug"),
Schemas: a.GetArrayInput("schemas"),
Exclude: a.GetArrayInput("exclude"),
}
)
if err = a.Atlas.Login(ctx, &atlasexec.LoginParams{
if err := a.Atlas.Login(ctx, &atlasexec.LoginParams{
Token: a.GetInput("cloud-token"),
}); err != nil {
return fmt.Errorf("failed to login to Atlas Cloud: %w", err)
}
params := &atlasexec.SchemaInspectParams{
URL: db.String(),
ConfigURL: config,
Env: env,
Schema: id.Schemas,
Exclude: id.Schemas,
URL: a.GetInput("url"),
ConfigURL: a.GetInput("config"),
Env: a.GetInput("env"),
Schema: a.GetArrayInput("schemas"),
Exclude: a.GetArrayInput("exclude"),
Format: `{{ printf "# %s\n# %s\n%s" .RedactedURL .Hash .MarshalHCL }}`,
}
res, err := a.Atlas.SchemaInspect(ctx, params)
if (params.ConfigURL != "" || params.Env != "") && params.URL != "" {
return errors.New("only one of the inputs 'config' or 'url' must be given")
}
hcl, err := a.Atlas.SchemaInspect(ctx, params)
if err != nil {
return fmt.Errorf("failed to inspect the schema: %w", err)
}
var (
parts = strings.SplitN(res, "\n", 3)
url = strings.TrimPrefix(parts[0], "# ") // redacted URL.
hash = strings.TrimPrefix(parts[1], "# ")
hcl = parts[2]
)
id.URL = url
var redactedURL, hash string
if parts := strings.SplitN(hcl, "\n", 3); len(parts) != 3 {
return fmt.Errorf("invalid inspect output, expect 3 lines, got %d", len(parts))
} else {
redactedURL = strings.TrimPrefix(parts[0], "# ")
hash = strings.TrimPrefix(parts[1], "# ")
hcl = parts[2]
}
cc, err := a.cloudClient(ctx, "cloud-token")
if err != nil {
return err
}
id := cloud.ScopeIdent{
ExtID: a.GetInput("slug"),
URL: redactedURL,
Schemas: params.Schema,
Exclude: params.Exclude,
}
h, err := cc.SnapshotHash(ctx, &cloud.SnapshotHashInput{ScopeIdent: id})
if err != nil {
return fmt.Errorf("failed to get the schema snapshot hash: %w", err)
Expand Down

0 comments on commit d59f823

Please sign in to comment.