Class: Mongoid::Criteria::Queryable::Pipeline
- Inherits:
-
Array
- Object
- Array
- Mongoid::Criteria::Queryable::Pipeline
- Defined in:
- lib/mongoid/criteria/queryable/pipeline.rb
Overview
Represents an aggregation pipeline.
Instance Attribute Summary collapse
-
#aliases ⇒ Object
readonly
Returns the value of attribute aliases.
- #aliases The field aliases.(Thefieldaliases.) ⇒ Object readonly
Instance Method Summary collapse
-
#__deep_copy__ ⇒ Pipeline
Deep copy the aggregation pipeline.
-
#group(entry) ⇒ Pipeline
Add a group operation to the aggregation pipeline.
-
#initialize(aliases = {}) {|_self| ... } ⇒ Pipeline
constructor
Initialize the new pipeline.
-
#project(entry) ⇒ Pipeline
Adds a $project entry to the aggregation pipeline.
-
#unwind(field_or_doc) ⇒ Pipeline
Add the $unwind entry to the pipeline.
Constructor Details
#initialize(aliases = {}) {|_self| ... } ⇒ Pipeline
Initialize the new pipeline.
45 46 47 48 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 45 def initialize(aliases = {}) @aliases = aliases yield(self) if block_given? end |
Instance Attribute Details
#aliases ⇒ Object (readonly)
Returns the value of attribute aliases.
9 10 11 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 9 def aliases @aliases end |
#aliases The field aliases.(Thefieldaliases.) ⇒ Object (readonly)
9 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 9 attr_reader :aliases |
Instance Method Details
#__deep_copy__ ⇒ Pipeline
Deep copy the aggregation pipeline. Will clone all the values in the pipeline as well as the pipeline itself.
18 19 20 21 22 23 24 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 18 def __deep_copy__ self.class.new(aliases) do |copy| each do |entry| copy.push(entry.__deep_copy__) end end end |
#group(entry) ⇒ Pipeline
Add a group operation to the aggregation pipeline.
34 35 36 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 34 def group(entry) push('$group' => evolve(entry.)) end |
#project(entry) ⇒ Pipeline
Adds a $project entry to the aggregation pipeline.
58 59 60 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 58 def project(entry) push('$project' => evolve(entry)) end |
#unwind(field_or_doc) ⇒ Pipeline
Add the $unwind entry to the pipeline.
72 73 74 75 76 77 78 79 80 |
# File 'lib/mongoid/criteria/queryable/pipeline.rb', line 72 def unwind(field_or_doc) if field_or_doc.respond_to? :keys push('$unwind' => field_or_doc) else normalized = field_or_doc.to_s name = aliases[normalized] || normalized push('$unwind' => name.__mongo_expression__) end end |