Module: Sequel::Postgres::JSONDatabaseMethods
- Defined in:
- lib/sequel/extensions/pg_json.rb
Overview
Methods enabling Database object integration with the json type.
Class Method Summary collapse
-
.extended(db) ⇒ Object
Reset the conversion procs when extending the Database object, so it will pick up the json convertor.
-
.parse_json(s) ⇒ Object
Parse the given string as json, returning either a JSONArray or JSONHash instance, and raising an error if the JSON parsing does not yield an array or hash.
Instance Method Summary collapse
-
#bound_variable_arg(arg, conn) ⇒ Object
Handle JSONArray and JSONHash in bound variables.
-
#schema_column_type(db_type) ⇒ Object
Make the column type detection recognize the json type.
Class Method Details
.extended(db) ⇒ Object
Reset the conversion procs when extending the Database object, so it will pick up the json convertor. This is only done for the native postgres adapter.
109 110 111 |
# File 'lib/sequel/extensions/pg_json.rb', line 109 def self.extended(db) db.reset_conversion_procs if db.respond_to?(:reset_conversion_procs) end |
.parse_json(s) ⇒ Object
Parse the given string as json, returning either a JSONArray or JSONHash instance, and raising an error if the JSON parsing does not yield an array or hash.
89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/sequel/extensions/pg_json.rb', line 89 def self.parse_json(s) begin value = JSON.parse(s) rescue JSON::ParserError=>e raise Sequel.convert_exception_class(e, Sequel::InvalidValue) end case value when Array JSONArray.new(value) when Hash JSONHash.new(value) else raise Sequel::InvalidValue, "unhandled json value: #{value.inspect} (from #{s.inspect})" end end |
Instance Method Details
#bound_variable_arg(arg, conn) ⇒ Object
Handle JSONArray and JSONHash in bound variables
114 115 116 117 118 119 120 121 |
# File 'lib/sequel/extensions/pg_json.rb', line 114 def bound_variable_arg(arg, conn) case arg when JSONArray, JSONHash arg.to_json else super end end |
#schema_column_type(db_type) ⇒ Object
Make the column type detection recognize the json type.
124 125 126 127 128 129 130 131 |
# File 'lib/sequel/extensions/pg_json.rb', line 124 def schema_column_type(db_type) case db_type when 'json' :json else super end end |