@xano/cli 0.0.95-beta.1 → 0.0.95-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/README.md +22 -9
  2. package/dist/base-command.d.ts +25 -0
  3. package/dist/base-command.js +37 -0
  4. package/dist/commands/auth/index.js +1 -1
  5. package/dist/commands/profile/create/index.js +2 -2
  6. package/dist/commands/profile/edit/index.js +2 -2
  7. package/dist/commands/profile/me/index.js +21 -2
  8. package/dist/commands/profile/wizard/index.js +3 -3
  9. package/dist/commands/profile/workspace/set/index.js +1 -1
  10. package/dist/commands/release/deploy/index.d.ts +17 -0
  11. package/dist/commands/release/deploy/index.js +107 -0
  12. package/dist/commands/{ephemeral → sandbox}/env/delete/index.d.ts +1 -4
  13. package/dist/commands/{ephemeral → sandbox}/env/delete/index.js +16 -34
  14. package/dist/commands/{ephemeral → sandbox}/env/get/index.d.ts +1 -4
  15. package/dist/commands/{ephemeral → sandbox}/env/get/index.js +11 -29
  16. package/dist/commands/{ephemeral → sandbox}/env/get_all/index.d.ts +1 -4
  17. package/dist/commands/{ephemeral → sandbox}/env/get_all/index.js +15 -33
  18. package/dist/commands/{ephemeral → sandbox}/env/list/index.d.ts +1 -4
  19. package/dist/commands/sandbox/env/list/index.js +65 -0
  20. package/dist/commands/{ephemeral → sandbox}/env/set/index.d.ts +1 -4
  21. package/dist/commands/{ephemeral → sandbox}/env/set/index.js +12 -30
  22. package/dist/commands/{ephemeral → sandbox}/env/set_all/index.d.ts +1 -4
  23. package/dist/commands/{ephemeral → sandbox}/env/set_all/index.js +15 -33
  24. package/dist/commands/{ephemeral → sandbox}/get/index.d.ts +1 -4
  25. package/dist/commands/sandbox/get/index.js +61 -0
  26. package/dist/commands/sandbox/impersonate/index.d.ts +5 -0
  27. package/dist/commands/sandbox/impersonate/index.js +5 -0
  28. package/dist/commands/{ephemeral → sandbox}/license/get/index.d.ts +1 -4
  29. package/dist/commands/{ephemeral → sandbox}/license/get/index.js +15 -33
  30. package/dist/commands/{ephemeral → sandbox}/license/set/index.d.ts +1 -4
  31. package/dist/commands/{ephemeral → sandbox}/license/set/index.js +16 -34
  32. package/dist/commands/{ephemeral → sandbox}/pull/index.d.ts +1 -2
  33. package/dist/commands/{ephemeral → sandbox}/pull/index.js +9 -26
  34. package/dist/commands/{ephemeral → sandbox}/push/index.d.ts +1 -2
  35. package/dist/commands/{ephemeral → sandbox}/push/index.js +11 -28
  36. package/dist/commands/{ephemeral/delete → sandbox/reset}/index.d.ts +1 -5
  37. package/dist/commands/sandbox/reset/index.js +69 -0
  38. package/dist/commands/{ephemeral/impersonate → sandbox/review}/index.d.ts +1 -4
  39. package/dist/commands/{ephemeral/impersonate → sandbox/review}/index.js +13 -31
  40. package/dist/commands/{ephemeral/unit_test/run_all → sandbox/unit_test/list}/index.d.ts +1 -2
  41. package/dist/commands/{ephemeral → sandbox}/unit_test/list/index.js +8 -24
  42. package/dist/commands/{ephemeral → sandbox}/unit_test/run/index.d.ts +1 -2
  43. package/dist/commands/{ephemeral → sandbox}/unit_test/run/index.js +7 -23
  44. package/dist/commands/{ephemeral/unit_test/list → sandbox/unit_test/run_all}/index.d.ts +1 -2
  45. package/dist/commands/{ephemeral → sandbox}/unit_test/run_all/index.js +7 -23
  46. package/dist/commands/{ephemeral/workflow_test/get → sandbox/workflow_test/delete}/index.d.ts +1 -2
  47. package/dist/commands/{ephemeral → sandbox}/workflow_test/delete/index.js +7 -23
  48. package/dist/commands/{ephemeral/workflow_test/run → sandbox/workflow_test/get}/index.d.ts +1 -2
  49. package/dist/commands/{ephemeral → sandbox}/workflow_test/get/index.js +6 -25
  50. package/dist/commands/{ephemeral/workflow_test/run_all → sandbox/workflow_test/list}/index.d.ts +1 -2
  51. package/dist/commands/{ephemeral → sandbox}/workflow_test/list/index.js +9 -25
  52. package/dist/commands/{ephemeral/workflow_test/delete → sandbox/workflow_test/run}/index.d.ts +1 -2
  53. package/dist/commands/{ephemeral → sandbox}/workflow_test/run/index.js +7 -23
  54. package/dist/commands/{ephemeral/workflow_test/list → sandbox/workflow_test/run_all}/index.d.ts +1 -2
  55. package/dist/commands/{ephemeral → sandbox}/workflow_test/run_all/index.js +7 -23
  56. package/dist/commands/tenant/create/index.d.ts +2 -1
  57. package/dist/commands/tenant/create/index.js +23 -6
  58. package/dist/commands/tenant/get/index.js +2 -2
  59. package/dist/commands/tenant/list/index.js +2 -2
  60. package/dist/commands/tenant/push/index.js +0 -34
  61. package/dist/commands/workspace/edit/index.d.ts +1 -0
  62. package/dist/commands/workspace/edit/index.js +16 -6
  63. package/dist/commands/workspace/get/index.js +9 -7
  64. package/dist/commands/workspace/list/index.d.ts +1 -0
  65. package/dist/commands/workspace/list/index.js +14 -7
  66. package/dist/commands/workspace/push/index.js +30 -2
  67. package/oclif.manifest.json +1985 -2354
  68. package/package.json +8 -8
  69. package/dist/commands/ephemeral/access/index.d.ts +0 -15
  70. package/dist/commands/ephemeral/access/index.js +0 -78
  71. package/dist/commands/ephemeral/create/index.d.ts +0 -17
  72. package/dist/commands/ephemeral/create/index.js +0 -102
  73. package/dist/commands/ephemeral/delete/index.js +0 -99
  74. package/dist/commands/ephemeral/env/list/index.js +0 -83
  75. package/dist/commands/ephemeral/get/index.js +0 -102
  76. package/dist/commands/ephemeral/list/index.d.ts +0 -15
  77. package/dist/commands/ephemeral/list/index.js +0 -109
  78. package/dist/commands/ephemeral/shared/index.d.ts +0 -15
  79. package/dist/commands/ephemeral/shared/index.js +0 -108
@@ -3,20 +3,20 @@ import BaseCommand from '../../../base-command.js';
3
3
  import { findFilesWithGuid } from '../../../utils/document-parser.js';
4
4
  import * as fs from 'node:fs';
5
5
  import * as path from 'node:path';
6
- export default class EphemeralPush extends BaseCommand {
6
+ export default class SandboxPush extends BaseCommand {
7
7
  static args = {
8
8
  directory: Args.string({
9
- description: 'Directory containing documents to push (as produced by ephemeral pull or workspace pull)',
9
+ description: 'Directory containing documents to push (as produced by sandbox pull or workspace pull)',
10
10
  required: true,
11
11
  }),
12
12
  };
13
- static description = 'Push local documents to an ephemeral tenant via multidoc import';
13
+ static description = 'Push local documents to your sandbox environment via multidoc import';
14
14
  static examples = [
15
- `$ xano ephemeral push ./my-workspace -t my-tenant
16
- Pushed 42 documents to ephemeral tenant my-tenant from ./my-workspace
15
+ `$ xano sandbox push ./my-workspace
16
+ Pushed 42 documents to sandbox environment from ./my-workspace
17
17
  `,
18
- `$ xano ephemeral push ./backup -t my-tenant --records --env`,
19
- `$ xano ephemeral push ./my-workspace -t my-tenant --truncate`,
18
+ `$ xano sandbox push ./backup --records --env`,
19
+ `$ xano sandbox push ./my-workspace --truncate`,
20
20
  ];
21
21
  static flags = {
22
22
  ...BaseCommand.baseFlags,
@@ -30,11 +30,6 @@ Pushed 42 documents to ephemeral tenant my-tenant from ./my-workspace
30
30
  description: 'Include records in import',
31
31
  required: false,
32
32
  }),
33
- tenant: Flags.string({
34
- char: 't',
35
- description: 'Ephemeral tenant name to push to',
36
- required: true,
37
- }),
38
33
  transaction: Flags.boolean({
39
34
  allowNo: true,
40
35
  default: true,
@@ -48,20 +43,8 @@ Pushed 42 documents to ephemeral tenant my-tenant from ./my-workspace
48
43
  }),
49
44
  };
50
45
  async run() {
51
- const { args, flags } = await this.parse(EphemeralPush);
52
- const profileName = flags.profile || this.getDefaultProfile();
53
- const credentials = this.loadCredentialsFile();
54
- if (!credentials || !(profileName in credentials.profiles)) {
55
- this.error(`Profile '${profileName}' not found.\n` + `Create a profile using 'xano profile create'`);
56
- }
57
- const profile = credentials.profiles[profileName];
58
- if (!profile.instance_origin) {
59
- this.error(`Profile '${profileName}' is missing instance_origin`);
60
- }
61
- if (!profile.access_token) {
62
- this.error(`Profile '${profileName}' is missing access_token`);
63
- }
64
- const tenantName = flags.tenant;
46
+ const { args, flags } = await this.parse(SandboxPush);
47
+ const { profile } = this.resolveProfile(flags);
65
48
  const inputDir = path.resolve(args.directory);
66
49
  if (!fs.existsSync(inputDir)) {
67
50
  this.error(`Directory not found: ${inputDir}`);
@@ -90,7 +73,7 @@ Pushed 42 documents to ephemeral tenant my-tenant from ./my-workspace
90
73
  transaction: flags.transaction.toString(),
91
74
  truncate: flags.truncate.toString(),
92
75
  });
93
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${tenantName}/multidoc?${queryParams.toString()}`;
76
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/multidoc?${queryParams.toString()}`;
94
77
  const startTime = Date.now();
95
78
  try {
96
79
  const response = await this.verboseFetch(apiUrl, {
@@ -139,7 +122,7 @@ Pushed 42 documents to ephemeral tenant my-tenant from ./my-workspace
139
122
  }
140
123
  }
141
124
  const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
142
- this.log(`Pushed ${documentEntries.length} documents to ephemeral tenant ${tenantName} from ${args.directory} in ${elapsed}s`);
125
+ this.log(`Pushed ${documentEntries.length} documents to sandbox environment from ${args.directory} in ${elapsed}s`);
143
126
  }
144
127
  collectFiles(dir) {
145
128
  const files = [];
@@ -1,13 +1,9 @@
1
1
  import BaseCommand from '../../../base-command.js';
2
- export default class EphemeralDelete extends BaseCommand {
3
- static args: {
4
- tenant_name: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
5
- };
2
+ export default class SandboxReset extends BaseCommand {
6
3
  static description: string;
7
4
  static examples: string[];
8
5
  static flags: {
9
6
  force: import("@oclif/core/interfaces").BooleanFlag<boolean>;
10
- output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
11
7
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
12
8
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
13
9
  };
@@ -0,0 +1,69 @@
1
+ import { Flags } from '@oclif/core';
2
+ import BaseCommand from '../../../base-command.js';
3
+ export default class SandboxReset extends BaseCommand {
4
+ static description = 'Reset your sandbox environment (clears all workspace data and drafts)';
5
+ static examples = [
6
+ `$ xano sandbox reset
7
+ Are you sure you want to reset your sandbox environment? All workspace data and drafts will be cleared. (y/N) y
8
+ Sandbox environment has been reset.
9
+ `,
10
+ `$ xano sandbox reset --force`,
11
+ ];
12
+ static flags = {
13
+ ...BaseCommand.baseFlags,
14
+ force: Flags.boolean({
15
+ char: 'f',
16
+ default: false,
17
+ description: 'Skip confirmation prompt',
18
+ required: false,
19
+ }),
20
+ };
21
+ async run() {
22
+ const { flags } = await this.parse(SandboxReset);
23
+ const { profile } = this.resolveProfile(flags);
24
+ if (!flags.force) {
25
+ const confirmed = await this.confirm(`Are you sure you want to reset your sandbox environment? All workspace data and drafts will be cleared.`);
26
+ if (!confirmed) {
27
+ this.log('Reset cancelled.');
28
+ return;
29
+ }
30
+ }
31
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/reset`;
32
+ try {
33
+ const response = await this.verboseFetch(apiUrl, {
34
+ headers: {
35
+ accept: 'application/json',
36
+ Authorization: `Bearer ${profile.access_token}`,
37
+ 'Content-Type': 'application/json',
38
+ },
39
+ method: 'POST',
40
+ }, flags.verbose, profile.access_token);
41
+ if (!response.ok) {
42
+ const errorText = await response.text();
43
+ this.error(`API request failed with status ${response.status}: ${response.statusText}\n${errorText}`);
44
+ }
45
+ this.log('Sandbox environment has been reset.');
46
+ }
47
+ catch (error) {
48
+ if (error instanceof Error) {
49
+ this.error(`Failed to reset sandbox environment: ${error.message}`);
50
+ }
51
+ else {
52
+ this.error(`Failed to reset sandbox environment: ${String(error)}`);
53
+ }
54
+ }
55
+ }
56
+ async confirm(message) {
57
+ const readline = await import('node:readline');
58
+ const rl = readline.createInterface({
59
+ input: process.stdin,
60
+ output: process.stdout,
61
+ });
62
+ return new Promise((resolve) => {
63
+ rl.question(`${message} (y/N) `, (answer) => {
64
+ rl.close();
65
+ resolve(answer.toLowerCase() === 'y' || answer.toLowerCase() === 'yes');
66
+ });
67
+ });
68
+ }
69
+ }
@@ -1,8 +1,5 @@
1
1
  import BaseCommand from '../../../base-command.js';
2
- export default class EphemeralImpersonate extends BaseCommand {
3
- static args: {
4
- tenant_name: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
5
- };
2
+ export default class SandboxReview extends BaseCommand {
6
3
  static description: string;
7
4
  static examples: string[];
8
5
  static flags: {
@@ -1,21 +1,15 @@
1
- import { Args, Flags } from '@oclif/core';
1
+ import { Flags } from '@oclif/core';
2
2
  import open from 'open';
3
3
  import BaseCommand from '../../../base-command.js';
4
- export default class EphemeralImpersonate extends BaseCommand {
5
- static args = {
6
- tenant_name: Args.string({
7
- description: 'Ephemeral tenant name to impersonate',
8
- required: true,
9
- }),
10
- };
11
- static description = 'Impersonate an ephemeral tenant and open it in the browser';
4
+ export default class SandboxReview extends BaseCommand {
5
+ static description = 'Open your sandbox environment in the browser to review and promote changes';
12
6
  static examples = [
13
- `$ xano ephemeral impersonate my-tenant
7
+ `$ xano sandbox review
14
8
  Opening browser...
15
- Impersonation successful!
9
+ Review session started!
16
10
  `,
17
- `$ xano ephemeral impersonate my-tenant -u`,
18
- `$ xano ephemeral impersonate my-tenant -o json`,
11
+ `$ xano sandbox review -u`,
12
+ `$ xano sandbox review -o json`,
19
13
  ];
20
14
  static flags = {
21
15
  ...BaseCommand.baseFlags,
@@ -34,21 +28,9 @@ Impersonation successful!
34
28
  }),
35
29
  };
36
30
  async run() {
37
- const { args, flags } = await this.parse(EphemeralImpersonate);
38
- const profileName = flags.profile || this.getDefaultProfile();
39
- const credentials = this.loadCredentialsFile();
40
- if (!credentials || !(profileName in credentials.profiles)) {
41
- this.error(`Profile '${profileName}' not found.\n` + `Create a profile using 'xano auth'`);
42
- }
43
- const profile = credentials.profiles[profileName];
44
- if (!profile.instance_origin) {
45
- this.error(`Profile '${profileName}' is missing instance_origin`);
46
- }
47
- if (!profile.access_token) {
48
- this.error(`Profile '${profileName}' is missing access_token`);
49
- }
50
- const tenantName = args.tenant_name;
51
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(tenantName)}/impersonate`;
31
+ const { flags } = await this.parse(SandboxReview);
32
+ const { profile } = this.resolveProfile(flags);
33
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/impersonate`;
52
34
  try {
53
35
  const response = await this.verboseFetch(apiUrl, {
54
36
  headers: {
@@ -80,17 +62,17 @@ Impersonation successful!
80
62
  else {
81
63
  this.log('Opening browser...');
82
64
  await open(impersonateUrl);
83
- this.log('Impersonation successful!');
65
+ this.log('Review session started!');
84
66
  }
85
67
  }
86
68
  process.exit(0);
87
69
  }
88
70
  catch (error) {
89
71
  if (error instanceof Error) {
90
- this.error(`Failed to impersonate ephemeral tenant: ${error.message}`);
72
+ this.error(`Failed to open sandbox review: ${error.message}`);
91
73
  }
92
74
  else {
93
- this.error(`Failed to impersonate ephemeral tenant: ${String(error)}`);
75
+ this.error(`Failed to open sandbox review: ${String(error)}`);
94
76
  }
95
77
  }
96
78
  }
@@ -1,12 +1,11 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralUnitTestRunAll extends BaseCommand {
2
+ export default class SandboxUnitTestList extends BaseCommand {
3
3
  static description: string;
4
4
  static examples: string[];
5
5
  static flags: {
6
6
  branch: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
7
7
  'obj-type': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
8
8
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
9
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
10
9
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
11
10
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
12
11
  };
@@ -1,13 +1,13 @@
1
1
  import { Flags } from '@oclif/core';
2
2
  import BaseCommand from '../../../../base-command.js';
3
- export default class EphemeralUnitTestList extends BaseCommand {
4
- static description = 'List all unit tests for an ephemeral tenant';
3
+ export default class SandboxUnitTestList extends BaseCommand {
4
+ static description = 'List all unit tests for a sandbox environment';
5
5
  static examples = [
6
- `$ xano ephemeral unit-test list -t e1a2-b3c4-x5y6
6
+ `$ xano sandbox unit-test list
7
7
  Unit tests:
8
8
  - my-test (ID: abc-123) [function: math]
9
9
  `,
10
- `$ xano ephemeral unit-test list -t e1a2-b3c4-x5y6 -o json`,
10
+ `$ xano sandbox unit-test list -o json`,
11
11
  ];
12
12
  static flags = {
13
13
  ...BaseCommand.baseFlags,
@@ -28,33 +28,17 @@ Unit tests:
28
28
  options: ['summary', 'json'],
29
29
  required: false,
30
30
  }),
31
- tenant: Flags.string({
32
- char: 't',
33
- description: 'Ephemeral tenant name',
34
- required: true,
35
- }),
36
31
  };
37
32
  async run() {
38
- const { flags } = await this.parse(EphemeralUnitTestList);
39
- const profileName = flags.profile || this.getDefaultProfile();
40
- const credentials = this.loadCredentialsFile();
41
- if (!credentials || !(profileName in credentials.profiles)) {
42
- this.error(`Profile '${profileName}' not found.\nCreate a profile using 'xano profile create'`);
43
- }
44
- const profile = credentials.profiles[profileName];
45
- if (!profile.instance_origin) {
46
- this.error(`Profile '${profileName}' is missing instance_origin`);
47
- }
48
- if (!profile.access_token) {
49
- this.error(`Profile '${profileName}' is missing access_token`);
50
- }
33
+ const { flags } = await this.parse(SandboxUnitTestList);
34
+ const { profile } = this.resolveProfile(flags);
51
35
  const params = new URLSearchParams();
52
36
  params.set('per_page', '10000');
53
37
  if (flags.branch)
54
38
  params.set('branch', flags.branch);
55
39
  if (flags['obj-type'])
56
40
  params.set('obj_type', flags['obj-type']);
57
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(flags.tenant)}/unit_test?${params}`;
41
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/unit_test?${params}`;
58
42
  try {
59
43
  const response = await this.verboseFetch(apiUrl, {
60
44
  headers: {
@@ -86,7 +70,7 @@ Unit tests:
86
70
  this.log('No unit tests found');
87
71
  }
88
72
  else {
89
- this.log(`Unit tests for tenant ${flags.tenant}:`);
73
+ this.log(`Unit tests for sandbox environment:`);
90
74
  for (const test of tests) {
91
75
  this.log(` - ${test.name} (ID: ${test.id}) [${test.obj_type}: ${test.obj_name}]`);
92
76
  }
@@ -1,5 +1,5 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralUnitTestRun extends BaseCommand {
2
+ export default class SandboxUnitTestRun extends BaseCommand {
3
3
  static args: {
4
4
  unit_test_id: import("@oclif/core/interfaces").Arg<string, Record<string, unknown>>;
5
5
  };
@@ -7,7 +7,6 @@ export default class EphemeralUnitTestRun extends BaseCommand {
7
7
  static examples: string[];
8
8
  static flags: {
9
9
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
10
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
11
10
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
12
11
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
13
12
  };
@@ -1,19 +1,19 @@
1
1
  import { Args, Flags } from '@oclif/core';
2
2
  import BaseCommand from '../../../../base-command.js';
3
- export default class EphemeralUnitTestRun extends BaseCommand {
3
+ export default class SandboxUnitTestRun extends BaseCommand {
4
4
  static args = {
5
5
  unit_test_id: Args.string({
6
6
  description: 'ID of the unit test to run',
7
7
  required: true,
8
8
  }),
9
9
  };
10
- static description = 'Run a unit test for an ephemeral tenant';
10
+ static description = 'Run a unit test for a sandbox environment';
11
11
  static examples = [
12
- `$ xano ephemeral unit-test run abc-123 -t e1a2-b3c4-x5y6
12
+ `$ xano sandbox unit-test run abc-123
13
13
  Running unit test abc-123...
14
14
  Result: PASS
15
15
  `,
16
- `$ xano ephemeral unit-test run abc-123 -t e1a2-b3c4-x5y6 -o json`,
16
+ `$ xano sandbox unit-test run abc-123 -o json`,
17
17
  ];
18
18
  static flags = {
19
19
  ...BaseCommand.baseFlags,
@@ -24,27 +24,11 @@ Result: PASS
24
24
  options: ['summary', 'json'],
25
25
  required: false,
26
26
  }),
27
- tenant: Flags.string({
28
- char: 't',
29
- description: 'Ephemeral tenant name',
30
- required: true,
31
- }),
32
27
  };
33
28
  async run() {
34
- const { args, flags } = await this.parse(EphemeralUnitTestRun);
35
- const profileName = flags.profile || this.getDefaultProfile();
36
- const credentials = this.loadCredentialsFile();
37
- if (!credentials || !(profileName in credentials.profiles)) {
38
- this.error(`Profile '${profileName}' not found.\nCreate a profile using 'xano profile create'`);
39
- }
40
- const profile = credentials.profiles[profileName];
41
- if (!profile.instance_origin) {
42
- this.error(`Profile '${profileName}' is missing instance_origin`);
43
- }
44
- if (!profile.access_token) {
45
- this.error(`Profile '${profileName}' is missing access_token`);
46
- }
47
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(flags.tenant)}/unit_test/${encodeURIComponent(args.unit_test_id)}/run`;
29
+ const { args, flags } = await this.parse(SandboxUnitTestRun);
30
+ const { profile } = this.resolveProfile(flags);
31
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/unit_test/${encodeURIComponent(args.unit_test_id)}/run`;
48
32
  try {
49
33
  if (flags.output === 'summary') {
50
34
  this.log(`Running unit test ${args.unit_test_id}...`);
@@ -1,12 +1,11 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralUnitTestList extends BaseCommand {
2
+ export default class SandboxUnitTestRunAll extends BaseCommand {
3
3
  static description: string;
4
4
  static examples: string[];
5
5
  static flags: {
6
6
  branch: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
7
7
  'obj-type': import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
8
8
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
9
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
10
9
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
11
10
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
12
11
  };
@@ -1,9 +1,9 @@
1
1
  import { Flags } from '@oclif/core';
2
2
  import BaseCommand from '../../../../base-command.js';
3
- export default class EphemeralUnitTestRunAll extends BaseCommand {
4
- static description = 'Run all unit tests for an ephemeral tenant';
3
+ export default class SandboxUnitTestRunAll extends BaseCommand {
4
+ static description = 'Run all unit tests for a sandbox environment';
5
5
  static examples = [
6
- `$ xano ephemeral unit-test run-all -t e1a2-b3c4-x5y6
6
+ `$ xano sandbox unit-test run-all
7
7
  Running 5 unit tests...
8
8
 
9
9
  PASS my-test [function: math]
@@ -12,7 +12,7 @@ FAIL data-validation [function: validate]
12
12
 
13
13
  Results: 4 passed, 1 failed
14
14
  `,
15
- `$ xano ephemeral unit-test run-all -t e1a2-b3c4-x5y6 -o json`,
15
+ `$ xano sandbox unit-test run-all -o json`,
16
16
  ];
17
17
  static flags = {
18
18
  ...BaseCommand.baseFlags,
@@ -33,27 +33,11 @@ Results: 4 passed, 1 failed
33
33
  options: ['summary', 'json'],
34
34
  required: false,
35
35
  }),
36
- tenant: Flags.string({
37
- char: 't',
38
- description: 'Ephemeral tenant name',
39
- required: true,
40
- }),
41
36
  };
42
37
  async run() {
43
- const { flags } = await this.parse(EphemeralUnitTestRunAll);
44
- const profileName = flags.profile || this.getDefaultProfile();
45
- const credentials = this.loadCredentialsFile();
46
- if (!credentials || !(profileName in credentials.profiles)) {
47
- this.error(`Profile '${profileName}' not found.\nCreate a profile using 'xano profile create'`);
48
- }
49
- const profile = credentials.profiles[profileName];
50
- if (!profile.instance_origin) {
51
- this.error(`Profile '${profileName}' is missing instance_origin`);
52
- }
53
- if (!profile.access_token) {
54
- this.error(`Profile '${profileName}' is missing access_token`);
55
- }
56
- const baseUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(flags.tenant)}/unit_test`;
38
+ const { flags } = await this.parse(SandboxUnitTestRunAll);
39
+ const { profile } = this.resolveProfile(flags);
40
+ const baseUrl = `${profile.instance_origin}/api:meta/sandbox/unit_test`;
57
41
  try {
58
42
  // Step 1: List all unit tests
59
43
  const listParams = new URLSearchParams();
@@ -1,5 +1,5 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralWorkflowTestGet extends BaseCommand {
2
+ export default class SandboxWorkflowTestDelete extends BaseCommand {
3
3
  static args: {
4
4
  workflow_test_id: import("@oclif/core/interfaces").Arg<number, {
5
5
  max?: number;
@@ -10,7 +10,6 @@ export default class EphemeralWorkflowTestGet extends BaseCommand {
10
10
  static examples: string[];
11
11
  static flags: {
12
12
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
13
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
14
13
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
15
14
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
16
15
  };
@@ -1,18 +1,18 @@
1
1
  import { Args, Flags } from '@oclif/core';
2
2
  import BaseCommand from '../../../../base-command.js';
3
- export default class EphemeralWorkflowTestDelete extends BaseCommand {
3
+ export default class SandboxWorkflowTestDelete extends BaseCommand {
4
4
  static args = {
5
5
  workflow_test_id: Args.integer({
6
6
  description: 'ID of the workflow test to delete',
7
7
  required: true,
8
8
  }),
9
9
  };
10
- static description = 'Delete a workflow test for an ephemeral tenant';
10
+ static description = 'Delete a workflow test for a sandbox environment';
11
11
  static examples = [
12
- `$ xano ephemeral workflow-test delete 42 -t e1a2-b3c4-x5y6
12
+ `$ xano sandbox workflow-test delete 42
13
13
  Deleted workflow test 42
14
14
  `,
15
- `$ xano ephemeral workflow-test delete 42 -t e1a2-b3c4-x5y6 -o json`,
15
+ `$ xano sandbox workflow-test delete 42 -o json`,
16
16
  ];
17
17
  static flags = {
18
18
  ...BaseCommand.baseFlags,
@@ -23,27 +23,11 @@ Deleted workflow test 42
23
23
  options: ['summary', 'json'],
24
24
  required: false,
25
25
  }),
26
- tenant: Flags.string({
27
- char: 't',
28
- description: 'Ephemeral tenant name',
29
- required: true,
30
- }),
31
26
  };
32
27
  async run() {
33
- const { args, flags } = await this.parse(EphemeralWorkflowTestDelete);
34
- const profileName = flags.profile || this.getDefaultProfile();
35
- const credentials = this.loadCredentialsFile();
36
- if (!credentials || !(profileName in credentials.profiles)) {
37
- this.error(`Profile '${profileName}' not found.\nCreate a profile using 'xano profile create'`);
38
- }
39
- const profile = credentials.profiles[profileName];
40
- if (!profile.instance_origin) {
41
- this.error(`Profile '${profileName}' is missing instance_origin`);
42
- }
43
- if (!profile.access_token) {
44
- this.error(`Profile '${profileName}' is missing access_token`);
45
- }
46
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(flags.tenant)}/workflow_test/${args.workflow_test_id}`;
28
+ const { args, flags } = await this.parse(SandboxWorkflowTestDelete);
29
+ const { profile } = this.resolveProfile(flags);
30
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/workflow_test/${args.workflow_test_id}`;
47
31
  try {
48
32
  const response = await this.verboseFetch(apiUrl, {
49
33
  headers: {
@@ -1,5 +1,5 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralWorkflowTestRun extends BaseCommand {
2
+ export default class SandboxWorkflowTestGet extends BaseCommand {
3
3
  static args: {
4
4
  workflow_test_id: import("@oclif/core/interfaces").Arg<number, {
5
5
  max?: number;
@@ -10,7 +10,6 @@ export default class EphemeralWorkflowTestRun extends BaseCommand {
10
10
  static examples: string[];
11
11
  static flags: {
12
12
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
13
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
14
13
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
15
14
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
16
15
  };
@@ -1,17 +1,14 @@
1
1
  import { Args, Flags } from '@oclif/core';
2
2
  import BaseCommand from '../../../../base-command.js';
3
- export default class EphemeralWorkflowTestGet extends BaseCommand {
3
+ export default class SandboxWorkflowTestGet extends BaseCommand {
4
4
  static args = {
5
5
  workflow_test_id: Args.integer({
6
6
  description: 'ID of the workflow test',
7
7
  required: true,
8
8
  }),
9
9
  };
10
- static description = 'Get a workflow test for an ephemeral tenant';
11
- static examples = [
12
- `$ xano ephemeral workflow-test get 42 -t e1a2-b3c4-x5y6`,
13
- `$ xano ephemeral workflow-test get 42 -t e1a2-b3c4-x5y6 -o json`,
14
- ];
10
+ static description = 'Get a workflow test for a sandbox environment';
11
+ static examples = [`$ xano sandbox workflow-test get 42`, `$ xano sandbox workflow-test get 42 -o json`];
15
12
  static flags = {
16
13
  ...BaseCommand.baseFlags,
17
14
  output: Flags.string({
@@ -21,27 +18,11 @@ export default class EphemeralWorkflowTestGet extends BaseCommand {
21
18
  options: ['summary', 'json'],
22
19
  required: false,
23
20
  }),
24
- tenant: Flags.string({
25
- char: 't',
26
- description: 'Ephemeral tenant name',
27
- required: true,
28
- }),
29
21
  };
30
22
  async run() {
31
- const { args, flags } = await this.parse(EphemeralWorkflowTestGet);
32
- const profileName = flags.profile || this.getDefaultProfile();
33
- const credentials = this.loadCredentialsFile();
34
- if (!credentials || !(profileName in credentials.profiles)) {
35
- this.error(`Profile '${profileName}' not found.\nCreate a profile using 'xano profile create'`);
36
- }
37
- const profile = credentials.profiles[profileName];
38
- if (!profile.instance_origin) {
39
- this.error(`Profile '${profileName}' is missing instance_origin`);
40
- }
41
- if (!profile.access_token) {
42
- this.error(`Profile '${profileName}' is missing access_token`);
43
- }
44
- const apiUrl = `${profile.instance_origin}/api:meta/ephemeral/tenant/${encodeURIComponent(flags.tenant)}/workflow_test/${args.workflow_test_id}`;
23
+ const { args, flags } = await this.parse(SandboxWorkflowTestGet);
24
+ const { profile } = this.resolveProfile(flags);
25
+ const apiUrl = `${profile.instance_origin}/api:meta/sandbox/workflow_test/${args.workflow_test_id}`;
45
26
  try {
46
27
  const response = await this.verboseFetch(apiUrl, {
47
28
  headers: {
@@ -1,11 +1,10 @@
1
1
  import BaseCommand from '../../../../base-command.js';
2
- export default class EphemeralWorkflowTestRunAll extends BaseCommand {
2
+ export default class SandboxWorkflowTestList extends BaseCommand {
3
3
  static description: string;
4
4
  static examples: string[];
5
5
  static flags: {
6
6
  branch: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
7
7
  output: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
8
- tenant: import("@oclif/core/interfaces").OptionFlag<string, import("@oclif/core/interfaces").CustomOptions>;
9
8
  profile: import("@oclif/core/interfaces").OptionFlag<string | undefined, import("@oclif/core/interfaces").CustomOptions>;
10
9
  verbose: import("@oclif/core/interfaces").BooleanFlag<boolean>;
11
10
  };