Update CPK to 4.1.2 and drop monkey patch
This commit is contained in:
parent
5fcfd64f92
commit
a98a2a0213
3 changed files with 20 additions and 100 deletions
2
Gemfile
2
Gemfile
|
@ -17,7 +17,7 @@ gem 'rinku', '>= 1.2.2', :require => 'rails_rinku'
|
||||||
gem 'oauth-plugin', '>= 0.4.0.pre7'
|
gem 'oauth-plugin', '>= 0.4.0.pre7'
|
||||||
gem 'open_id_authentication', '>= 1.1.0'
|
gem 'open_id_authentication', '>= 1.1.0'
|
||||||
gem 'validates_email_format_of', '>= 1.5.1'
|
gem 'validates_email_format_of', '>= 1.5.1'
|
||||||
gem 'composite_primary_keys', '>= 4.1.1'
|
gem 'composite_primary_keys', '>= 4.1.2'
|
||||||
|
|
||||||
# Load libxml support for XML parsing and generation
|
# Load libxml support for XML parsing and generation
|
||||||
gem 'libxml-ruby', '>= 2.0.5', :require => 'libxml'
|
gem 'libxml-ruby', '>= 2.0.5', :require => 'libxml'
|
||||||
|
|
38
Gemfile.lock
38
Gemfile.lock
|
@ -39,24 +39,24 @@ GEM
|
||||||
coffee-script (2.2.0)
|
coffee-script (2.2.0)
|
||||||
coffee-script-source
|
coffee-script-source
|
||||||
execjs
|
execjs
|
||||||
coffee-script-source (1.1.3)
|
coffee-script-source (1.2.0)
|
||||||
composite_primary_keys (4.1.1)
|
composite_primary_keys (4.1.2)
|
||||||
activerecord (~> 3.1)
|
activerecord (~> 3.1)
|
||||||
dynamic_form (1.1.4)
|
dynamic_form (1.1.4)
|
||||||
erubis (2.7.0)
|
erubis (2.7.0)
|
||||||
execjs (1.2.9)
|
execjs (1.3.0)
|
||||||
multi_json (~> 1.0)
|
multi_json (~> 1.0)
|
||||||
faraday (0.7.5)
|
faraday (0.7.5)
|
||||||
addressable (~> 2.2.6)
|
addressable (~> 2.2.6)
|
||||||
multipart-post (~> 1.1.3)
|
multipart-post (~> 1.1.3)
|
||||||
rack (>= 1.1.0, < 2)
|
rack (>= 1.1.0, < 2)
|
||||||
hike (1.2.1)
|
hike (1.2.1)
|
||||||
httpclient (2.2.3)
|
httpclient (2.2.4)
|
||||||
i18n (0.6.0)
|
i18n (0.6.0)
|
||||||
jquery-rails (1.0.18)
|
jquery-rails (1.0.19)
|
||||||
railties (~> 3.0)
|
railties (~> 3.0)
|
||||||
thor (~> 0.14)
|
thor (~> 0.14)
|
||||||
json (1.6.1)
|
json (1.6.5)
|
||||||
libv8 (3.3.10.4)
|
libv8 (3.3.10.4)
|
||||||
libxml-ruby (2.2.2)
|
libxml-ruby (2.2.2)
|
||||||
mail (2.3.0)
|
mail (2.3.0)
|
||||||
|
@ -64,10 +64,10 @@ GEM
|
||||||
mime-types (~> 1.16)
|
mime-types (~> 1.16)
|
||||||
treetop (~> 1.4.8)
|
treetop (~> 1.4.8)
|
||||||
memcache-client (1.8.5)
|
memcache-client (1.8.5)
|
||||||
memcached (1.3.5)
|
memcached (1.3.6)
|
||||||
mime-types (1.17.2)
|
mime-types (1.17.2)
|
||||||
multi_json (1.0.3)
|
multi_json (1.0.4)
|
||||||
multipart-post (1.1.3)
|
multipart-post (1.1.4)
|
||||||
nokogiri (1.5.0)
|
nokogiri (1.5.0)
|
||||||
oauth (0.4.5)
|
oauth (0.4.5)
|
||||||
oauth-plugin (0.4.0.rc2)
|
oauth-plugin (0.4.0.rc2)
|
||||||
|
@ -75,14 +75,14 @@ GEM
|
||||||
oauth (~> 0.4.4)
|
oauth (~> 0.4.4)
|
||||||
oauth2
|
oauth2
|
||||||
rack
|
rack
|
||||||
oauth2 (0.5.1)
|
oauth2 (0.5.2)
|
||||||
faraday (~> 0.7.4)
|
faraday (~> 0.7)
|
||||||
multi_json (~> 1.0.3)
|
multi_json (~> 1.0)
|
||||||
open_id_authentication (1.1.0)
|
open_id_authentication (1.1.0)
|
||||||
rack-openid (~> 1.3)
|
rack-openid (~> 1.3)
|
||||||
pg (0.11.0)
|
pg (0.12.2)
|
||||||
polyglot (0.3.3)
|
polyglot (0.3.3)
|
||||||
rack (1.3.5)
|
rack (1.3.6)
|
||||||
rack-cache (1.1)
|
rack-cache (1.1)
|
||||||
rack (>= 0.4)
|
rack (>= 0.4)
|
||||||
rack-mount (0.8.3)
|
rack-mount (0.8.3)
|
||||||
|
@ -114,14 +114,14 @@ GEM
|
||||||
rdoc (~> 3.4)
|
rdoc (~> 3.4)
|
||||||
thor (~> 0.14.6)
|
thor (~> 0.14.6)
|
||||||
rake (0.9.2.2)
|
rake (0.9.2.2)
|
||||||
rdoc (3.11)
|
rdoc (3.12)
|
||||||
json (~> 1.4)
|
json (~> 1.4)
|
||||||
rinku (1.4.1)
|
rinku (1.5.0)
|
||||||
rmagick (2.13.1)
|
rmagick (2.13.1)
|
||||||
ruby-openid (2.1.8)
|
ruby-openid (2.1.8)
|
||||||
sanitize (2.0.3)
|
sanitize (2.0.3)
|
||||||
nokogiri (>= 1.4.4, < 1.6)
|
nokogiri (>= 1.4.4, < 1.6)
|
||||||
sass (3.1.10)
|
sass (3.1.12)
|
||||||
sass-rails (3.1.5)
|
sass-rails (3.1.5)
|
||||||
actionpack (~> 3.1.0)
|
actionpack (~> 3.1.0)
|
||||||
railties (~> 3.1.0)
|
railties (~> 3.1.0)
|
||||||
|
@ -140,7 +140,7 @@ GEM
|
||||||
polyglot
|
polyglot
|
||||||
polyglot (>= 0.3.1)
|
polyglot (>= 0.3.1)
|
||||||
tzinfo (0.3.31)
|
tzinfo (0.3.31)
|
||||||
uglifier (1.1.0)
|
uglifier (1.2.2)
|
||||||
execjs (>= 0.3.0)
|
execjs (>= 0.3.0)
|
||||||
multi_json (>= 1.0.2)
|
multi_json (>= 1.0.2)
|
||||||
validates_email_format_of (1.5.3)
|
validates_email_format_of (1.5.3)
|
||||||
|
@ -151,7 +151,7 @@ PLATFORMS
|
||||||
DEPENDENCIES
|
DEPENDENCIES
|
||||||
SystemTimer (>= 1.1.3)
|
SystemTimer (>= 1.1.3)
|
||||||
coffee-rails (~> 3.1.0)
|
coffee-rails (~> 3.1.0)
|
||||||
composite_primary_keys (>= 4.1.1)
|
composite_primary_keys (>= 4.1.2)
|
||||||
dynamic_form
|
dynamic_form
|
||||||
httpclient
|
httpclient
|
||||||
jquery-rails
|
jquery-rails
|
||||||
|
|
|
@ -1,80 +0,0 @@
|
||||||
module ActiveRecord
|
|
||||||
module Associations
|
|
||||||
class AssociationScope
|
|
||||||
def add_constraints(scope)
|
|
||||||
tables = construct_tables
|
|
||||||
|
|
||||||
chain.each_with_index do |reflection, i|
|
|
||||||
table, foreign_table = tables.shift, tables.first
|
|
||||||
|
|
||||||
if reflection.source_macro == :has_and_belongs_to_many
|
|
||||||
join_table = tables.shift
|
|
||||||
|
|
||||||
# CPK
|
|
||||||
# scope = scope.joins(join(
|
|
||||||
# join_table,
|
|
||||||
# table[reflection.active_record_primary_key].
|
|
||||||
# eq(join_table[reflection.association_foreign_key])
|
|
||||||
#))
|
|
||||||
predicate = cpk_join_predicate(table, reflection.association_primary_key,
|
|
||||||
join_table, reflection.association_foreign_key)
|
|
||||||
scope = scope.joins(join(join_table, predicate))
|
|
||||||
|
|
||||||
table, foreign_table = join_table, tables.first
|
|
||||||
end
|
|
||||||
|
|
||||||
if reflection.source_macro == :belongs_to
|
|
||||||
if reflection.options[:polymorphic]
|
|
||||||
key = reflection.association_primary_key(klass)
|
|
||||||
else
|
|
||||||
key = reflection.association_primary_key
|
|
||||||
end
|
|
||||||
|
|
||||||
foreign_key = reflection.foreign_key
|
|
||||||
else
|
|
||||||
key = reflection.foreign_key
|
|
||||||
foreign_key = reflection.active_record_primary_key
|
|
||||||
end
|
|
||||||
|
|
||||||
conditions = self.conditions[i]
|
|
||||||
|
|
||||||
if reflection == chain.last
|
|
||||||
# CPK
|
|
||||||
# scope = scope.where(table[key].eq(owner[foreign_key]))
|
|
||||||
predicate = cpk_join_predicate(table, key, owner, foreign_key)
|
|
||||||
scope = scope.where(predicate)
|
|
||||||
|
|
||||||
if reflection.type
|
|
||||||
scope = scope.where(table[reflection.type].eq(owner.class.base_class.name))
|
|
||||||
end
|
|
||||||
|
|
||||||
conditions.each do |condition|
|
|
||||||
if options[:through] && condition.is_a?(Hash)
|
|
||||||
condition = { table.name => condition }
|
|
||||||
end
|
|
||||||
|
|
||||||
scope = scope.where(interpolate(condition))
|
|
||||||
end
|
|
||||||
else
|
|
||||||
# CPK
|
|
||||||
# constraint = table[key].eq(foreign_table[foreign_key])
|
|
||||||
constraint = cpk_join_predicate(table, key, foreign_table, foreign_key)
|
|
||||||
|
|
||||||
if reflection.type
|
|
||||||
type = chain[i + 1].klass.base_class.name
|
|
||||||
constraint = constraint.and(table[reflection.type].eq(type))
|
|
||||||
end
|
|
||||||
|
|
||||||
scope = scope.joins(join(foreign_table, constraint))
|
|
||||||
|
|
||||||
unless conditions.empty?
|
|
||||||
scope = scope.where(sanitize(conditions, table))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
scope
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
Loading…
Add table
Add a link
Reference in a new issue