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.
Files changed (47) hide show
  1. checksums.yaml +4 -4
  2. metadata +4 -84
  3. data/MIT-LICENSE +0 -20
  4. data/README.rdoc +0 -3
  5. data/Rakefile +0 -32
  6. data/lib/find_helper.rb +0 -128
  7. data/lib/find_helper/active_record_finder.rb +0 -49
  8. data/lib/find_helper/format_finder_value.rb +0 -83
  9. data/lib/find_helper/mongoid_finder.rb +0 -56
  10. data/lib/find_helper/scope.rb +0 -23
  11. data/lib/find_helper/version.rb +0 -3
  12. data/lib/tasks/find_helper_tasks.rake +0 -4
  13. data/test/dummy/README.rdoc +0 -28
  14. data/test/dummy/Rakefile +0 -6
  15. data/test/dummy/app/assets/javascripts/application.js +0 -13
  16. data/test/dummy/app/assets/stylesheets/application.css +0 -15
  17. data/test/dummy/app/controllers/application_controller.rb +0 -5
  18. data/test/dummy/app/helpers/application_helper.rb +0 -2
  19. data/test/dummy/app/views/layouts/application.html.erb +0 -14
  20. data/test/dummy/bin/bundle +0 -3
  21. data/test/dummy/bin/rails +0 -4
  22. data/test/dummy/bin/rake +0 -4
  23. data/test/dummy/config.ru +0 -4
  24. data/test/dummy/config/application.rb +0 -23
  25. data/test/dummy/config/boot.rb +0 -5
  26. data/test/dummy/config/database.yml +0 -25
  27. data/test/dummy/config/environment.rb +0 -5
  28. data/test/dummy/config/environments/development.rb +0 -37
  29. data/test/dummy/config/environments/production.rb +0 -78
  30. data/test/dummy/config/environments/test.rb +0 -39
  31. data/test/dummy/config/initializers/assets.rb +0 -8
  32. data/test/dummy/config/initializers/backtrace_silencers.rb +0 -7
  33. data/test/dummy/config/initializers/cookies_serializer.rb +0 -3
  34. data/test/dummy/config/initializers/filter_parameter_logging.rb +0 -4
  35. data/test/dummy/config/initializers/inflections.rb +0 -16
  36. data/test/dummy/config/initializers/mime_types.rb +0 -4
  37. data/test/dummy/config/initializers/session_store.rb +0 -3
  38. data/test/dummy/config/initializers/wrap_parameters.rb +0 -14
  39. data/test/dummy/config/locales/en.yml +0 -23
  40. data/test/dummy/config/routes.rb +0 -56
  41. data/test/dummy/config/secrets.yml +0 -22
  42. data/test/dummy/public/404.html +0 -67
  43. data/test/dummy/public/422.html +0 -67
  44. data/test/dummy/public/500.html +0 -66
  45. data/test/dummy/public/favicon.ico +0 -0
  46. data/test/find_helper_test.rb +0 -7
  47. data/test/test_helper.rb +0 -15
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: a7c36ff779bad0716e65577c8e01b31fc95d8e00
4
- data.tar.gz: ac5d43f50143dd7ff29ca8b40f74200352dac5cc
3
+ metadata.gz: 6ad991d74e33439be38530e5c411cd8937a66834
4
+ data.tar.gz: 5648dfcfb78020a5ee7bd0cc9368c5e1876659bb
5
5
  SHA512:
6
- metadata.gz: 9414207d3b4a9a8118a496527f83771639e5f6bd649e3a250e67fd401a2c8fe01ae46aa6e1c1d4c7ca8c376deb194e0c029253efdeb2e334752ed9b753b698d1
7
- data.tar.gz: 9be639c05046a34fd0bf192230a28218f397ccbe4f566fb03e9b1d35c844f9a89b1ea40b89ec8417bb3502cec694edbd79938eec9f864c99b44249727ec5482a
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.1
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-29 00:00:00.000000000 Z
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: []
@@ -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.
@@ -1,3 +0,0 @@
1
- = FindHelper
2
-
3
- This project rocks and uses MIT-LICENSE.
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
@@ -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