Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dvg/rails_agnostic_models
Gem to ease rails upgrading by abstracting API differences away from your models.
https://github.com/dvg/rails_agnostic_models
Last synced: 29 days ago
JSON representation
Gem to ease rails upgrading by abstracting API differences away from your models.
- Host: GitHub
- URL: https://github.com/dvg/rails_agnostic_models
- Owner: DVG
- License: mit
- Created: 2014-03-05T15:41:04.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2014-03-22T21:15:04.000Z (almost 11 years ago)
- Last Synced: 2024-10-24T23:30:17.640Z (3 months ago)
- Language: Ruby
- Size: 238 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# RailsAgnosticModels
The purpose of this project is to ease the pain of upgrading Rails versions by abstracting away differences between the Rails 2.3 and 3.2 API.
### Wait, if I'm gonna update my code, why don't I just update to Rails 3 or 4 instead of this crap?
If your codebase is small enough to do that in one go, please, by all means.
However if you have a large legacy code base that you simply can't update all at once, this gem will (eventually) enable you to do small incremental changes and eventually make the jump without crashing and burning quite as bad.
## Installation
Add this line to your application's Gemfile:
gem 'rails_agnostic_models'
And then execute:
$ bundle
Or install it yourself as:
$ gem install rails_agnostic_models
## Usage
```ruby
class MyModel < ActiveRecord::Base
# Manage flat_out incompatible code with Rails Edition Specific Blocks
rails_2 { acts_as_audited }
rails_3 { audited }# scoping, named_scope in Rails 2, scope in Rails 3+
# We recommend using FakeArel in Rails 2 projects to get a universal query interface, but it is not required
version_agnostic_scope :active, { where active: true }# single table inheritance, set_inheritance_column in rails 2, self.inheritance_column= in Rails 3+
version_agnostic_inheritance_column "type_inheritance"# sends the options hash onto default_scope in Rails 2
# translates to an arel method chain in Rails 3+
# Currenlty only :order and :conditions are supported
version_agnostic_default_scope(:order => "created_at DESC", :conditions => {:active => true})
end
```## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request