Sha256: eea6adf75585104bb7de5e246035aa8a27b350c1096e7e6433980edba059495f

Contents?: true

Size: 1.1 KB

Versions: 5

Compression:

Stored size: 1.1 KB

Contents

[Back to Guides](../README.md)

# How to serialize a Plain-Old Ruby Object (PORO)

When you are first getting started with ActiveModelSerializers, it may seem only `ActiveRecord::Base` objects can be serializable, but pretty much any object can be serializable with ActiveModelSerializers.  Here is an example of a PORO that is serializable:
```ruby
# my_model.rb
class MyModel
  alias :read_attribute_for_serialization :send
  attr_accessor :id, :name, :level
  
  def initialize(attributes)
    @id = attributes[:id]
    @name = attributes[:name]
    @level = attributes[:level]
  end

  def self.model_name
    @_model_name ||= ActiveModel::Name.new(self)
  end
end
```

Fortunately, ActiveModelSerializers provides a [`ActiveModelSerializers::Model`](https://github.com/rails-api/active_model_serializers/blob/master/lib/active_model_serializers/model.rb) which you can use in production code that will make your PORO a lot cleaner.  The above code now becomes:
```ruby
# my_model.rb
class MyModel < ActiveModelSerializers::Model
  attr_accessor :id, :name, :level
end
```

The default serializer would be `MyModelSerializer`.

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
active_model_serializers-0.10.4 docs/howto/serialize_poro.md
active_model_serializers-0.10.3 docs/howto/serialize_poro.md
active_model_serializers-0.10.2 docs/howto/serialize_poro.md
active_model_serializers-0.10.1 docs/howto/serialize_poro.md
active_model_serializers-0.10.0 docs/howto/serialize_poro.md