neonctl 2.28.0 → 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 (135) hide show
  1. package/README.md +2 -2
  2. package/dist/analytics.js +35 -33
  3. package/dist/api.js +34 -34
  4. package/dist/auth.js +50 -44
  5. package/dist/cli.js +2 -2
  6. package/dist/commands/auth.js +58 -52
  7. package/dist/commands/bootstrap.js +115 -157
  8. package/dist/commands/branches.js +154 -147
  9. package/dist/commands/bucket.js +124 -118
  10. package/dist/commands/checkout.js +49 -49
  11. package/dist/commands/config.js +212 -88
  12. package/dist/commands/connection_string.js +62 -62
  13. package/dist/commands/data_api.js +96 -96
  14. package/dist/commands/databases.js +23 -23
  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 +97 -98
  19. package/dist/commands/index.js +26 -26
  20. package/dist/commands/init.js +23 -22
  21. package/dist/commands/ip_allow.js +29 -29
  22. package/dist/commands/link.js +223 -166
  23. package/dist/commands/neon_auth.js +381 -363
  24. package/dist/commands/operations.js +11 -11
  25. package/dist/commands/orgs.js +8 -8
  26. package/dist/commands/projects.js +101 -99
  27. package/dist/commands/psql.js +31 -31
  28. package/dist/commands/roles.js +21 -21
  29. package/dist/commands/schema_diff.js +23 -23
  30. package/dist/commands/set_context.js +17 -17
  31. package/dist/commands/status.js +17 -17
  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 +23 -16
  37. package/dist/current_branch_fast_path.js +6 -6
  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 +19 -19
  45. package/dist/functions_api.js +10 -10
  46. package/dist/help.js +15 -15
  47. package/dist/index.js +94 -92
  48. package/dist/log.js +2 -2
  49. package/dist/pkg.js +5 -5
  50. package/dist/psql/cli.js +4 -2
  51. package/dist/psql/command/cmd_cond.js +61 -61
  52. package/dist/psql/command/cmd_connect.js +159 -154
  53. package/dist/psql/command/cmd_copy.js +107 -97
  54. package/dist/psql/command/cmd_describe.js +368 -363
  55. package/dist/psql/command/cmd_format.js +276 -263
  56. package/dist/psql/command/cmd_io.js +269 -263
  57. package/dist/psql/command/cmd_lo.js +74 -66
  58. package/dist/psql/command/cmd_meta.js +148 -148
  59. package/dist/psql/command/cmd_misc.js +17 -17
  60. package/dist/psql/command/cmd_pipeline.js +142 -135
  61. package/dist/psql/command/cmd_restrict.js +25 -25
  62. package/dist/psql/command/cmd_show.js +183 -168
  63. package/dist/psql/command/dispatch.js +26 -26
  64. package/dist/psql/command/shared.js +14 -14
  65. package/dist/psql/complete/filenames.js +16 -16
  66. package/dist/psql/complete/index.js +4 -4
  67. package/dist/psql/complete/matcher.js +33 -32
  68. package/dist/psql/complete/psqlVars.js +173 -173
  69. package/dist/psql/complete/queries.js +5 -3
  70. package/dist/psql/complete/rules.js +900 -863
  71. package/dist/psql/core/common.js +136 -133
  72. package/dist/psql/core/help.js +343 -343
  73. package/dist/psql/core/mainloop.js +160 -153
  74. package/dist/psql/core/prompt.js +126 -123
  75. package/dist/psql/core/settings.js +111 -111
  76. package/dist/psql/core/sqlHelp.js +150 -150
  77. package/dist/psql/core/startup.js +211 -205
  78. package/dist/psql/core/syncVars.js +14 -14
  79. package/dist/psql/core/variables.js +24 -24
  80. package/dist/psql/describe/formatters.js +302 -289
  81. package/dist/psql/describe/processNamePattern.js +28 -28
  82. package/dist/psql/describe/queries.js +656 -651
  83. package/dist/psql/index.js +436 -411
  84. package/dist/psql/io/history.js +36 -36
  85. package/dist/psql/io/input.js +15 -15
  86. package/dist/psql/io/lineEditor/buffer.js +27 -25
  87. package/dist/psql/io/lineEditor/complete.js +15 -15
  88. package/dist/psql/io/lineEditor/filename.js +22 -22
  89. package/dist/psql/io/lineEditor/index.js +65 -62
  90. package/dist/psql/io/lineEditor/keymap.js +325 -318
  91. package/dist/psql/io/lineEditor/vt100.js +60 -60
  92. package/dist/psql/io/pgpass.js +18 -18
  93. package/dist/psql/io/pgservice.js +14 -14
  94. package/dist/psql/io/psqlrc.js +46 -46
  95. package/dist/psql/print/aligned.js +175 -166
  96. package/dist/psql/print/asciidoc.js +51 -51
  97. package/dist/psql/print/crosstab.js +34 -31
  98. package/dist/psql/print/csv.js +25 -22
  99. package/dist/psql/print/html.js +54 -54
  100. package/dist/psql/print/json.js +12 -12
  101. package/dist/psql/print/latex.js +118 -118
  102. package/dist/psql/print/pager.js +28 -26
  103. package/dist/psql/print/troff.js +48 -48
  104. package/dist/psql/print/unaligned.js +15 -14
  105. package/dist/psql/print/units.js +17 -17
  106. package/dist/psql/scanner/slash.js +48 -46
  107. package/dist/psql/scanner/sql.js +88 -84
  108. package/dist/psql/scanner/stringutils.js +21 -17
  109. package/dist/psql/types/index.js +7 -7
  110. package/dist/psql/types/scanner.js +8 -8
  111. package/dist/psql/wire/connection.js +341 -327
  112. package/dist/psql/wire/copy.js +7 -7
  113. package/dist/psql/wire/pipeline.js +26 -24
  114. package/dist/psql/wire/protocol.js +102 -102
  115. package/dist/psql/wire/sasl.js +62 -62
  116. package/dist/psql/wire/tls.js +79 -73
  117. package/dist/storage_api.js +15 -15
  118. package/dist/test_utils/fixtures.js +34 -31
  119. package/dist/test_utils/oauth_server.js +5 -5
  120. package/dist/utils/api_enums.js +13 -13
  121. package/dist/utils/branch_notice.js +5 -5
  122. package/dist/utils/branch_picker.js +26 -26
  123. package/dist/utils/compute_units.js +4 -4
  124. package/dist/utils/enrichers.js +20 -15
  125. package/dist/utils/esbuild.js +28 -28
  126. package/dist/utils/formats.js +1 -1
  127. package/dist/utils/middlewares.js +3 -3
  128. package/dist/utils/package_manager.js +68 -0
  129. package/dist/utils/point_in_time.js +12 -12
  130. package/dist/utils/psql.js +30 -30
  131. package/dist/utils/string.js +2 -2
  132. package/dist/utils/ui.js +9 -9
  133. package/dist/utils/zip.js +1 -1
  134. package/dist/writer.js +17 -17
  135. package/package.json +6 -7
@@ -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) => {