From 374e600710eb977184c380b9ee3993dc646f203c Mon Sep 17 00:00:00 2001 From: chulanovskyi-bs <56116665+chulanovskyi-bs@users.noreply.github.com> Date: Thu, 31 Oct 2024 19:28:58 +0200 Subject: [PATCH] HCK-8611: connection string parser (#116) * fix: connection string parser * feat: improved connection string detection of mssql format * fix: connection string parser * fix: aligned improvements between plugins * fix: unified helpers --- .../helpers/parseConnectionString.js | 47 ++++++++++--------- 1 file changed, 24 insertions(+), 23 deletions(-) diff --git a/reverse_engineering/helpers/parseConnectionString.js b/reverse_engineering/helpers/parseConnectionString.js index f00faef..96781a9 100644 --- a/reverse_engineering/helpers/parseConnectionString.js +++ b/reverse_engineering/helpers/parseConnectionString.js @@ -1,5 +1,5 @@ -const { URL } = require('url'); const { ConnectionPool } = require('mssql'); +const { URL } = require('url'); const mssqlPrefix = 'mssql://'; const sqlserverPrefix = 'jdbc:sqlserver://'; @@ -8,9 +8,9 @@ const sqlserverPrefix = 'jdbc:sqlserver://'; const parseMssqlUrl = ({ url = '' }) => { const parsed = new URL(url); return { - database: parsed.pathname.slice(1), host: parsed.hostname, port: parsed.port ? Number(parsed.port) : null, + databaseName: parsed.pathname.slice(1), userName: parsed.username, userPassword: parsed.password, }; @@ -18,11 +18,11 @@ const parseMssqlUrl = ({ url = '' }) => { // example: jdbc:sqlserver://synapseworkspace.sql.azuresynapse.net:1433;databaseName=SampleDB;user=myusername@mytenant.onmicrosoft.com;password=myStrongPassword123;encrypt=true;trustServerCertificate=false;authentication=ActiveDirectoryPassword;loginTimeout=30; const parseSqlServerUrl = ({ url = '' }) => { - const [_protocol, params] = url.split(sqlserverPrefix); - const [server, ...paramParts] = params.split(';'); + const [_protocol, urlParams] = url.split(sqlserverPrefix); + const [server, ...paramParts] = urlParams.split(';'); const [host, port] = server.split(':'); - const parsedParams = paramParts.reduce((acc, part) => { + const params = paramParts.reduce((acc, part) => { const [key, value] = part.split('='); if (key && value) { acc[key] = value; @@ -31,33 +31,34 @@ const parseSqlServerUrl = ({ url = '' }) => { }, {}); return { - server: host, + host, port: port ? Number(port) : null, - database: parsedParams.databaseName, - user: parsedParams.user, - password: parsedParams.password, + databaseName: params.databaseName, + userName: params.user, + userPassword: params.password, + }; +}; + +// example: Server=tcp:synapseworkspace.sql.azuresynapse.net,1433;Database=SampleDB;Authentication=Active Directory Password;User ID=myusername@mytenant.onmicrosoft.com;Password=password;Encrypt=true;TrustServerCertificate=false;Connection Timeout=30; +const parseBasicString = ({ string = '' }) => { + const parsed = ConnectionPool.parseConnectionString(string); + return { + databaseName: parsed.database, + host: parsed.server, + port: parsed.port, + userName: parsed.user, + userPassword: parsed.password, }; }; -// Default connection string example: -// Server=host,1433;Database=DatabaseName;User Id=username;Password=password; const parseConnectionString = ({ string = '' }) => { - let params; if (string.startsWith(sqlserverPrefix)) { - params = parseSqlServerUrl({ url: string }); + return parseSqlServerUrl({ url: string }); } else if (string.startsWith(mssqlPrefix)) { - params = parseMssqlUrl({ url: string }); + return parseMssqlUrl({ url: string }); } else { - params = ConnectionPool.parseConnectionString(string); + return parseBasicString({ string }); } - - return { - databaseName: params.database, - host: params.server, - port: params.port, - userName: params.user, - userPassword: params.password, - }; }; module.exports = {