ownable 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
data/Gemfile ADDED
@@ -0,0 +1,3 @@
1
+ source :rubygems
2
+
3
+ gemspec
@@ -0,0 +1,73 @@
1
+ ## INTRODUCTION
2
+
3
+ Ownable gem helps you verify the "ownership" of a associated models in Rails 3.
4
+
5
+ The term "ownership" in the contact of Ownable is the association between two models, usually a User Model (though any model can do) and some other Model.
6
+
7
+ Ownable becomes incresa
8
+
9
+ For example:
10
+
11
+ User has_many Orders has_one Invoice has_many Payments
12
+
13
+ Rather than manually defining and then checking the association between User and Payment like:
14
+ - @payment.invoice.order.user == current_user # => true/false
15
+
16
+ you can use Ownable for a much shorter and simpler syntax:
17
+ - @payment.owned_by? current_user # => true/false
18
+
19
+
20
+ ## INSTALLATION
21
+
22
+ Ownable is currently available only in Gem form and requires version >= 3.0 of Rails.
23
+
24
+ You just have to add the 'ownable' gem to your Gemfile
25
+
26
+ gem 'ownable'
27
+
28
+ Then tell bundler to update the gems :
29
+
30
+ $ bundle install
31
+
32
+
33
+ ## USE
34
+
35
+ In each Model define the associations from the Model to the "Owner" model (which will be User in this example)
36
+
37
+ Assuming a set of Model associations as follows:
38
+
39
+ User has_many Orders has_one Invoice has_many Payments
40
+
41
+
42
+ class Payment < ActiveRecord::Base
43
+ acts_as_ownable :through => [:invoice, :order, :user]
44
+ ...
45
+ end
46
+
47
+ Now all Payment objects will have the instance methods:
48
+
49
+ @payment.owned_by?(model_instance)
50
+
51
+ and
52
+
53
+ @payment.owned_by_id?(id)
54
+
55
+ Note that when declaring acts_as_ownable in the Models, the last Model name in the array must be the "Owner" model name.
56
+ Also, this only works when each upstream association returns a single object. For example, the following will NOT work:
57
+
58
+ Publisher has_many Authors has_and_belongs_to_many Books
59
+
60
+ class Book < ActiveRecord::Base
61
+ acts_as_ownable :through => [:author, :publisher]
62
+ ...
63
+ end
64
+
65
+ @book.owned_by? Publisher.first
66
+
67
+
68
+ This will not work because several authors may have co-authored a Book so there is multiple paths back to the "Owner" model (the Publisher).
69
+ At this time this gem does not support these relationships.
70
+
71
+ ## THANKS
72
+
73
+ Thanks to jlecour's (http://github.com/jlecour) geokit-rails project for helping me understand how to build a gem that plays well with Rails 3.
@@ -0,0 +1,17 @@
1
+ require 'rake'
2
+ require 'rake/testtask'
3
+ require 'rake/rdoctask'
4
+
5
+ #load 'test/tasks.rake'
6
+
7
+ #desc 'Default: run unit tests.'
8
+ #task :default => :test
9
+
10
+ desc 'Generate documentation for the Ownable gem.'
11
+ Rake::RDocTask.new(:rdoc) do |rdoc|
12
+ rdoc.rdoc_dir = 'rdoc'
13
+ rdoc.title = 'Ownable'
14
+ rdoc.options << '--line-numbers' << '--inline-source'
15
+ rdoc.rdoc_files.include('README')
16
+ rdoc.rdoc_files.include('lib/**/*.rb')
17
+ end
@@ -0,0 +1,2 @@
1
+ require 'ownable/railtie'
2
+ require 'ownable/acts_as_ownable'
@@ -0,0 +1,57 @@
1
+ require 'active_record'
2
+ require 'active_support/concern'
3
+
4
+ module Ownable
5
+
6
+ # Add acts_as_ownable to ActiveRecord subclasses
7
+ module ActsAsOwnable extend ActiveSupport::Concern
8
+
9
+ module ClassMethods
10
+
11
+ def acts_as_ownable(options = {})
12
+ cattr_accessor :ownable_through
13
+
14
+ self.ownable_through = options[:through] || [':user']
15
+ end
16
+
17
+ end #ClassMethods
18
+
19
+ # Add owned_by? and owned_by_id? to ActiveRecord subclasses
20
+ module InstanceMethods
21
+
22
+ def owned_by? candidate
23
+ owner = find_owner
24
+
25
+ return false if (owner.nil? || candidate.nil?)
26
+ candidate == owner
27
+ end
28
+
29
+ def owned_by_id? candidate_id
30
+ owner = find_owner
31
+
32
+ return false if (owner.nil? || candidate_id.nil?)
33
+ candidate_id == owner.id
34
+ end
35
+
36
+
37
+ private
38
+
39
+ def find_owner
40
+ owner = self
41
+
42
+ self.ownable_through.each do |class_name|
43
+ begin
44
+ owner = owner.send class_name
45
+ rescue
46
+ owner = nil
47
+ end
48
+ end
49
+
50
+ return owner
51
+ end
52
+
53
+ end #InstanceMethods
54
+
55
+ end #ActsAsOwnable
56
+
57
+ end #Ownable
@@ -0,0 +1,15 @@
1
+ require 'ownable'
2
+ require 'rails'
3
+
4
+ module Ownable
5
+ class Railtie < Rails::Railtie
6
+
7
+ initializer 'ownable.insert_into_active_record' do
8
+ ActiveSupport.on_load :active_record do
9
+ ActiveRecord::Base.send :extend, Ownable::ActsAsOwnable::ClassMethods
10
+ ActiveRecord::Base.send :include, Ownable::ActsAsOwnable::InstanceMethods
11
+ end
12
+ end
13
+
14
+ end
15
+ end
@@ -0,0 +1,3 @@
1
+ module Ownable
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,24 @@
1
+ # -*- encoding: utf-8 -*-
2
+ require File.expand_path("../lib/ownable/version", __FILE__)
3
+
4
+ Gem::Specification.new do |s|
5
+ s.name = "ownable"
6
+ s.version = Ownable::VERSION
7
+ s.platform = Gem::Platform::RUBY
8
+ s.authors = ["David Gonzalez"]
9
+ s.email = ["davidjgonzalez@gmail.com"]
10
+ s.homepage = "http://unicornless.com/gems/ownable"
11
+ s.summary = "Model ownership with Rails 3"
12
+ s.description = "Model ownership with Rails 3"
13
+
14
+ s.required_rubygems_version = ">= 1.3.6"
15
+
16
+ s.add_runtime_dependency 'rails', '~> 3.0.0'
17
+
18
+ s.add_development_dependency "bundler", "~> 1.0.0"
19
+
20
+ s.files = `git ls-files`.split("\n")
21
+ s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
22
+ s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
23
+ s.require_paths = ["lib"]
24
+ end
metadata ADDED
@@ -0,0 +1,99 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: ownable
3
+ version: !ruby/object:Gem::Version
4
+ prerelease: false
5
+ segments:
6
+ - 0
7
+ - 1
8
+ - 0
9
+ version: 0.1.0
10
+ platform: ruby
11
+ authors:
12
+ - David Gonzalez
13
+ autorequire:
14
+ bindir: bin
15
+ cert_chain: []
16
+
17
+ date: 2010-10-04 00:00:00 -04:00
18
+ default_executable:
19
+ dependencies:
20
+ - !ruby/object:Gem::Dependency
21
+ name: rails
22
+ prerelease: false
23
+ requirement: &id001 !ruby/object:Gem::Requirement
24
+ requirements:
25
+ - - ~>
26
+ - !ruby/object:Gem::Version
27
+ segments:
28
+ - 3
29
+ - 0
30
+ - 0
31
+ version: 3.0.0
32
+ type: :runtime
33
+ version_requirements: *id001
34
+ - !ruby/object:Gem::Dependency
35
+ name: bundler
36
+ prerelease: false
37
+ requirement: &id002 !ruby/object:Gem::Requirement
38
+ requirements:
39
+ - - ~>
40
+ - !ruby/object:Gem::Version
41
+ segments:
42
+ - 1
43
+ - 0
44
+ - 0
45
+ version: 1.0.0
46
+ type: :development
47
+ version_requirements: *id002
48
+ description: Model ownership with Rails 3
49
+ email:
50
+ - davidjgonzalez@gmail.com
51
+ executables: []
52
+
53
+ extensions: []
54
+
55
+ extra_rdoc_files: []
56
+
57
+ files:
58
+ - Gemfile
59
+ - README.markdown
60
+ - Rakefile
61
+ - lib/ownable.rb
62
+ - lib/ownable/acts_as_ownable.rb
63
+ - lib/ownable/railtie.rb
64
+ - lib/ownable/version.rb
65
+ - ownable.gemspec
66
+ has_rdoc: true
67
+ homepage: http://unicornless.com/gems/ownable
68
+ licenses: []
69
+
70
+ post_install_message:
71
+ rdoc_options: []
72
+
73
+ require_paths:
74
+ - lib
75
+ required_ruby_version: !ruby/object:Gem::Requirement
76
+ requirements:
77
+ - - ">="
78
+ - !ruby/object:Gem::Version
79
+ segments:
80
+ - 0
81
+ version: "0"
82
+ required_rubygems_version: !ruby/object:Gem::Requirement
83
+ requirements:
84
+ - - ">="
85
+ - !ruby/object:Gem::Version
86
+ segments:
87
+ - 1
88
+ - 3
89
+ - 6
90
+ version: 1.3.6
91
+ requirements: []
92
+
93
+ rubyforge_project:
94
+ rubygems_version: 1.3.6
95
+ signing_key:
96
+ specification_version: 3
97
+ summary: Model ownership with Rails 3
98
+ test_files: []
99
+