netlify-cli 24.9.0 → 24.10.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.
- package/dist/commands/database/connect.d.ts +7 -0
- package/dist/commands/database/connect.d.ts.map +1 -0
- package/dist/commands/database/connect.js +119 -0
- package/dist/commands/database/connect.js.map +1 -0
- package/dist/commands/database/database.d.ts.map +1 -1
- package/dist/commands/database/database.js +15 -0
- package/dist/commands/database/database.js.map +1 -1
- package/dist/commands/database/db-connection.d.ts +7 -0
- package/dist/commands/database/db-connection.d.ts.map +1 -1
- package/dist/commands/database/db-connection.js +22 -8
- package/dist/commands/database/db-connection.js.map +1 -1
- package/dist/commands/database/meta-commands.d.ts +18 -0
- package/dist/commands/database/meta-commands.d.ts.map +1 -0
- package/dist/commands/database/meta-commands.js +51 -0
- package/dist/commands/database/meta-commands.js.map +1 -0
- package/dist/commands/database/psql-formatter.d.ts +3 -0
- package/dist/commands/database/psql-formatter.d.ts.map +1 -0
- package/dist/commands/database/psql-formatter.js +47 -0
- package/dist/commands/database/psql-formatter.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/npm-shrinkwrap.json +2 -2
- package/package.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../../../src/commands/database/connect.ts"],"names":[],"mappings":"AAGA,OAAO,WAAW,MAAM,oBAAoB,CAAA;AAK5C,MAAM,WAAW,cAAc;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AAED,eAAO,MAAM,OAAO,GAAU,SAAS,cAAc,EAAE,SAAS,WAAW,KAAG,OAAO,CAAC,IAAI,CAuHzF,CAAA"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import readline from 'readline';
|
|
2
|
+
import { log, logJson } from '../../utils/command-helpers.js';
|
|
3
|
+
import { connectRawClient } from './db-connection.js';
|
|
4
|
+
import { executeMetaCommand } from './meta-commands.js';
|
|
5
|
+
import { formatQueryResult } from './psql-formatter.js';
|
|
6
|
+
export const connect = async (options, command) => {
|
|
7
|
+
const buildDir = command.netlify.site.root ?? command.project.root ?? command.project.baseDirectory;
|
|
8
|
+
if (!buildDir) {
|
|
9
|
+
throw new Error('Could not determine the project root directory.');
|
|
10
|
+
}
|
|
11
|
+
const { client, connectionString, cleanup } = await connectRawClient(buildDir);
|
|
12
|
+
// --json without --query: print connection details
|
|
13
|
+
if (options.json && !options.query) {
|
|
14
|
+
logJson({ connection_string: connectionString, context: 'dev' });
|
|
15
|
+
await cleanup();
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
log(`Connected to ${connectionString}`);
|
|
19
|
+
// --query: one-shot mode
|
|
20
|
+
if (options.query) {
|
|
21
|
+
try {
|
|
22
|
+
const result = await client.query(options.query);
|
|
23
|
+
if (options.json) {
|
|
24
|
+
logJson(result.rows);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
log(formatQueryResult(result.fields, result.rows, result.rowCount, result.command));
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
finally {
|
|
31
|
+
await cleanup();
|
|
32
|
+
}
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
// Interactive REPL
|
|
36
|
+
const rl = readline.createInterface({
|
|
37
|
+
input: process.stdin,
|
|
38
|
+
output: process.stdout,
|
|
39
|
+
prompt: 'netlifydb=> ',
|
|
40
|
+
});
|
|
41
|
+
let buffer = '';
|
|
42
|
+
const handleCleanup = async () => {
|
|
43
|
+
rl.close();
|
|
44
|
+
await cleanup();
|
|
45
|
+
};
|
|
46
|
+
process.on('SIGINT', () => {
|
|
47
|
+
if (buffer) {
|
|
48
|
+
// Cancel current multi-line input
|
|
49
|
+
buffer = '';
|
|
50
|
+
process.stdout.write('\n');
|
|
51
|
+
rl.setPrompt('netlifydb=> ');
|
|
52
|
+
rl.prompt();
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
log('');
|
|
56
|
+
void handleCleanup();
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
rl.on('close', () => {
|
|
60
|
+
void handleCleanup();
|
|
61
|
+
});
|
|
62
|
+
rl.on('line', (line) => {
|
|
63
|
+
// Meta-commands are only recognized at the start of input (not mid-statement)
|
|
64
|
+
if (buffer === '' && line.trimStart().startsWith('\\')) {
|
|
65
|
+
rl.pause();
|
|
66
|
+
void (async () => {
|
|
67
|
+
try {
|
|
68
|
+
const result = await executeMetaCommand(line, client);
|
|
69
|
+
switch (result.type) {
|
|
70
|
+
case 'quit':
|
|
71
|
+
await handleCleanup();
|
|
72
|
+
return;
|
|
73
|
+
case 'help':
|
|
74
|
+
log(result.text);
|
|
75
|
+
break;
|
|
76
|
+
case 'unknown':
|
|
77
|
+
log(`Invalid command ${result.command}. Try \\? for help.`);
|
|
78
|
+
break;
|
|
79
|
+
case 'query':
|
|
80
|
+
log(formatQueryResult(result.fields, result.rows, result.rowCount, result.command));
|
|
81
|
+
break;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
catch (err) {
|
|
85
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
86
|
+
log(`ERROR: ${message}`);
|
|
87
|
+
}
|
|
88
|
+
rl.resume();
|
|
89
|
+
rl.prompt();
|
|
90
|
+
})();
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
buffer += (buffer ? '\n' : '') + line;
|
|
94
|
+
if (buffer.trimEnd().endsWith(';')) {
|
|
95
|
+
const sql = buffer;
|
|
96
|
+
buffer = '';
|
|
97
|
+
rl.setPrompt('netlifydb=> ');
|
|
98
|
+
rl.pause();
|
|
99
|
+
void (async () => {
|
|
100
|
+
try {
|
|
101
|
+
const result = await client.query(sql);
|
|
102
|
+
log(formatQueryResult(result.fields, result.rows, result.rowCount, result.command));
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
106
|
+
log(`ERROR: ${message}`);
|
|
107
|
+
}
|
|
108
|
+
rl.resume();
|
|
109
|
+
rl.prompt();
|
|
110
|
+
})();
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
rl.setPrompt('netlifydb-> ');
|
|
114
|
+
rl.prompt();
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
rl.prompt();
|
|
118
|
+
};
|
|
119
|
+
//# sourceMappingURL=connect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connect.js","sourceRoot":"","sources":["../../../src/commands/database/connect.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/commands/database/database.ts"],"names":[],"mappings":"AAEA,OAAO,WAAW,MAAM,oBAAoB,CAAA;AAI5C,MAAM,MAAM,SAAS,GAAG;IACtB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,MAAM,CAAA;IACnB,eAAe,EAAE,OAAO,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;IACjB,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,MAAM,CAAA;CAChB,CAAA;AAID,eAAO,MAAM,qBAAqB,GAAI,SAAS,WAAW,
|
|
1
|
+
{"version":3,"file":"database.d.ts","sourceRoot":"","sources":["../../../src/commands/database/database.ts"],"names":[],"mappings":"AAEA,OAAO,WAAW,MAAM,oBAAoB,CAAA;AAI5C,MAAM,MAAM,SAAS,GAAG;IACtB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,MAAM,CAAA;IACnB,eAAe,EAAE,OAAO,CAAA;CACzB,CAAA;AAED,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;IACjB,GAAG,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,MAAM,CAAA;CAChB,CAAA;AAID,eAAO,MAAM,qBAAqB,GAAI,SAAS,WAAW,SA+HzD,CAAA"}
|
|
@@ -54,6 +54,21 @@ export const createDatabaseCommand = (program) => {
|
|
|
54
54
|
await status(options, command);
|
|
55
55
|
});
|
|
56
56
|
if (process.env.EXPERIMENTAL_NETLIFY_DB_ENABLED === '1') {
|
|
57
|
+
dbCommand
|
|
58
|
+
.command('connect')
|
|
59
|
+
.description('Connect to the database')
|
|
60
|
+
.option('-q, --query <sql>', 'Execute a single query and exit')
|
|
61
|
+
.option('--json', 'Output query results as JSON. When used without --query, prints the connection details as JSON instead.')
|
|
62
|
+
.action(async (options, command) => {
|
|
63
|
+
const { connect } = await import('./connect.js');
|
|
64
|
+
await connect(options, command);
|
|
65
|
+
})
|
|
66
|
+
.addExamples([
|
|
67
|
+
'netlify db connect',
|
|
68
|
+
'netlify db connect --query "SELECT * FROM users"',
|
|
69
|
+
'netlify db connect --json --query "SELECT * FROM users"',
|
|
70
|
+
'netlify db connect --json',
|
|
71
|
+
]);
|
|
57
72
|
dbCommand
|
|
58
73
|
.command('migrate')
|
|
59
74
|
.description('Apply database migrations to the local development database')
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"database.js","sourceRoot":"","sources":["../../../src/commands/database/database.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"database.js","sourceRoot":"","sources":["../../../src/commands/database/database.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,15 @@
|
|
|
1
|
+
import { Client } from 'pg';
|
|
1
2
|
import { type SQLExecutor } from '@netlify/dev';
|
|
2
3
|
interface DBConnection {
|
|
3
4
|
executor: SQLExecutor;
|
|
4
5
|
cleanup: () => Promise<void>;
|
|
5
6
|
}
|
|
6
7
|
export declare function connectToDatabase(buildDir: string): Promise<DBConnection>;
|
|
8
|
+
interface RawDBConnection {
|
|
9
|
+
client: Client;
|
|
10
|
+
connectionString: string;
|
|
11
|
+
cleanup: () => Promise<void>;
|
|
12
|
+
}
|
|
13
|
+
export declare function connectRawClient(buildDir: string): Promise<RawDBConnection>;
|
|
7
14
|
export {};
|
|
8
15
|
//# sourceMappingURL=db-connection.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"db-connection.d.ts","sourceRoot":"","sources":["../../../src/commands/database/db-connection.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"db-connection.d.ts","sourceRoot":"","sources":["../../../src/commands/database/db-connection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAA;AAE3B,OAAO,EAAc,KAAK,WAAW,EAAE,MAAM,cAAc,CAAA;AAK3D,UAAU,YAAY;IACpB,QAAQ,EAAE,WAAW,CAAA;IACrB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAC7B;AAED,wBAAsB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC,CAM/E;AAED,UAAU,eAAe;IACvB,MAAM,EAAE,MAAM,CAAA;IACd,gBAAgB,EAAE,MAAM,CAAA;IACxB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAC7B;AAED,wBAAsB,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC,CAgDjF"}
|
|
@@ -3,13 +3,21 @@ import { NetlifyDev } from '@netlify/dev';
|
|
|
3
3
|
import { LocalState } from '@netlify/dev-utils';
|
|
4
4
|
import { PgClientExecutor } from './pg-client-executor.js';
|
|
5
5
|
export async function connectToDatabase(buildDir) {
|
|
6
|
+
const { client, cleanup } = await connectRawClient(buildDir);
|
|
7
|
+
return {
|
|
8
|
+
executor: new PgClientExecutor(client),
|
|
9
|
+
cleanup,
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export async function connectRawClient(buildDir) {
|
|
6
13
|
const state = new LocalState(buildDir);
|
|
7
|
-
const
|
|
8
|
-
if (
|
|
9
|
-
const client = new Client({ connectionString });
|
|
14
|
+
const storedConnectionString = state.get('dbConnectionString');
|
|
15
|
+
if (storedConnectionString) {
|
|
16
|
+
const client = new Client({ connectionString: storedConnectionString });
|
|
10
17
|
await client.connect();
|
|
11
18
|
return {
|
|
12
|
-
|
|
19
|
+
client,
|
|
20
|
+
connectionString: storedConnectionString,
|
|
13
21
|
cleanup: () => client.end(),
|
|
14
22
|
};
|
|
15
23
|
}
|
|
@@ -28,14 +36,20 @@ export async function connectToDatabase(buildDir) {
|
|
|
28
36
|
serverAddress: null,
|
|
29
37
|
});
|
|
30
38
|
await netlifyDev.start();
|
|
31
|
-
const
|
|
32
|
-
if (!
|
|
39
|
+
const connectionString = state.get('dbConnectionString');
|
|
40
|
+
if (!connectionString) {
|
|
33
41
|
await netlifyDev.stop();
|
|
34
42
|
throw new Error('Local database failed to start. Set EXPERIMENTAL_NETLIFY_DB_ENABLED=1 to enable.');
|
|
35
43
|
}
|
|
44
|
+
const client = new Client({ connectionString });
|
|
45
|
+
await client.connect();
|
|
36
46
|
return {
|
|
37
|
-
|
|
38
|
-
|
|
47
|
+
client,
|
|
48
|
+
connectionString,
|
|
49
|
+
cleanup: async () => {
|
|
50
|
+
await client.end();
|
|
51
|
+
await netlifyDev.stop();
|
|
52
|
+
},
|
|
39
53
|
};
|
|
40
54
|
}
|
|
41
55
|
//# sourceMappingURL=db-connection.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"db-connection.js","sourceRoot":"","sources":["../../../src/commands/database/db-connection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAA;AAE3B,OAAO,EAAE,UAAU,EAAoB,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAO1D,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,QAAgB;IACtD,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAA;IACtC,MAAM,
|
|
1
|
+
{"version":3,"file":"db-connection.js","sourceRoot":"","sources":["../../../src/commands/database/db-connection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,IAAI,CAAA;AAE3B,OAAO,EAAE,UAAU,EAAoB,MAAM,cAAc,CAAA;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAO1D,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,QAAgB;IACtD,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,gBAAgB,CAAC,QAAQ,CAAC,CAAA;IAC5D,OAAO;QACL,QAAQ,EAAE,IAAI,gBAAgB,CAAC,MAAM,CAAC;QACtC,OAAO;KACR,CAAA;AACH,CAAC;AAQD,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,QAAgB;IACrD,MAAM,KAAK,GAAG,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAA;IACtC,MAAM,sBAAsB,GAAG,KAAK,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAA;IAE9D,IAAI,sBAAsB,EAAE,CAAC;QAC3B,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,CAAC,CAAA;QACvE,MAAM,MAAM,CAAC,OAAO,EAAE,CAAA;QACtB,OAAO;YACL,MAAM;YACN,gBAAgB,EAAE,sBAAsB;YACxC,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,EAAE;SAC5B,CAAA;IACH,CAAC;IAED,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC;QAChC,WAAW,EAAE,QAAQ;QACrB,SAAS,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC7B,KAAK,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QACzB,aAAa,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QACjC,oBAAoB,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QACxC,SAAS,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC7B,WAAW,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC/B,OAAO,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC3B,MAAM,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC1B,SAAS,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC7B,WAAW,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;QAC/B,aAAa,EAAE,IAAI;KACpB,CAAC,CAAA;IAEF,MAAM,UAAU,CAAC,KAAK,EAAE,CAAA;IAExB,MAAM,gBAAgB,GAAG,KAAK,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAA;IACxD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,MAAM,UAAU,CAAC,IAAI,EAAE,CAAA;QACvB,MAAM,IAAI,KAAK,CAAC,kFAAkF,CAAC,CAAA;IACrG,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAC,CAAA;IAC/C,MAAM,MAAM,CAAC,OAAO,EAAE,CAAA;IAEtB,OAAO;QACL,MAAM;QACN,gBAAgB;QAChB,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,MAAM,MAAM,CAAC,GAAG,EAAE,CAAA;YAClB,MAAM,UAAU,CAAC,IAAI,EAAE,CAAA;QACzB,CAAC;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { Client, FieldDef } from 'pg';
|
|
2
|
+
export type MetaCommandResult = {
|
|
3
|
+
type: 'query';
|
|
4
|
+
fields: FieldDef[];
|
|
5
|
+
rows: Record<string, unknown>[];
|
|
6
|
+
rowCount: number | null;
|
|
7
|
+
command: string;
|
|
8
|
+
} | {
|
|
9
|
+
type: 'quit';
|
|
10
|
+
} | {
|
|
11
|
+
type: 'help';
|
|
12
|
+
text: string;
|
|
13
|
+
} | {
|
|
14
|
+
type: 'unknown';
|
|
15
|
+
command: string;
|
|
16
|
+
};
|
|
17
|
+
export declare const executeMetaCommand: (input: string, client: Client) => Promise<MetaCommandResult>;
|
|
18
|
+
//# sourceMappingURL=meta-commands.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"meta-commands.d.ts","sourceRoot":"","sources":["../../../src/commands/database/meta-commands.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAA;AAE1C,MAAM,MAAM,iBAAiB,GACzB;IAAE,IAAI,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,GAChH;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,GAChB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAC9B;IAAE,IAAI,EAAE,SAAS,CAAC;IAAC,OAAO,EAAE,MAAM,CAAA;CAAE,CAAA;AAcxC,eAAO,MAAM,kBAAkB,GAAU,OAAO,MAAM,EAAE,QAAQ,MAAM,KAAG,OAAO,CAAC,iBAAiB,CAmDjG,CAAA"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
const HELP_TEXT = `Netlify DB interactive client. Supports a subset of psql commands.
|
|
2
|
+
|
|
3
|
+
General
|
|
4
|
+
\\q quit
|
|
5
|
+
|
|
6
|
+
Informational
|
|
7
|
+
\\d list tables
|
|
8
|
+
\\dt list tables
|
|
9
|
+
\\d NAME describe table
|
|
10
|
+
\\l list databases
|
|
11
|
+
\\? show this help`;
|
|
12
|
+
export const executeMetaCommand = async (input, client) => {
|
|
13
|
+
const trimmed = input.trim();
|
|
14
|
+
const [cmd, ...args] = trimmed.split(/\s+/);
|
|
15
|
+
if (cmd === '\\q') {
|
|
16
|
+
return { type: 'quit' };
|
|
17
|
+
}
|
|
18
|
+
if (cmd === '\\?') {
|
|
19
|
+
return { type: 'help', text: HELP_TEXT };
|
|
20
|
+
}
|
|
21
|
+
if (cmd === '\\dt' || (cmd === '\\d' && args.length === 0)) {
|
|
22
|
+
const result = await client.query(`SELECT schemaname AS "Schema", tablename AS "Name", tableowner AS "Owner"
|
|
23
|
+
FROM pg_tables
|
|
24
|
+
WHERE schemaname NOT IN ('pg_catalog', 'information_schema')
|
|
25
|
+
ORDER BY schemaname, tablename`);
|
|
26
|
+
return { type: 'query', fields: result.fields, rows: result.rows, rowCount: result.rowCount, command: 'SELECT' };
|
|
27
|
+
}
|
|
28
|
+
if (cmd === '\\d' && args.length > 0) {
|
|
29
|
+
const tableName = args[0];
|
|
30
|
+
const result = await client.query(`SELECT column_name AS "Column", data_type AS "Type",
|
|
31
|
+
CASE WHEN is_nullable = 'YES' THEN 'yes' ELSE 'no' END AS "Nullable",
|
|
32
|
+
column_default AS "Default"
|
|
33
|
+
FROM information_schema.columns
|
|
34
|
+
WHERE table_schema = 'public' AND table_name = $1
|
|
35
|
+
ORDER BY ordinal_position`, [tableName]);
|
|
36
|
+
if (result.rowCount === 0) {
|
|
37
|
+
return { type: 'query', fields: result.fields, rows: result.rows, rowCount: 0, command: 'SELECT' };
|
|
38
|
+
}
|
|
39
|
+
return { type: 'query', fields: result.fields, rows: result.rows, rowCount: result.rowCount, command: 'SELECT' };
|
|
40
|
+
}
|
|
41
|
+
if (cmd === '\\l') {
|
|
42
|
+
const result = await client.query(`SELECT datname AS "Name",
|
|
43
|
+
pg_catalog.pg_get_userbyid(datdba) AS "Owner",
|
|
44
|
+
pg_catalog.pg_encoding_to_char(encoding) AS "Encoding"
|
|
45
|
+
FROM pg_catalog.pg_database
|
|
46
|
+
ORDER BY 1`);
|
|
47
|
+
return { type: 'query', fields: result.fields, rows: result.rows, rowCount: result.rowCount, command: 'SELECT' };
|
|
48
|
+
}
|
|
49
|
+
return { type: 'unknown', command: cmd };
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=meta-commands.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"meta-commands.js","sourceRoot":"","sources":["../../../src/commands/database/meta-commands.ts"],"names":[],"mappings":"AAQA,MAAM,SAAS,GAAG;;;;;;;;;;8BAUY,CAAA;AAE9B,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,KAAa,EAAE,MAAc,EAA8B,EAAE;IACpG,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAA;IAC5B,MAAM,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;IAE3C,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QAClB,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAA;IACzB,CAAC;IAED,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QAClB,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,CAAA;IAC1C,CAAC;IAED,IAAI,GAAG,KAAK,MAAM,IAAI,CAAC,GAAG,KAAK,KAAK,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE,CAAC;QAC3D,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAC/B;;;sCAGgC,CACjC,CAAA;QACD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;IAClH,CAAC;IAED,IAAI,GAAG,KAAK,KAAK,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACrC,MAAM,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,CAAA;QACzB,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAC/B;;;;;iCAK2B,EAC3B,CAAC,SAAS,CAAC,CACZ,CAAA;QACD,IAAI,MAAM,CAAC,QAAQ,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;QACpG,CAAC;QACD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;IAClH,CAAC;IAED,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QAClB,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,KAAK,CAC/B;;;;kBAIY,CACb,CAAA;QACD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;IAClH,CAAC;IAED,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,EAAE,CAAA;AAC1C,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"psql-formatter.d.ts","sourceRoot":"","sources":["../../../src/commands/database/psql-formatter.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAA;AAkBlC,eAAO,MAAM,iBAAiB,GAC5B,QAAQ,QAAQ,EAAE,EAClB,MAAM,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,EAC/B,UAAU,MAAM,GAAG,IAAI,EACvB,SAAS,MAAM,KACd,MAuCF,CAAA"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
const formatValue = (value) => {
|
|
2
|
+
if (value === null || value === undefined) {
|
|
3
|
+
return '';
|
|
4
|
+
}
|
|
5
|
+
if (value instanceof Date) {
|
|
6
|
+
return value.toISOString();
|
|
7
|
+
}
|
|
8
|
+
if (typeof value === 'object') {
|
|
9
|
+
return JSON.stringify(value);
|
|
10
|
+
}
|
|
11
|
+
if (typeof value === 'string') {
|
|
12
|
+
return value;
|
|
13
|
+
}
|
|
14
|
+
return String(value);
|
|
15
|
+
};
|
|
16
|
+
export const formatQueryResult = (fields, rows, rowCount, command) => {
|
|
17
|
+
if (fields.length === 0) {
|
|
18
|
+
// DDL or DML without returning clause
|
|
19
|
+
if (command === 'INSERT') {
|
|
20
|
+
return `INSERT 0 ${String(rowCount ?? 0)}`;
|
|
21
|
+
}
|
|
22
|
+
if (command === 'UPDATE' || command === 'DELETE') {
|
|
23
|
+
return `${command} ${String(rowCount ?? 0)}`;
|
|
24
|
+
}
|
|
25
|
+
return command;
|
|
26
|
+
}
|
|
27
|
+
const headers = fields.map((f) => f.name);
|
|
28
|
+
const stringRows = rows.map((row) => headers.map((h) => formatValue(row[h])));
|
|
29
|
+
const widths = headers.map((header, i) => {
|
|
30
|
+
const maxDataWidth = stringRows.reduce((max, row) => Math.max(max, row[i].length), 0);
|
|
31
|
+
return Math.max(header.length, maxDataWidth);
|
|
32
|
+
});
|
|
33
|
+
const lines = [];
|
|
34
|
+
// Header
|
|
35
|
+
lines.push(headers.map((h, i) => ` ${h.padEnd(widths[i])} `).join('|'));
|
|
36
|
+
// Separator
|
|
37
|
+
lines.push(widths.map((w) => '-'.repeat(w + 2)).join('+'));
|
|
38
|
+
// Rows
|
|
39
|
+
for (const row of stringRows) {
|
|
40
|
+
lines.push(row.map((val, i) => ` ${val.padEnd(widths[i])} `).join('|'));
|
|
41
|
+
}
|
|
42
|
+
// Footer
|
|
43
|
+
const count = rowCount ?? rows.length;
|
|
44
|
+
lines.push(`(${String(count)} ${count === 1 ? 'row' : 'rows'})`);
|
|
45
|
+
return lines.join('\n');
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=psql-formatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"psql-formatter.js","sourceRoot":"","sources":["../../../src/commands/database/psql-formatter.ts"],"names":[],"mappings":"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"}
|