Class: Mongoid::Contextual::GeoNear
- Inherits:
-
Object
- Object
- Mongoid::Contextual::GeoNear
- Extended by:
- Forwardable
- Includes:
- Enumerable, Command
- Defined in:
- lib/mongoid/contextual/geo_near.rb
Overview
Represents a $geoNear database command instruction.
Instance Attribute Summary
Attributes included from Command
#collection, #collection The collection to query against., #criteria, #criteria The criteria for the context.
Instance Method Summary collapse
-
#average_distance ⇒ Float | nil
Get the average distance for all documents from the point in the command.
-
#distance_multiplier(value) ⇒ GeoNear
Provide a distance multiplier to be used for each returned distance.
-
#each ⇒ Enumerator
Iterates over each of the documents in the $geoNear, excluding the extra information that was passed back from the database.
-
#empty_and_chainable? ⇒ true
Is this context’s criteria considered empty?.
-
#execute ⇒ Hash
Execute the $geoNear, returning the raw output.
-
#initialize(collection, criteria, near) ⇒ GeoNear
constructor
Initialize the new map/reduce directive.
-
#inspect ⇒ String
Get a pretty string representation of the command.
-
#max_distance(value = nil) ⇒ GeoNear | Float
Specify the maximum distance to find documents for, or get the value of the document with the furthest distance.
-
#min_distance(value) ⇒ GeoNear
Specify the minimum distance to find documents for.
-
#spherical ⇒ GeoNear
Tell the command to calculate based on spherical distances.
-
#stats ⇒ Hash
Get the stats for the command run.
-
#time ⇒ Float
Get the execution time of the command.
-
#unique(value = true) ⇒ GeoNear
Tell the command whether or not the returned results should be unique.
Methods included from Command
Constructor Details
#initialize(collection, criteria, near) ⇒ GeoNear
Initialize the new map/reduce directive.
69 70 71 72 73 74 |
# File 'lib/mongoid/contextual/geo_near.rb', line 69 def initialize(collection, criteria, near) @collection, @criteria = collection, criteria command[:geoNear] = collection.name.to_s command[:near] = near end |
Instance Method Details
#average_distance ⇒ Float | nil
Get the average distance for all documents from the point in the command.
23 24 25 26 |
# File 'lib/mongoid/contextual/geo_near.rb', line 23 def average_distance average = stats["avgDistance"] (average.nil? || average.nan?) ? nil : average end |
#distance_multiplier(value) ⇒ GeoNear
Provide a distance multiplier to be used for each returned distance.
55 56 57 58 |
# File 'lib/mongoid/contextual/geo_near.rb', line 55 def distance_multiplier(value) command[:distanceMultiplier] = value self end |
#each ⇒ Enumerator
Iterates over each of the documents in the $geoNear, excluding the extra information that was passed back from the database.
37 38 39 40 41 42 43 44 45 |
# File 'lib/mongoid/contextual/geo_near.rb', line 37 def each if block_given? documents.each do |doc| yield doc end else to_enum end end |
#empty_and_chainable? ⇒ true
Is this context’s criteria considered empty?
189 190 191 |
# File 'lib/mongoid/contextual/geo_near.rb', line 189 def empty_and_chainable? true end |
#execute ⇒ Hash
Execute the $geoNear, returning the raw output.
159 160 161 |
# File 'lib/mongoid/contextual/geo_near.rb', line 159 def execute results end |
#inspect ⇒ String
Get a pretty string representation of the command.
82 83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/mongoid/contextual/geo_near.rb', line 82 def inspect %Q{#<Mongoid::Contextual::GeoNear selector: #{criteria.selector.inspect} class: #{criteria.klass} near: #{command[:near]} multiplier: #{command[:distanceMultiplier] || "N/A"} max: #{command[:maxDistance] || "N/A"} min: #{command[:minDistance] || "N/A"} unique: #{command[:unique].nil? ? true : command[:unique]} spherical: #{command[:spherical] || false}> } end |
#max_distance(value = nil) ⇒ GeoNear | Float
Specify the maximum distance to find documents for, or get the value of the document with the furthest distance.
107 108 109 110 111 112 113 114 |
# File 'lib/mongoid/contextual/geo_near.rb', line 107 def max_distance(value = nil) if value command[:maxDistance] = value self else stats["maxDistance"] end end |
#min_distance(value) ⇒ GeoNear
Specify the minimum distance to find documents for.
124 125 126 127 |
# File 'lib/mongoid/contextual/geo_near.rb', line 124 def min_distance(value) command[:minDistance] = value self end |
#spherical ⇒ GeoNear
Tell the command to calculate based on spherical distances.
135 136 137 138 |
# File 'lib/mongoid/contextual/geo_near.rb', line 135 def spherical command[:spherical] = true self end |
#stats ⇒ Hash
Get the stats for the command run.
169 170 171 |
# File 'lib/mongoid/contextual/geo_near.rb', line 169 def stats results["stats"] end |
#time ⇒ Float
Get the execution time of the command.
179 180 181 |
# File 'lib/mongoid/contextual/geo_near.rb', line 179 def time stats["time"] end |
#unique(value = true) ⇒ GeoNear
Tell the command whether or not the returned results should be unique.
148 149 150 151 |
# File 'lib/mongoid/contextual/geo_near.rb', line 148 def unique(value = true) command[:unique] = value self end |