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/database.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/database.rb')
-rw-r--r-- | lib/dbshell/client/database.rb | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/dbshell/client/database.rb b/lib/dbshell/client/database.rb new file mode 100644 index 0000000..edea777 --- /dev/null +++ b/lib/dbshell/client/database.rb @@ -0,0 +1,24 @@ +require 'dbshell/sqlite3_client' +require 'dbshell/postgres_client' + +class DBShell::DatabaseClient + def self.handler(connection_params) + case connection_params['adapter'] + when 'sqlite3' + DBShell::Sqlite3Client + when 'postgresql' + DBShell::PostgresClient + else + raise DBShell::InvalidDatabaseAdapter + end + end + + def self.runshell(connection_params) + self + .handler(connection_params) + .runshell(connection_params) + end +end + + +class DBShell::InvalidDatabaseAdapter < StandardError; end |