neonctl 2.27.1 → 2.29.0

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 (136) hide show
  1. package/README.md +35 -3
  2. package/dist/analytics.js +52 -34
  3. package/dist/api.js +643 -13
  4. package/dist/auth.js +50 -44
  5. package/dist/cli.js +8 -1
  6. package/dist/commands/auth.js +64 -51
  7. package/dist/commands/bootstrap.js +115 -157
  8. package/dist/commands/branches.js +160 -150
  9. package/dist/commands/bucket.js +183 -146
  10. package/dist/commands/checkout.js +51 -51
  11. package/dist/commands/config.js +228 -82
  12. package/dist/commands/connection_string.js +62 -62
  13. package/dist/commands/data_api.js +100 -101
  14. package/dist/commands/databases.js +29 -26
  15. package/dist/commands/deploy.js +12 -12
  16. package/dist/commands/dev.js +114 -114
  17. package/dist/commands/env.js +43 -43
  18. package/dist/commands/functions.js +101 -104
  19. package/dist/commands/index.js +27 -25
  20. package/dist/commands/init.js +23 -22
  21. package/dist/commands/ip_allow.js +29 -29
  22. package/dist/commands/link.js +232 -182
  23. package/dist/commands/neon_auth.js +385 -370
  24. package/dist/commands/operations.js +11 -11
  25. package/dist/commands/orgs.js +8 -8
  26. package/dist/commands/projects.js +103 -101
  27. package/dist/commands/psql.js +31 -31
  28. package/dist/commands/roles.js +27 -24
  29. package/dist/commands/schema_diff.js +25 -26
  30. package/dist/commands/set_context.js +17 -17
  31. package/dist/commands/status.js +40 -0
  32. package/dist/commands/user.js +5 -5
  33. package/dist/commands/vpc_endpoints.js +50 -50
  34. package/dist/config.js +7 -7
  35. package/dist/config_format.js +5 -5
  36. package/dist/context.js +37 -14
  37. package/dist/current_branch_fast_path.js +55 -0
  38. package/dist/dev/env.js +33 -33
  39. package/dist/dev/functions.js +4 -4
  40. package/dist/dev/inputs.js +6 -6
  41. package/dist/dev/runtime.js +25 -25
  42. package/dist/env.js +14 -14
  43. package/dist/env_file.js +13 -13
  44. package/dist/errors.js +68 -5
  45. package/dist/functions_api.js +10 -10
  46. package/dist/help.js +15 -15
  47. package/dist/index.js +110 -107
  48. package/dist/log.js +2 -2
  49. package/dist/parameters.gen.js +14 -14
  50. package/dist/pkg.js +5 -5
  51. package/dist/psql/cli.js +4 -2
  52. package/dist/psql/command/cmd_cond.js +61 -61
  53. package/dist/psql/command/cmd_connect.js +159 -154
  54. package/dist/psql/command/cmd_copy.js +107 -97
  55. package/dist/psql/command/cmd_describe.js +368 -363
  56. package/dist/psql/command/cmd_format.js +276 -263
  57. package/dist/psql/command/cmd_io.js +269 -263
  58. package/dist/psql/command/cmd_lo.js +74 -66
  59. package/dist/psql/command/cmd_meta.js +148 -148
  60. package/dist/psql/command/cmd_misc.js +17 -17
  61. package/dist/psql/command/cmd_pipeline.js +142 -135
  62. package/dist/psql/command/cmd_restrict.js +25 -25
  63. package/dist/psql/command/cmd_show.js +183 -168
  64. package/dist/psql/command/dispatch.js +26 -26
  65. package/dist/psql/command/shared.js +14 -14
  66. package/dist/psql/complete/filenames.js +16 -16
  67. package/dist/psql/complete/index.js +4 -4
  68. package/dist/psql/complete/matcher.js +33 -32
  69. package/dist/psql/complete/psqlVars.js +173 -173
  70. package/dist/psql/complete/queries.js +5 -3
  71. package/dist/psql/complete/rules.js +900 -863
  72. package/dist/psql/core/common.js +136 -133
  73. package/dist/psql/core/help.js +343 -343
  74. package/dist/psql/core/mainloop.js +160 -153
  75. package/dist/psql/core/prompt.js +126 -123
  76. package/dist/psql/core/settings.js +111 -111
  77. package/dist/psql/core/sqlHelp.js +150 -150
  78. package/dist/psql/core/startup.js +211 -205
  79. package/dist/psql/core/syncVars.js +14 -14
  80. package/dist/psql/core/variables.js +24 -24
  81. package/dist/psql/describe/formatters.js +302 -289
  82. package/dist/psql/describe/processNamePattern.js +28 -28
  83. package/dist/psql/describe/queries.js +656 -651
  84. package/dist/psql/index.js +436 -411
  85. package/dist/psql/io/history.js +36 -36
  86. package/dist/psql/io/input.js +15 -15
  87. package/dist/psql/io/lineEditor/buffer.js +27 -25
  88. package/dist/psql/io/lineEditor/complete.js +15 -15
  89. package/dist/psql/io/lineEditor/filename.js +22 -22
  90. package/dist/psql/io/lineEditor/index.js +65 -62
  91. package/dist/psql/io/lineEditor/keymap.js +325 -318
  92. package/dist/psql/io/lineEditor/vt100.js +60 -60
  93. package/dist/psql/io/pgpass.js +18 -18
  94. package/dist/psql/io/pgservice.js +14 -14
  95. package/dist/psql/io/psqlrc.js +46 -46
  96. package/dist/psql/print/aligned.js +175 -166
  97. package/dist/psql/print/asciidoc.js +51 -51
  98. package/dist/psql/print/crosstab.js +34 -31
  99. package/dist/psql/print/csv.js +25 -22
  100. package/dist/psql/print/html.js +54 -54
  101. package/dist/psql/print/json.js +12 -12
  102. package/dist/psql/print/latex.js +118 -118
  103. package/dist/psql/print/pager.js +28 -26
  104. package/dist/psql/print/troff.js +48 -48
  105. package/dist/psql/print/unaligned.js +15 -14
  106. package/dist/psql/print/units.js +17 -17
  107. package/dist/psql/scanner/slash.js +48 -46
  108. package/dist/psql/scanner/sql.js +88 -84
  109. package/dist/psql/scanner/stringutils.js +21 -17
  110. package/dist/psql/types/index.js +7 -7
  111. package/dist/psql/types/scanner.js +8 -8
  112. package/dist/psql/wire/connection.js +341 -327
  113. package/dist/psql/wire/copy.js +7 -7
  114. package/dist/psql/wire/pipeline.js +26 -24
  115. package/dist/psql/wire/protocol.js +102 -102
  116. package/dist/psql/wire/sasl.js +62 -62
  117. package/dist/psql/wire/tls.js +79 -73
  118. package/dist/storage_api.js +22 -23
  119. package/dist/test_utils/fixtures.js +74 -41
  120. package/dist/test_utils/oauth_server.js +5 -5
  121. package/dist/utils/api_enums.js +33 -0
  122. package/dist/utils/branch_notice.js +5 -5
  123. package/dist/utils/branch_picker.js +26 -26
  124. package/dist/utils/compute_units.js +4 -4
  125. package/dist/utils/enrichers.js +28 -16
  126. package/dist/utils/esbuild.js +28 -28
  127. package/dist/utils/formats.js +1 -1
  128. package/dist/utils/middlewares.js +3 -3
  129. package/dist/utils/package_manager.js +68 -0
  130. package/dist/utils/point_in_time.js +12 -12
  131. package/dist/utils/psql.js +30 -30
  132. package/dist/utils/string.js +2 -2
  133. package/dist/utils/ui.js +9 -9
  134. package/dist/utils/zip.js +1 -1
  135. package/dist/writer.js +17 -17
  136. package/package.json +10 -12
@@ -1,31 +1,31 @@
1
- import { detectAgent, enrichResponse, interactiveInit, orchestrate, routeDataStep, } from 'neon-init';
2
- import { sendError } from '../analytics.js';
3
- import { log } from '../log.js';
4
- export const command = 'init';
5
- export const describe = 'Initialize a project with Neon using your AI coding assistant';
1
+ import { detectAgent, enrichResponse, interactiveInit, orchestrate, routeDataStep, } from "neon-init";
2
+ import { sendError } from "../analytics.js";
3
+ import { log } from "../log.js";
4
+ export const command = "init";
5
+ export const describe = "Initialize a project with Neon using your AI coding assistant";
6
6
  export const builder = (yargs) => yargs
7
- .option('context-file', {
7
+ .option("context-file", {
8
8
  hidden: true,
9
9
  })
10
- .option('agent', {
11
- alias: 'a',
12
- type: 'boolean',
10
+ .option("agent", {
11
+ alias: "a",
12
+ type: "boolean",
13
13
  default: false,
14
- describe: 'Enable agent/JSON mode (agent type is auto-detected).',
14
+ describe: "Enable agent/JSON mode (agent type is auto-detected).",
15
15
  })
16
- .option('data', {
17
- type: 'string',
16
+ .option("data", {
17
+ type: "string",
18
18
  describe: 'JSON object with a "step" field to route to a specific phase and phase-specific options.',
19
19
  })
20
- .option('skip-migrations', {
21
- type: 'boolean',
20
+ .option("skip-migrations", {
21
+ type: "boolean",
22
22
  default: false,
23
- describe: 'Skip the migrations phase.',
23
+ describe: "Skip the migrations phase.",
24
24
  })
25
- .option('preview', {
26
- type: 'boolean',
25
+ .option("preview", {
26
+ type: "boolean",
27
27
  default: false,
28
- describe: 'Enable preview features (e.g. project bootstrapping from templates).',
28
+ describe: "Enable preview features (e.g. project bootstrapping from templates).",
29
29
  })
30
30
  .strict(false);
31
31
  export const handler = async (argv) => {
@@ -33,7 +33,8 @@ export const handler = async (argv) => {
33
33
  // Auto-detect agent from environment. When --agent is explicitly passed,
34
34
  // always detect (the user asked for agent mode). Otherwise, require
35
35
  // non-TTY stdin to distinguish agent from human in terminal.
36
- const agent = (argv.agent || !process.stdin.isTTY ? detectAgent() : null) || undefined;
36
+ const agent = (argv.agent || !process.stdin.isTTY ? detectAgent() : null) ||
37
+ undefined;
37
38
  const isAgentMode = argv.agent || agent !== undefined;
38
39
  // --data with a "step" field routes to the appropriate phase
39
40
  if (argv.data && isAgentMode) {
@@ -42,11 +43,11 @@ export const handler = async (argv) => {
42
43
  data = JSON.parse(argv.data);
43
44
  }
44
45
  catch {
45
- log.error('Invalid JSON in --data flag. Expected a JSON object.');
46
+ log.error("Invalid JSON in --data flag. Expected a JSON object.");
46
47
  process.exit(1);
47
48
  return;
48
49
  }
49
- if (typeof data.step === 'string') {
50
+ if (typeof data.step === "string") {
50
51
  const result = await routeDataStep(data, agent);
51
52
  log.info(JSON.stringify(enrichResponse(result), null, 2));
52
53
  return;
@@ -66,7 +67,7 @@ export const handler = async (argv) => {
66
67
  }
67
68
  catch {
68
69
  const exitError = new Error(`failed to run neon-init`);
69
- sendError(exitError, 'NEON_INIT_FAILED');
70
+ sendError(exitError, "NEON_INIT_FAILED");
70
71
  process.exit(1);
71
72
  }
72
73
  };
@@ -1,55 +1,55 @@
1
- import { writer } from '../writer.js';
2
- import { fillSingleProject } from '../utils/enrichers.js';
3
- import { projectUpdateRequest } from '../parameters.gen.js';
4
- import { log } from '../log.js';
1
+ import { log } from "../log.js";
2
+ import { projectUpdateRequest } from "../parameters.gen.js";
3
+ import { fillSingleProject } from "../utils/enrichers.js";
4
+ import { writer } from "../writer.js";
5
5
  const IP_ALLOW_FIELDS = [
6
- 'id',
7
- 'name',
8
- 'IP_addresses',
9
- 'protected_branches_only',
6
+ "id",
7
+ "name",
8
+ "IP_addresses",
9
+ "protected_branches_only",
10
10
  ];
11
- export const command = 'ip-allow';
12
- export const describe = 'Manage IP Allow';
11
+ export const command = "ip-allow";
12
+ export const describe = "Manage IP Allow";
13
13
  export const builder = (argv) => {
14
14
  return argv
15
- .usage('$0 ip-allow <sub-command> [options]')
15
+ .usage("$0 ip-allow <sub-command> [options]")
16
16
  .options({
17
- 'project-id': {
18
- describe: 'Project ID',
19
- type: 'string',
17
+ "project-id": {
18
+ describe: "Project ID",
19
+ type: "string",
20
20
  },
21
21
  })
22
22
  .middleware(fillSingleProject)
23
- .command('list', 'List the IP allowlist', (yargs) => yargs, async (args) => {
23
+ .command("list", "List the IP allowlist", (yargs) => yargs, async (args) => {
24
24
  await list(args);
25
25
  })
26
- .command('add [ips...]', 'Add IP addresses to the IP allowlist', (yargs) => yargs
27
- .usage('$0 ip-allow add [ips...]')
28
- .positional('ips', {
29
- describe: 'The list of IP addresses to add',
30
- type: 'string',
26
+ .command("add [ips...]", "Add IP addresses to the IP allowlist", (yargs) => yargs
27
+ .usage("$0 ip-allow add [ips...]")
28
+ .positional("ips", {
29
+ describe: "The list of IP addresses to add",
30
+ type: "string",
31
31
  default: [],
32
32
  array: true,
33
33
  })
34
34
  .options({
35
- 'protected-only': {
36
- describe: projectUpdateRequest['project.settings.allowed_ips.protected_branches_only'].description,
37
- type: 'boolean',
35
+ "protected-only": {
36
+ describe: projectUpdateRequest["project.settings.allowed_ips.protected_branches_only"].description,
37
+ type: "boolean",
38
38
  },
39
39
  }), async (args) => {
40
40
  await add(args);
41
41
  })
42
- .command('remove [ips...]', 'Remove IP addresses from the IP allowlist', (yargs) => yargs.usage('$0 ip-allow remove [ips...]').positional('ips', {
43
- describe: 'The list of IP addresses to remove',
44
- type: 'string',
42
+ .command("remove [ips...]", "Remove IP addresses from the IP allowlist", (yargs) => yargs.usage("$0 ip-allow remove [ips...]").positional("ips", {
43
+ describe: "The list of IP addresses to remove",
44
+ type: "string",
45
45
  default: [],
46
46
  array: true,
47
47
  }), async (args) => {
48
48
  await remove(args);
49
49
  })
50
- .command('reset [ips...]', 'Reset the IP allowlist', (yargs) => yargs.usage('$0 ip-allow reset [ips...]').positional('ips', {
51
- describe: 'The list of IP addresses to reset',
52
- type: 'string',
50
+ .command("reset [ips...]", "Reset the IP allowlist", (yargs) => yargs.usage("$0 ip-allow reset [ips...]").positional("ips", {
51
+ describe: "The list of IP addresses to reset",
52
+ type: "string",
53
53
  default: [],
54
54
  array: true,
55
55
  }), async (args) => {