UNPKG

waterline-postgresql

Version:
55 lines (52 loc) 1.26 kB
import url from 'url' import {parse as parsePG} from 'pg-connection-string' export default function parseConnectionString(str) { var parsed = url.parse(str) var protocol = parsed.protocol if (protocol && protocol.indexOf('maria') === 0) { protocol = 'maria' } if (protocol === null) { return { client: 'sqlite3', connection: { filename: str } } } if (protocol.slice(-1) === ':') { protocol = protocol.slice(0, -1); } return { client: protocol, connection: protocol === 'postgres' ? parsePG(str) : connectionObject(parsed) } } function connectionObject(parsed) { var connection = {}; var db = parsed.pathname; if (db[0] === '/') { db = db.slice(1) } if (parsed.protocol.indexOf('maria') === 0) { connection.db = db } else { connection.database = db } if (parsed.hostname) { connection.host = parsed.hostname; } if (parsed.port) { connection.port = parsed.port; } if (parsed.auth) { var idx = parsed.auth.indexOf(':'); if (idx !== -1) { connection.user = parsed.auth.slice(0, idx); if (idx < parsed.auth.length - 1) { connection.password = parsed.auth.slice(idx + 1); } } } return connection }