find_helper 0.0.1 → 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- metadata +4 -84
- data/MIT-LICENSE +0 -20
- data/README.rdoc +0 -3
- data/Rakefile +0 -32
- data/lib/find_helper.rb +0 -128
- data/lib/find_helper/active_record_finder.rb +0 -49
- data/lib/find_helper/format_finder_value.rb +0 -83
- data/lib/find_helper/mongoid_finder.rb +0 -56
- data/lib/find_helper/scope.rb +0 -23
- data/lib/find_helper/version.rb +0 -3
- data/lib/tasks/find_helper_tasks.rake +0 -4
- data/test/dummy/README.rdoc +0 -28
- data/test/dummy/Rakefile +0 -6
- data/test/dummy/app/assets/javascripts/application.js +0 -13
- data/test/dummy/app/assets/stylesheets/application.css +0 -15
- data/test/dummy/app/controllers/application_controller.rb +0 -5
- data/test/dummy/app/helpers/application_helper.rb +0 -2
- data/test/dummy/app/views/layouts/application.html.erb +0 -14
- data/test/dummy/bin/bundle +0 -3
- data/test/dummy/bin/rails +0 -4
- data/test/dummy/bin/rake +0 -4
- data/test/dummy/config.ru +0 -4
- data/test/dummy/config/application.rb +0 -23
- data/test/dummy/config/boot.rb +0 -5
- data/test/dummy/config/database.yml +0 -25
- data/test/dummy/config/environment.rb +0 -5
- data/test/dummy/config/environments/development.rb +0 -37
- data/test/dummy/config/environments/production.rb +0 -78
- data/test/dummy/config/environments/test.rb +0 -39
- data/test/dummy/config/initializers/assets.rb +0 -8
- data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
- data/test/dummy/config/initializers/cookies_serializer.rb +0 -3
- data/test/dummy/config/initializers/filter_parameter_logging.rb +0 -4
- data/test/dummy/config/initializers/inflections.rb +0 -16
- data/test/dummy/config/initializers/mime_types.rb +0 -4
- data/test/dummy/config/initializers/session_store.rb +0 -3
- data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
- data/test/dummy/config/locales/en.yml +0 -23
- data/test/dummy/config/routes.rb +0 -56
- data/test/dummy/config/secrets.yml +0 -22
- data/test/dummy/public/404.html +0 -67
- data/test/dummy/public/422.html +0 -67
- data/test/dummy/public/500.html +0 -66
- data/test/dummy/public/favicon.ico +0 -0
- data/test/find_helper_test.rb +0 -7
- data/test/test_helper.rb +0 -15
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6ad991d74e33439be38530e5c411cd8937a66834
|
4
|
+
data.tar.gz: 5648dfcfb78020a5ee7bd0cc9368c5e1876659bb
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a1c165fa4d9a72270fb8b90b67968a48ed3ef49cc3e22d082b56a83ca9428c73218967ff02d374bab93d41c67a831dba74c28a92cd1c87a6d411a81e95a77e6a
|
7
|
+
data.tar.gz: 979e68ebc6fabd401c8244cf698c3e0c004172bbacd04ff4e4917b89fb4e3c797e9fa7d92b02f33c13bdb3088164e8833665ef447f0cd3cfc067d6d54c44d6a7
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: find_helper
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- panaoke
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-06-
|
11
|
+
date: 2015-06-30 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: make orm model find so easy
|
14
14
|
email:
|
@@ -16,52 +16,7 @@ email:
|
|
16
16
|
executables: []
|
17
17
|
extensions: []
|
18
18
|
extra_rdoc_files: []
|
19
|
-
files:
|
20
|
-
- MIT-LICENSE
|
21
|
-
- README.rdoc
|
22
|
-
- Rakefile
|
23
|
-
- lib/find_helper.rb
|
24
|
-
- lib/find_helper/active_record_finder.rb
|
25
|
-
- lib/find_helper/format_finder_value.rb
|
26
|
-
- lib/find_helper/mongoid_finder.rb
|
27
|
-
- lib/find_helper/scope.rb
|
28
|
-
- lib/find_helper/version.rb
|
29
|
-
- lib/tasks/find_helper_tasks.rake
|
30
|
-
- test/dummy/README.rdoc
|
31
|
-
- test/dummy/Rakefile
|
32
|
-
- test/dummy/app/assets/javascripts/application.js
|
33
|
-
- test/dummy/app/assets/stylesheets/application.css
|
34
|
-
- test/dummy/app/controllers/application_controller.rb
|
35
|
-
- test/dummy/app/helpers/application_helper.rb
|
36
|
-
- test/dummy/app/views/layouts/application.html.erb
|
37
|
-
- test/dummy/bin/bundle
|
38
|
-
- test/dummy/bin/rails
|
39
|
-
- test/dummy/bin/rake
|
40
|
-
- test/dummy/config.ru
|
41
|
-
- test/dummy/config/application.rb
|
42
|
-
- test/dummy/config/boot.rb
|
43
|
-
- test/dummy/config/database.yml
|
44
|
-
- test/dummy/config/environment.rb
|
45
|
-
- test/dummy/config/environments/development.rb
|
46
|
-
- test/dummy/config/environments/production.rb
|
47
|
-
- test/dummy/config/environments/test.rb
|
48
|
-
- test/dummy/config/initializers/assets.rb
|
49
|
-
- test/dummy/config/initializers/backtrace_silencers.rb
|
50
|
-
- test/dummy/config/initializers/cookies_serializer.rb
|
51
|
-
- test/dummy/config/initializers/filter_parameter_logging.rb
|
52
|
-
- test/dummy/config/initializers/inflections.rb
|
53
|
-
- test/dummy/config/initializers/mime_types.rb
|
54
|
-
- test/dummy/config/initializers/session_store.rb
|
55
|
-
- test/dummy/config/initializers/wrap_parameters.rb
|
56
|
-
- test/dummy/config/locales/en.yml
|
57
|
-
- test/dummy/config/routes.rb
|
58
|
-
- test/dummy/config/secrets.yml
|
59
|
-
- test/dummy/public/404.html
|
60
|
-
- test/dummy/public/422.html
|
61
|
-
- test/dummy/public/500.html
|
62
|
-
- test/dummy/public/favicon.ico
|
63
|
-
- test/find_helper_test.rb
|
64
|
-
- test/test_helper.rb
|
19
|
+
files: []
|
65
20
|
homepage: https://github.com/panaoke/find_helper
|
66
21
|
licenses:
|
67
22
|
- MIT
|
@@ -86,39 +41,4 @@ rubygems_version: 2.4.6
|
|
86
41
|
signing_key:
|
87
42
|
specification_version: 4
|
88
43
|
summary: active record or mongoid find helper
|
89
|
-
test_files:
|
90
|
-
- test/dummy/app/assets/javascripts/application.js
|
91
|
-
- test/dummy/app/assets/stylesheets/application.css
|
92
|
-
- test/dummy/app/controllers/application_controller.rb
|
93
|
-
- test/dummy/app/helpers/application_helper.rb
|
94
|
-
- test/dummy/app/views/layouts/application.html.erb
|
95
|
-
- test/dummy/bin/bundle
|
96
|
-
- test/dummy/bin/rails
|
97
|
-
- test/dummy/bin/rake
|
98
|
-
- test/dummy/config/application.rb
|
99
|
-
- test/dummy/config/boot.rb
|
100
|
-
- test/dummy/config/database.yml
|
101
|
-
- test/dummy/config/environment.rb
|
102
|
-
- test/dummy/config/environments/development.rb
|
103
|
-
- test/dummy/config/environments/production.rb
|
104
|
-
- test/dummy/config/environments/test.rb
|
105
|
-
- test/dummy/config/initializers/assets.rb
|
106
|
-
- test/dummy/config/initializers/backtrace_silencers.rb
|
107
|
-
- test/dummy/config/initializers/cookies_serializer.rb
|
108
|
-
- test/dummy/config/initializers/filter_parameter_logging.rb
|
109
|
-
- test/dummy/config/initializers/inflections.rb
|
110
|
-
- test/dummy/config/initializers/mime_types.rb
|
111
|
-
- test/dummy/config/initializers/session_store.rb
|
112
|
-
- test/dummy/config/initializers/wrap_parameters.rb
|
113
|
-
- test/dummy/config/locales/en.yml
|
114
|
-
- test/dummy/config/routes.rb
|
115
|
-
- test/dummy/config/secrets.yml
|
116
|
-
- test/dummy/config.ru
|
117
|
-
- test/dummy/public/404.html
|
118
|
-
- test/dummy/public/422.html
|
119
|
-
- test/dummy/public/500.html
|
120
|
-
- test/dummy/public/favicon.ico
|
121
|
-
- test/dummy/Rakefile
|
122
|
-
- test/dummy/README.rdoc
|
123
|
-
- test/find_helper_test.rb
|
124
|
-
- test/test_helper.rb
|
44
|
+
test_files: []
|
data/MIT-LICENSE
DELETED
@@ -1,20 +0,0 @@
|
|
1
|
-
Copyright 2015 YOURNAME
|
2
|
-
|
3
|
-
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
-
a copy of this software and associated documentation files (the
|
5
|
-
"Software"), to deal in the Software without restriction, including
|
6
|
-
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
-
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
-
permit persons to whom the Software is furnished to do so, subject to
|
9
|
-
the following conditions:
|
10
|
-
|
11
|
-
The above copyright notice and this permission notice shall be
|
12
|
-
included in all copies or substantial portions of the Software.
|
13
|
-
|
14
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
-
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
-
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
-
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
-
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
-
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
-
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.rdoc
DELETED
data/Rakefile
DELETED
@@ -1,32 +0,0 @@
|
|
1
|
-
begin
|
2
|
-
require 'bundler/setup'
|
3
|
-
rescue LoadError
|
4
|
-
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
5
|
-
end
|
6
|
-
|
7
|
-
require 'rdoc/task'
|
8
|
-
|
9
|
-
RDoc::Task.new(:rdoc) do |rdoc|
|
10
|
-
rdoc.rdoc_dir = 'rdoc'
|
11
|
-
rdoc.title = 'FindHelper'
|
12
|
-
rdoc.options << '--line-numbers'
|
13
|
-
rdoc.rdoc_files.include('README.rdoc')
|
14
|
-
rdoc.rdoc_files.include('lib/**/*.rb')
|
15
|
-
end
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
Bundler::GemHelper.install_tasks
|
21
|
-
|
22
|
-
require 'rake/testtask'
|
23
|
-
|
24
|
-
Rake::TestTask.new(:test) do |t|
|
25
|
-
t.libs << 'lib'
|
26
|
-
t.libs << 'test'
|
27
|
-
t.pattern = 'test/**/*_test.rb'
|
28
|
-
t.verbose = false
|
29
|
-
end
|
30
|
-
|
31
|
-
|
32
|
-
task default: :test
|
data/lib/find_helper.rb
DELETED
@@ -1,128 +0,0 @@
|
|
1
|
-
require 'find_helper'
|
2
|
-
require 'find_helper/version'
|
3
|
-
require 'find_helper/scope'
|
4
|
-
require 'find_helper/format_finder_value'
|
5
|
-
require 'find_helper/active_record_finder'
|
6
|
-
require 'find_helper/mongoid_finder'
|
7
|
-
|
8
|
-
=begin
|
9
|
-
用来扩展model的查询能力
|
10
|
-
1. 通过参数来实现级联调用named_scope的效果
|
11
|
-
2. 提供包含多种比较条件的查询
|
12
|
-
3. 自动将特殊字段类型的查询值转换, 包含日期, 时间, 数组, 数组, 布尔
|
13
|
-
|
14
|
-
Example:
|
15
|
-
|
16
|
-
class Product < ActiveRecord::Base
|
17
|
-
|
18
|
-
include FindHelper # 引入hash级联查询能力
|
19
|
-
|
20
|
-
定义一个字段name的like查询scope
|
21
|
-
named_scope :product_name, { |name| :conditions => ['name like ?', "%{name}%"])
|
22
|
-
|
23
|
-
named_scope :price_gte, {|price| :conditions => ['price_gte >= ?', price]}
|
24
|
-
|
25
|
-
end
|
26
|
-
|
27
|
-
常规查询方法 VS hash级联查询查询方法(by_scopes)
|
28
|
-
查询 name like 'prom', price 大于 100的
|
29
|
-
|
30
|
-
Product.name('prom').price_gte(100)
|
31
|
-
|
|
32
|
-
v
|
33
|
-
Product.by_scopes({:name => 'prom', :price_gte => 100})
|
34
|
-
|
35
|
-
同时还支持
|
36
|
-
|
37
|
-
1. 一般查询扩展
|
38
|
-
Product.by_scopes({:product_name => 'prom', :price_gte => 100, :domain_id => 5})
|
39
|
-
|
|
40
|
-
v
|
41
|
-
Product.product_name('prom').price_gte(100).find(:all, :conditions => {'products.domain_id = ?', 5})
|
42
|
-
|
43
|
-
2. 默认去除空值查询条件
|
44
|
-
Product.by_scopes({:product_name => '', :price_gte => 100, :domain_id => 5})
|
45
|
-
|
|
46
|
-
v
|
47
|
-
Product.price_gte(100).find(:all, :conditions => {'products.domain_id = ?', 5})
|
48
|
-
|
49
|
-
不去除空值查询条件
|
50
|
-
Product.by_scopes({:name => '', :price_gte => 100, :domain_id => 5}, false)
|
51
|
-
|
|
52
|
-
v
|
53
|
-
Product.product_name('').price_gte(100).find(:all, :conditions => {'products.domain_id = ?', 5})
|
54
|
-
|
55
|
-
3. $like(模糊)查询
|
56
|
-
Product.by_scopes({:$like_name => 'prom'})
|
57
|
-
|
|
58
|
-
v
|
59
|
-
Product.find(:all, :conditions => ['products.name like ?', "%prom%"])
|
60
|
-
|
61
|
-
4. $gt(大于)查询
|
62
|
-
Product.by_scopes({:$gt_price => '100'})
|
63
|
-
|
|
64
|
-
v
|
65
|
-
Product.find(:all, :conditions => ['products.price > ?', 100])
|
66
|
-
|
67
|
-
5. $gte(大于等于)查询
|
68
|
-
Product.by_scopes({:$gte_price => '100'})
|
69
|
-
|
|
70
|
-
v
|
71
|
-
Product.find(:all, :conditions => ['products.price >= ?', 100])
|
72
|
-
|
73
|
-
6. $le(小于)查询
|
74
|
-
Product.by_scopes({:$le_price => '100'})
|
75
|
-
|
|
76
|
-
v
|
77
|
-
Product.find(:all, :conditions => ['products.price < ?', 100])
|
78
|
-
|
79
|
-
7. $lte(等于小于)查询
|
80
|
-
Product.by_scopes({:$le_price => '100'})
|
81
|
-
|
|
82
|
-
v
|
83
|
-
Product.find(:all, :conditions => ['products.price <= ?', 100])
|
84
|
-
|
85
|
-
8. $ne(不等于)查询
|
86
|
-
Product.by_scopes({:$ne_price => '100'})
|
87
|
-
|
|
88
|
-
v
|
89
|
-
Product.find(:all, :conditions => ['products.price != ?', 100])
|
90
|
-
|
91
|
-
9. $in(集合内)查询
|
92
|
-
Product.by_scopes({:$in_price => '100,150,200'})
|
93
|
-
|
|
94
|
-
v
|
95
|
-
Product.find(:all, :conditions => ['products.price in ?', [100, 150, 200])
|
96
|
-
|
97
|
-
10. $nin(集合外)查询
|
98
|
-
Product.by_scopes({:$nin_price => '100,150,200'}) # 查询值 可以为符号','连接的字符串或数组
|
99
|
-
|
|
100
|
-
v
|
101
|
-
Product.find(:all, :conditions => ['products.price not in ?', [100, 150, 200])
|
102
|
-
|
103
|
-
11. $exists(存在或不为空值)查询
|
104
|
-
Product.by_scopes({:$exists_price => value}) #注 value可为任意值
|
105
|
-
|
|
106
|
-
v
|
107
|
-
Product.find(:all, :conditions => ['products.price is not null')
|
108
|
-
|
109
|
-
12. $nexists(不存在或不为空值)查询
|
110
|
-
Product.by_scopes({:$nexists_price => value}) #注 value可为任意值
|
111
|
-
|
|
112
|
-
v
|
113
|
-
Product.find(:all, :conditions => ['products.price is null')
|
114
|
-
|
115
|
-
13. 日期类查询
|
116
|
-
Product.by_scopes({:$gte_created_at => '2012-12-12'}) #注 查询值 可为时间类型的字符串或时间类(包含 Date, DateTime, Time)
|
117
|
-
|
|
118
|
-
v
|
119
|
-
Product.find(:all, :conditions => ["created_at >= '2012-12-12 00:00:00'")
|
120
|
-
=end
|
121
|
-
|
122
|
-
module FindHelper
|
123
|
-
extend ActiveSupport::Concern
|
124
|
-
|
125
|
-
included do
|
126
|
-
self.send(:extend, Scope)
|
127
|
-
end
|
128
|
-
end
|
@@ -1,49 +0,0 @@
|
|
1
|
-
module FindHelper
|
2
|
-
|
3
|
-
class ActiveRecordFinder
|
4
|
-
|
5
|
-
include ::FindHelper::FormatFinderValue
|
6
|
-
attr_reader :klass, :filed, :find_filed, :find_value, :find_type, :filed_type
|
7
|
-
|
8
|
-
FINDER_TYPES = {
|
9
|
-
:$eq => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} = ?", value]},
|
10
|
-
:$gt => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} > ?", value]},
|
11
|
-
:$gte => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} >= ?", value]},
|
12
|
-
:$lt => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} < ?", value]},
|
13
|
-
:$lte => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} <= ?", value]},
|
14
|
-
:$ne => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} != ?", value]},
|
15
|
-
:$in => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} in (?)", format_array]},
|
16
|
-
:$nin => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} not in (?) ", format_array]},
|
17
|
-
:$like => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} like ?", "%#{value}%"]},
|
18
|
-
:$exists => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} is not null "]},
|
19
|
-
:$nexists => lambda{|klass, filed, value| ["#{klass.table_name}.#{filed} is null "]}
|
20
|
-
}
|
21
|
-
|
22
|
-
DEFAULT_FINDER_TYPES = :$eq
|
23
|
-
|
24
|
-
def initialize(klass, filed, find_value)
|
25
|
-
@klass = klass
|
26
|
-
@filed = filed
|
27
|
-
@find_value = find_value
|
28
|
-
end
|
29
|
-
|
30
|
-
def split_filed
|
31
|
-
@find_type = :$eq
|
32
|
-
@find_filed = @filed
|
33
|
-
@find_type, @find_filed = @filed.to_s.split("_", 2) if @filed.to_s.first == "$"
|
34
|
-
@find_type = @find_type.to_sym
|
35
|
-
end
|
36
|
-
|
37
|
-
def to_finder
|
38
|
-
split_filed
|
39
|
-
|
40
|
-
FINDER_TYPES[@find_type].call(@klass, @find_filed, format_value)
|
41
|
-
end
|
42
|
-
|
43
|
-
def field_type
|
44
|
-
@field_type ||= klass.columns_hash[@find_filed.to_s].type
|
45
|
-
end
|
46
|
-
|
47
|
-
end
|
48
|
-
|
49
|
-
end
|
@@ -1,83 +0,0 @@
|
|
1
|
-
module FindHelper
|
2
|
-
|
3
|
-
module FormatFinderValue
|
4
|
-
|
5
|
-
def format_date
|
6
|
-
if find_value.is_a?(Date)
|
7
|
-
find_value
|
8
|
-
elsif find_value.respond_to?(:to_date)
|
9
|
-
find_value.to_date
|
10
|
-
else
|
11
|
-
Date.parse(find_value.to_s)
|
12
|
-
end
|
13
|
-
end
|
14
|
-
|
15
|
-
def format_regexp
|
16
|
-
if find_value.is_a?(Regexp)
|
17
|
-
find_value
|
18
|
-
else
|
19
|
-
Regexp.new(find_value)
|
20
|
-
end
|
21
|
-
end
|
22
|
-
|
23
|
-
def format_time
|
24
|
-
if [DateTime, Time].include?(find_value.class)
|
25
|
-
find_value
|
26
|
-
elsif find_value.respond_to?(:to_time)
|
27
|
-
find_value.to_time
|
28
|
-
else
|
29
|
-
if find_value.is_a?(Numeric)
|
30
|
-
Time.at(find_value)
|
31
|
-
else
|
32
|
-
Time.parse(find_value)
|
33
|
-
end
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
def format_array
|
38
|
-
case find_value
|
39
|
-
when String
|
40
|
-
find_value.split(",")
|
41
|
-
else
|
42
|
-
if find_value.respond_to?(:to_a)
|
43
|
-
find_value.to_a
|
44
|
-
else
|
45
|
-
Array(find_value)
|
46
|
-
end
|
47
|
-
|
48
|
-
end
|
49
|
-
end
|
50
|
-
|
51
|
-
def format_boolean
|
52
|
-
case find_value
|
53
|
-
when String
|
54
|
-
['true', '1'].include?(find_value)
|
55
|
-
when Integer
|
56
|
-
find_value == 1
|
57
|
-
else
|
58
|
-
find_value
|
59
|
-
end
|
60
|
-
end
|
61
|
-
|
62
|
-
def format_value
|
63
|
-
case field_type
|
64
|
-
when :date
|
65
|
-
format_date
|
66
|
-
when :datetime
|
67
|
-
format_time
|
68
|
-
when :time
|
69
|
-
format_time
|
70
|
-
when :integer
|
71
|
-
find_value.to_i
|
72
|
-
when :float
|
73
|
-
find_value.to_f
|
74
|
-
when :boolean
|
75
|
-
format_boolean
|
76
|
-
else
|
77
|
-
find_value
|
78
|
-
end
|
79
|
-
end
|
80
|
-
|
81
|
-
end
|
82
|
-
|
83
|
-
end
|
@@ -1,56 +0,0 @@
|
|
1
|
-
module FindHelper
|
2
|
-
|
3
|
-
class MongoidFinder
|
4
|
-
include ::FindHelper::FormatFinderValue
|
5
|
-
attr_reader :klass, :filed, :find_filed, :find_value, :find_type
|
6
|
-
|
7
|
-
FINDER_TYPES = {
|
8
|
-
:$eq => lambda{|filed, value, ins| {filed => value} },
|
9
|
-
:$gt => lambda{|filed, value, ins| {filed => {:$gt => value}} },
|
10
|
-
:$gte => lambda{|filed, value, ins| {filed => {:$gte => value} } },
|
11
|
-
:$lt => lambda{|filed, value, ins| {filed => {:$lt => value}} },
|
12
|
-
:$lte => lambda{|filed, value, ins| {filed => {:$lte => value}} },
|
13
|
-
:$ne => lambda{|filed, value, ins| {filed => {:$ne => value} } },
|
14
|
-
:$in => lambda{|filed, value, ins| {filed => {:$in => ins.format_array}} },
|
15
|
-
:$nin => lambda{|filed, value, ins| {filed => {:$nin => ins.format_array } } },
|
16
|
-
:$like => lambda{|filed, value, ins| {filed => ins.format_regexp} },
|
17
|
-
:$exists => lambda{|filed, value, ins| {filed => { :$exists => true} } },
|
18
|
-
:$nexists => lambda{|filed, value, ins| {filed => { :$exists => false} } }
|
19
|
-
}
|
20
|
-
FIELD_TYPES = {
|
21
|
-
:Time => :time,
|
22
|
-
:Integer => :integer,
|
23
|
-
:String => :string,
|
24
|
-
:Boolean => :boolean,
|
25
|
-
:Float => :float,
|
26
|
-
:Date => :date
|
27
|
-
}
|
28
|
-
|
29
|
-
DEFAULT_FINDER_TYPES = :$eq
|
30
|
-
|
31
|
-
def initialize(klass, filed, find_value)
|
32
|
-
@klass = klass
|
33
|
-
@filed = filed
|
34
|
-
@find_value = find_value
|
35
|
-
end
|
36
|
-
|
37
|
-
def split_filed
|
38
|
-
@find_type = :$eq
|
39
|
-
@find_filed = @filed
|
40
|
-
@find_type, @find_filed = @filed.to_s.split("_", 2) if @filed.to_s.first == "$"
|
41
|
-
@find_type = @find_type.to_sym
|
42
|
-
end
|
43
|
-
|
44
|
-
def to_finder
|
45
|
-
split_filed
|
46
|
-
|
47
|
-
FINDER_TYPES[@find_type].call(@find_filed, format_value, self)
|
48
|
-
end
|
49
|
-
|
50
|
-
def field_type
|
51
|
-
@field_type ||= FIELD_TYPES[klass.fields[@find_filed.to_s].type.name.to_sym]
|
52
|
-
end
|
53
|
-
|
54
|
-
end
|
55
|
-
|
56
|
-
end
|