diff options
author | Teddy Wing | 2017-04-29 21:55:48 +0200 |
---|---|---|
committer | Teddy Wing | 2017-04-29 21:55:48 +0200 |
commit | b700c1bef89a67a64f1040fb6bb03c0320eefe91 (patch) | |
tree | c7173b62b8a7d6f33c41544e14139c8b5f4a6a5a /lib/dbshell/client/postgres.rb | |
parent | cf14e894685c695c7ecbaa2c119e2ea414afc00a (diff) | |
download | dbshell-rails-b700c1bef89a67a64f1040fb6bb03c0320eefe91.tar.bz2 |
Rename database client files to put them in a `Client` module
Will be modifying the class names in the next commit. Here we change the
file names & locations of the database client files.
The format changes thusly:
<adapter>_client.rb -> client/<adapter>.rb
This organisation feels cleaner to me. Wasn't liking the previous
structure.
Diffstat (limited to 'lib/dbshell/client/postgres.rb')
-rw-r--r-- | lib/dbshell/client/postgres.rb | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/dbshell/client/postgres.rb b/lib/dbshell/client/postgres.rb new file mode 100644 index 0000000..1c1c663 --- /dev/null +++ b/lib/dbshell/client/postgres.rb @@ -0,0 +1,23 @@ +class DBShell::PostgresClient + EXECUTABLE_NAME = 'psql' + + def self.runshell(db_info) + args = self.build_command(db_info) + exec(*args) + end + + def self.build_command(db_info) + args = [EXECUTABLE_NAME] + + host = db_info['host'] + port = db_info['port'] + db_name = db_info['database'] + user = db_info['username'] + password = db_info['password'] + + args.push('-U', user) if user + args.push('-h', host) if host + args.push('-p', port) if port + args.push(db_name) + end +end |