No commit activity in last 3 years
No release in over 3 years
Basic MongoMapper port of technoweenie's acts_as_versioned
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0
>= 0

Runtime

 Project Readme

ActsAsVersioned for MongoMapper

Basic MongoMapper port of technoweenie's acts_as_versioned. Stores changed attributes in a single collection using a general Hash key.

Usage

Basic Example

class Page
  include MongoMapper::Document

  plugin MongoMapper::Acts::Versioned

  key :title, String
end

page = Page.create(:title => 'title')
page.version              # => 1
page.versions.size        # => 1

page.title = 'new title'
page.save

page = page.reload
page.version              # => 2
page.versions.size        # => 2
page.title                # => 'new title'

page.revert_to!(1)

page = page.reload
page.version              # => 1
page.versions.size        # => 2
page.title                # => 'title'

Keys that do not trigger new versions

Default ignored keys are:

  • "_id"
  • "created_at"
  • "updated_at"
  • "creator_id"
  • "updater_id"
  • "version"
  • "_type"
  • "_versioned_type"
  • versioned_foreign_key

Ignoring additional keys

Simply add do_not_version 'new_skipped_key', 'another_skipped_key' somewhere in your model.

Older MongoMapper versions

  • For MongoMapper <= 0.8.6, see the master branch of this repository.

Older embedded document versions

  • See the next branch of this repository.

Upgrading from older embedded document versions

Since 0.3.0, versions have moved into standalone documents rather than embedded documents, mostly for performance reasons.
In hindsight, it didn't really make much sense to load all of a document's versions in every query (unless a query specified .fields without :versions), on top of the actual document itself.
Versions are now only loaded when specifically requested. Existing versions in your system will however not be automatically updated.

Here's an example script that can do it for you.
Assuming models called Page and Template, you can convert its old versions through a script like such:

models = [Page, Template]

models.each do |model|
  model.const_set(:Version, Class.new {
    include MongoMapper::EmbeddedDocument
    key :modified
    key :version
  })

  model.many :versions, class_name: "#{model.name}::Version"

  model.all.each do |document|
    document.versions.each do |old_version|
      MongoMapper::Acts::Versioned::DocumentVersion.create(
        entity_type: model.name,
        entity_id:   document.id,
        modified:    old_version.modified,
        version:     old_version.version
      ) || warn("Didnt create new version for #{old_version.inspect}")
    end
  end
end

Bundler note

Make sure to specify :require => 'acts_as_versioned' in your Gemfile.

Tested with

  • MongoMapper 0.11.1, 0.13.1, 0.14.0
  • Ruby 1.9.2 up to 2.4.0

Copyright

See LICENSE.