Class: Mongoid::Contextual::GeoNear

Inherits:
Object
  • Object
show all
Extended by:
Forwardable
Includes:
Enumerable, Command
Defined in:
build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb

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

Methods included from Command

#client, #command

Constructor Details

#initialize(collection, criteria, near) ⇒ GeoNear

Initialize the new map/reduce directive.

Examples:

Initialize the new map/reduce.

MapReduce.new(criteria, map, reduce)

Parameters:

  • collection (Mongo::Collection)

    The collection to run the operation on.

  • criteria (Criteria)

    The Mongoid criteria.

  • near (String)


66
67
68
69
70
71
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 66

def initialize(collection, criteria, near)
  @collection, @criteria = collection, criteria
  command[:geoNear] = collection.name.to_s
  command[:near] = near
  apply_criteria_options
end

Instance Method Details

#average_distanceFloat | nil

Get the average distance for all documents from the point in the command.

Examples:

Get the average distance.

geo_near.average_distance

Returns:

  • (Float | nil)

    The average distance.



20
21
22
23
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 20

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.

Examples:

Provide the distance multiplier.

geo_near.distance_multiplier(13113.1)

Parameters:

  • value (Integer | Float)

    The distance multiplier.

Returns:

  • (GeoNear)

    The GeoNear wrapper.



52
53
54
55
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 52

def distance_multiplier(value)
  command[:distanceMultiplier] = value
  self
end

#eachEnumerator

Iterates over each of the documents in the $geoNear, excluding the extra information that was passed back from the database.

Examples:

Iterate over the results.

geo_near.each do |doc|
  p doc
end

Returns:

  • (Enumerator)

    The enumerator.



34
35
36
37
38
39
40
41
42
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 34

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?

Examples:

Is this context’s criteria considered empty?

geo_near.empty_and_chainable?

Returns:

  • (true)

    Always true.



186
187
188
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 186

def empty_and_chainable?
  true
end

#executeHash

Execute the $geoNear, returning the raw output.

Examples:

Run the $geoNear

geo_near.execute

Returns:

  • (Hash)

    The raw output



156
157
158
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 156

def execute
  results
end

#inspectString

Get a pretty string representation of the command.

Examples:

Inspect the geoNear.

geo_near.inspect

Returns:

  • (String)

    The inspection string.



79
80
81
82
83
84
85
86
87
88
89
90
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 79

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.

Examples:

Set the max distance.

geo_near.max_distance(0.5)

Get the max distance.

geo_near.max_distance

Parameters:

  • value (Integer | Float) (defaults to: nil)

    The maximum distance.

Returns:

  • (GeoNear | Float)

    The GeoNear command or the value.



104
105
106
107
108
109
110
111
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 104

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.

Examples:

Set the min distance.

geo_near.min_distance(0.5)

Parameters:

  • value (Integer | Float)

    The minimum distance.

Returns:

  • (GeoNear)

    The GeoNear command.



121
122
123
124
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 121

def min_distance(value)
  command[:minDistance] = value
  self
end

#sphericalGeoNear

Tell the command to calculate based on spherical distances.

Examples:

Add the spherical flag.

geo_near.spherical

Returns:



132
133
134
135
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 132

def spherical
  command[:spherical] = true
  self
end

#statsHash

Get the stats for the command run.

Examples:

Get the stats.

geo_near.stats

Returns:

  • (Hash)

    The stats from the command run.



166
167
168
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 166

def stats
  results["stats"]
end

#timeFloat

Get the execution time of the command.

Examples:

Get the execution time.

geo_near.time

Returns:

  • (Float)

    The execution time.



176
177
178
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 176

def time
  stats["time"]
end

#unique(value = true) ⇒ GeoNear

Tell the command whether or not the returned results should be unique.

Examples:

Set the unique flag.

geo_near.unique(false)

Parameters:

  • value (true | false) (defaults to: true)

    Whether to return unique documents.

Returns:



145
146
147
148
# File 'build/mongoid-8.1/lib/mongoid/contextual/geo_near.rb', line 145

def unique(value = true)
  command[:unique] = value
  self
end