Module: Serega::ClassMethods
- Included in:
- Serega
- Defined in:
- lib/serega.rb
Overview
Serializers class methods
Instance Attribute Summary collapse
-
#config ⇒ SeregaConfig
readonly
Returns current config.
Instance Method Summary collapse
-
#as_json(object, opts = FROZEN_EMPTY_HASH) ⇒ Hash
Serializes provided object as JSON.
-
#attribute(name, **opts, &block) ⇒ Serega::SeregaAttribute
Adds attribute.
-
#attributes ⇒ Hash
Lists attributes.
-
#call(object, opts = FROZEN_EMPTY_HASH) ⇒ Hash
Serializes provided object to Hash.
-
#plugin(name, **opts) ⇒ class<Module>
Enables plugin for current serializer.
-
#plugin_used?(name) ⇒ Boolean
Checks plugin is used.
- #to_h(object, opts = FROZEN_EMPTY_HASH) ⇒ Object
-
#to_json(object, opts = FROZEN_EMPTY_HASH) ⇒ String
Serializes provided object to JSON string.
Instance Attribute Details
#config ⇒ SeregaConfig (readonly)
Returns current config
71 72 73 |
# File 'lib/serega.rb', line 71 def config @config end |
Instance Method Details
#as_json(object, opts = FROZEN_EMPTY_HASH) ⇒ Hash
Serializes provided object as JSON
240 241 242 |
# File 'lib/serega.rb', line 240 def as_json(object, opts = FROZEN_EMPTY_HASH) config.from_json.call(to_json(object, opts)) end |
#attribute(name, **opts, &block) ⇒ Serega::SeregaAttribute
Adds attribute
178 179 180 181 |
# File 'lib/serega.rb', line 178 def attribute(name, **opts, &block) attribute = self::SeregaAttribute.new(name: name, opts: opts, block: block) attributes[attribute.name] = attribute end |
#attributes ⇒ Hash
Lists attributes
165 166 167 |
# File 'lib/serega.rb', line 165 def attributes @attributes ||= {} end |
#call(object, opts = FROZEN_EMPTY_HASH) ⇒ Hash
Serializes provided object to Hash
197 198 199 200 |
# File 'lib/serega.rb', line 197 def call(object, opts = FROZEN_EMPTY_HASH) initiate_keys = config.initiate_keys new(opts.slice(*initiate_keys)).to_h(object, opts.except(*initiate_keys)) end |
#plugin(name, **opts) ⇒ class<Module>
Enables plugin for current serializer
123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 |
# File 'lib/serega.rb', line 123 def plugin(name, **opts) raise SeregaError, "This plugin is already loaded" if plugin_used?(name) plugin = SeregaPlugins.find_plugin(name) # We split loading of plugin to three parts - before_load, load, after_load: # # - **before_load_plugin** usually used to check requirements and to load additional plugins # - **load_plugin** usually used to include plugin modules # - **after_load_plugin** usually used to add config options plugin.before_load_plugin(self, **opts) if plugin.respond_to?(:before_load_plugin) plugin.load_plugin(self, **opts) if plugin.respond_to?(:load_plugin) plugin.after_load_plugin(self, **opts) if plugin.respond_to?(:after_load_plugin) # Store attached plugins, so we can check it is loaded later config.plugins << (plugin.respond_to?(:plugin_name) ? plugin.plugin_name : plugin) plugin end |
#plugin_used?(name) ⇒ Boolean
Checks plugin is used
150 151 152 153 154 155 156 157 158 |
# File 'lib/serega.rb', line 150 def plugin_used?(name) plugin_name = case name when Module then name.respond_to?(:plugin_name) ? name.plugin_name : name else name end config.plugins.include?(plugin_name) end |
#to_h(object, opts = FROZEN_EMPTY_HASH) ⇒ Object
203 204 205 |
# File 'lib/serega.rb', line 203 def to_h(object, opts = FROZEN_EMPTY_HASH) call(object, opts) end |
#to_json(object, opts = FROZEN_EMPTY_HASH) ⇒ String
Serializes provided object to JSON string
221 222 223 224 |
# File 'lib/serega.rb', line 221 def to_json(object, opts = FROZEN_EMPTY_HASH) initiate_keys = config.initiate_keys new(opts.slice(*initiate_keys)).to_json(object, opts.except(*initiate_keys)) end |