mystic 0.1.2 → 0.1.3
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.
- checksums.yaml +4 -4
- data/lib/mystic.rb +7 -1
- data/lib/mystic/model.rb +25 -21
- metadata +2 -2
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA1:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: d72462dbb17bb77c1cf67fd294286f52636bd68f
         | 
| 4 | 
            +
              data.tar.gz: e78d213ceb6133c03b24c00c959403bb51f3cc99
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 3ef965891e3f3dc4c1617511707bf6af8cf3e747512cd96f44d20964142c7e81f13793dba7350a1c60eec681ae58f533e894dac57c85c8beb84e77eaf785ede9
         | 
| 7 | 
            +
              data.tar.gz: 731b449bdc535b57cd0c22fd6bbc216c9f25b371b01e7a2e51e7386cf99701092c1358f93f4d0ce340915963b04e942644b712f14cf54c3e5eb81d239b57f05d
         | 
    
        data/lib/mystic.rb
    CHANGED
    
    | @@ -54,11 +54,17 @@ module Mystic | |
| 54 54 | 
             
                  conf[:user] = conf.delete :username
         | 
| 55 55 | 
             
                  raise MysticError, "Mystic only supports Postgres." unless /^postg.+$/i =~ conf[:adapter]
         | 
| 56 56 |  | 
| 57 | 
            -
                  @postgres = Postgres.new | 
| 57 | 
            +
                  @postgres = Postgres.new conf
         | 
| 58 58 |  | 
| 59 59 | 
             
                  @env
         | 
| 60 60 | 
             
                end
         | 
| 61 61 |  | 
| 62 | 
            +
                def manual_conn conf={}
         | 
| 63 | 
            +
                  load_env
         | 
| 64 | 
            +
                  @env = (ENV["RACK_ENV"] || ENV["RAILS_ENV"] || "development").to_s
         | 
| 65 | 
            +
                  @postgres = Postgres.new(conf)
         | 
| 66 | 
            +
                end
         | 
| 67 | 
            +
                
         | 
| 62 68 | 
             
            		def root path=Pathname.new(Dir.pwd)
         | 
| 63 69 | 
             
            			raise RootError, "Failed to find the application's root." if path == path.parent
         | 
| 64 70 | 
             
            			mystic_path = path.join "config", "database.yml"
         | 
    
        data/lib/mystic/model.rb
    CHANGED
    
    | @@ -8,7 +8,7 @@ module Mystic | |
| 8 8 |  | 
| 9 9 | 
             
                module ClassMethods
         | 
| 10 10 | 
             
                  def table_name
         | 
| 11 | 
            -
                    to_s.downcase
         | 
| 11 | 
            +
                    to_s.split("::").last.downcase
         | 
| 12 12 | 
             
                  end
         | 
| 13 13 |  | 
| 14 14 | 
             
              		def visible_cols
         | 
| @@ -26,19 +26,16 @@ module Mystic | |
| 26 26 | 
             
              			plural = opts[:plural] && op != "INSERT"
         | 
| 27 27 |  | 
| 28 28 | 
             
              			sql << " RETURNING #{visible_cols*','}" if return_rows && op != "SELECT"
         | 
| 29 | 
            -
             | 
| 29 | 
            +
                    
         | 
| 30 | 
            +
                    return sql unless return_json
         | 
| 31 | 
            +
                    
         | 
| 30 32 | 
             
              			s = []
         | 
| 31 | 
            -
             | 
| 32 | 
            -
             | 
| 33 | 
            -
             | 
| 34 | 
            -
             | 
| 35 | 
            -
             | 
| 36 | 
            -
             | 
| 37 | 
            -
              				s << "FROM res"
         | 
| 38 | 
            -
              			else
         | 
| 39 | 
            -
              				s << sql
         | 
| 40 | 
            -
              			end
         | 
| 41 | 
            -
            			
         | 
| 33 | 
            +
            				s << "WITH res AS (#{sql}) SELECT"
         | 
| 34 | 
            +
            				s << "array_to_json(array_agg(res))" if plural
         | 
| 35 | 
            +
            				s << "row_to_json(res)" unless plural
         | 
| 36 | 
            +
            				s << "AS #{Mystic::JSON_COL}"
         | 
| 37 | 
            +
            				s << "FROM res"
         | 
| 38 | 
            +
                    s << "LIMIT 1" unless plural
         | 
| 42 39 | 
             
              			s*' '
         | 
| 43 40 | 
             
              		end
         | 
| 44 41 |  | 
| @@ -60,7 +57,7 @@ module Mystic | |
| 60 57 | 
             
              				:sql => sql.join(' '),
         | 
| 61 58 | 
             
              				:return_rows => true,
         | 
| 62 59 | 
             
              				:return_json => sym_opts[:return_json],
         | 
| 63 | 
            -
              				:plural =>  | 
| 60 | 
            +
              				:plural => sym_opts[:fetch] == false
         | 
| 64 61 | 
             
              			)
         | 
| 65 62 | 
             
                  end
         | 
| 66 63 |  | 
| @@ -73,7 +70,8 @@ module Mystic | |
| 73 70 | 
             
              			wrapper_sql(
         | 
| 74 71 | 
             
              				:sql => "UPDATE #{table_name} SET #{set.sqlize*','} WHERE #{where.sqlize*' AND '}",
         | 
| 75 72 | 
             
              				:return_rows => sym_opts[:return_rows],
         | 
| 76 | 
            -
              				:return_json => sym_opts[:return_json]
         | 
| 73 | 
            +
              				:return_json => sym_opts[:return_json],
         | 
| 74 | 
            +
                      :plural => sym_opts.member?(:plural) ? sym_opts[:plural] : true
         | 
| 77 75 | 
             
              			)
         | 
| 78 76 | 
             
                  end
         | 
| 79 77 |  | 
| @@ -85,7 +83,8 @@ module Mystic | |
| 85 83 | 
             
              			wrapper_sql(
         | 
| 86 84 | 
             
              				:sql => "INSERT INTO #{table_name} (#{params.keys*','}) VALUES (#{params.values.sqlize*','})",
         | 
| 87 85 | 
             
              				:return_rows => sym_opts[:return_rows],
         | 
| 88 | 
            -
              				:return_json => sym_opts[:return_json]
         | 
| 86 | 
            +
              				:return_json => sym_opts[:return_json],
         | 
| 87 | 
            +
                      :plural => sym_opts.member?(:plural) ? sym_opts[:plural] : true
         | 
| 89 88 | 
             
              			)
         | 
| 90 89 | 
             
                  end
         | 
| 91 90 |  | 
| @@ -97,7 +96,8 @@ module Mystic | |
| 97 96 | 
             
              			wrapper_sql(
         | 
| 98 97 | 
             
              				:sql => "DELETE FROM #{table_name} WHERE #{params.sqlize*' AND '}",
         | 
| 99 98 | 
             
              				:return_rows => sym_opts[:return_rows],
         | 
| 100 | 
            -
              				:return_json => sym_opts[:return_json]
         | 
| 99 | 
            +
              				:return_json => sym_opts[:return_json],
         | 
| 100 | 
            +
                      :plural => sym_opts.member?(:plural) ? sym_opts[:plural] : true
         | 
| 101 101 | 
             
              			)
         | 
| 102 102 | 
             
                  end
         | 
| 103 103 |  | 
| @@ -106,23 +106,27 @@ module Mystic | |
| 106 106 | 
             
                  end
         | 
| 107 107 |  | 
| 108 108 | 
             
                  def fetch params={}, opts={}
         | 
| 109 | 
            -
                    res = select params, opts.merge({:count => 1})
         | 
| 109 | 
            +
                    res = select params, opts.merge({:count => 1, :fetch => true})
         | 
| 110 110 | 
             
              			return res if res.is_a? String
         | 
| 111 111 | 
             
              			res.first rescue nil
         | 
| 112 112 | 
             
                  end
         | 
| 113 113 |  | 
| 114 114 | 
             
                  def create params={}, opts={}
         | 
| 115 | 
            -
                    res = Mystic.execute insert_sql(params, opts)
         | 
| 115 | 
            +
                    res = Mystic.execute insert_sql(params, opts.merge({ :return_rows => true }))
         | 
| 116 116 | 
             
              			return res if res.is_a? String
         | 
| 117 117 | 
             
              			res.first rescue nil
         | 
| 118 118 | 
             
                  end
         | 
| 119 119 |  | 
| 120 120 | 
             
                  def update where={}, set={}, opts={}
         | 
| 121 | 
            -
                    Mystic.execute update_sql(where, set, opts.merge({ :return_rows => true }))
         | 
| 121 | 
            +
                    res = Mystic.execute update_sql(where, set, opts.merge({ :return_rows => true }))
         | 
| 122 | 
            +
                    return res.first unless opts[:plural]
         | 
| 123 | 
            +
                    res
         | 
| 122 124 | 
             
                  end
         | 
| 123 125 |  | 
| 124 126 | 
             
                  def delete params={}, opts={}
         | 
| 125 | 
            -
              			Mystic.execute delete_sql(params, opts)
         | 
| 127 | 
            +
              			res = Mystic.execute delete_sql(params, opts)
         | 
| 128 | 
            +
                    return res.first if !opts[:plural] && !res.nil?
         | 
| 129 | 
            +
                    res
         | 
| 126 130 | 
             
                  end
         | 
| 127 131 |  | 
| 128 132 | 
             
              		def exec_func funcname, *params
         | 
    
        metadata
    CHANGED
    
    | @@ -1,14 +1,14 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: mystic
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 0.1. | 
| 4 | 
            +
              version: 0.1.3
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Nathaniel Symer
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date: 2014- | 
| 11 | 
            +
            date: 2014-09-09 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 14 | 
             
              name: densify
         |