Project

structural

0.01
No commit activity in last 3 years
No release in over 3 years
A cut down fork of the Id gem developed at On The Beach Ltd.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.6
>= 0
~> 3.0
>= 0

Runtime

 Project Readme

Structural

Structural is a cut down fork of Id, designed to work with Ruby >= 1.8.7 and Rails >= 2.3.

Defining a model

class MyModel
  include Structural::Model

  field :foo
  field :bar, default: 42
  field :baz, key: 'barry'
end

my_model = MyModel.new(foo: 7, barry: 'hello')
my_model.foo # => 7
my_model.bar # => 42
my_model.baz # => 'hello'

Default values can be specified, as well as key aliases.

Associations

We can also specify has_one or has_many associations for nested documents:

class Zoo
  include Structural::Model

  has_many :lions
  has_many :zebras
  has_one :zookeeper, type: Person
end

zoo = Zoo.new(lions: [{name: 'Hetty'}],
              zebras: [{name: 'Lisa'}],
              zookeeper: {name: 'Russell'})

zoo.lions.first.class # => Lion
zoo.lions.first.name  # => "Hetty"
zoo.zookeeper.class   # => Person
zoo.zookeeper.name    # => "Russell"

Types are inferred from the association name unless one is specified.

Designed for immutability

structural models provide accessor methods, but no mutator methods. When changing the value of a field, a new copy of the object is created:

person = Person.new(name: 'Russell', job: 'programmer')
person.set(name: 'Radek')
# => returns a new Person whose name is Radek and whose job is 'programmer'
person.hat.set(colour: 'red')
# => returns a new person object with a new hat object with its colour set to red