|  |  |  | @ -41,6 +41,28 @@ pub struct Collection<'a> { | 
		
	
		
			
				|  |  |  |  |     inner:      *mut bindings::mongoc_collection_t | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | /// Options to configure an aggregate operation.
 | 
		
	
		
			
				|  |  |  |  | pub struct AggregateOptions { | 
		
	
		
			
				|  |  |  |  |     /// Flags to use
 | 
		
	
		
			
				|  |  |  |  |     pub query_flags: Flags<QueryFlag>, | 
		
	
		
			
				|  |  |  |  |     /// Options for the aggregate
 | 
		
	
		
			
				|  |  |  |  |     pub options: Option<Document>, | 
		
	
		
			
				|  |  |  |  |     /// Read prefs to use
 | 
		
	
		
			
				|  |  |  |  |     pub read_prefs:  Option<ReadPrefs> | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | impl AggregateOptions { | 
		
	
		
			
				|  |  |  |  |     /// Default options that are used if no options are specified
 | 
		
	
		
			
				|  |  |  |  |     /// when aggregating.
 | 
		
	
		
			
				|  |  |  |  |     pub fn default() -> AggregateOptions { | 
		
	
		
			
				|  |  |  |  |         AggregateOptions { | 
		
	
		
			
				|  |  |  |  |             query_flags: Flags::new(), | 
		
	
		
			
				|  |  |  |  |             options: None, | 
		
	
		
			
				|  |  |  |  |             read_prefs: None | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  | /// Options to configure a bulk operation.
 | 
		
	
		
			
				|  |  |  |  | pub struct BulkOperationOptions { | 
		
	
		
			
				|  |  |  |  |     /// If the operations must be performed in order
 | 
		
	
	
		
			
				
					|  |  |  | @ -210,6 +232,46 @@ impl<'a> Collection<'a> { | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Execute an aggregation query on the collection.
 | 
		
	
		
			
				|  |  |  |  |     /// The bson 'pipeline' is not validated, simply passed along as appropriate to the server.
 | 
		
	
		
			
				|  |  |  |  |     /// As such, compatibility and errors should be validated in the appropriate server documentation.
 | 
		
	
		
			
				|  |  |  |  |     pub fn aggregate( | 
		
	
		
			
				|  |  |  |  |         &'a self, | 
		
	
		
			
				|  |  |  |  |         pipeline: &Document, | 
		
	
		
			
				|  |  |  |  |         options: Option<&AggregateOptions> | 
		
	
		
			
				|  |  |  |  |     ) -> Result<Cursor<'a>> { | 
		
	
		
			
				|  |  |  |  |         let default_options = AggregateOptions::default(); | 
		
	
		
			
				|  |  |  |  |         let options         = options.unwrap_or(&default_options); | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         let cursor_ptr = unsafe { | 
		
	
		
			
				|  |  |  |  |             bindings::mongoc_collection_aggregate( | 
		
	
		
			
				|  |  |  |  |                 self.inner, | 
		
	
		
			
				|  |  |  |  |                 options.query_flags.flags(), | 
		
	
		
			
				|  |  |  |  |                 try!(Bsonc::from_document(pipeline)).inner(), | 
		
	
		
			
				|  |  |  |  |                 match options.options { | 
		
	
		
			
				|  |  |  |  |                     Some(ref o) => { | 
		
	
		
			
				|  |  |  |  |                         try!(Bsonc::from_document(o)).inner() | 
		
	
		
			
				|  |  |  |  |                     }, | 
		
	
		
			
				|  |  |  |  |                     None => ptr::null() | 
		
	
		
			
				|  |  |  |  |                 }, | 
		
	
		
			
				|  |  |  |  |                 match options.read_prefs { | 
		
	
		
			
				|  |  |  |  |                     Some(ref prefs) => prefs.inner(), | 
		
	
		
			
				|  |  |  |  |                     None => ptr::null() | 
		
	
		
			
				|  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |             ) | 
		
	
		
			
				|  |  |  |  |         }; | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         if cursor_ptr.is_null() { | 
		
	
		
			
				|  |  |  |  |             return Err(InvalidParamsError.into()) | 
		
	
		
			
				|  |  |  |  |         } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |         Ok(Cursor::new( | 
		
	
		
			
				|  |  |  |  |             cursor::CreatedBy::Collection(self), | 
		
	
		
			
				|  |  |  |  |             cursor_ptr, | 
		
	
		
			
				|  |  |  |  |             None | 
		
	
		
			
				|  |  |  |  |         )) | 
		
	
		
			
				|  |  |  |  |     } | 
		
	
		
			
				|  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |     /// Execute a command on the collection.
 | 
		
	
		
			
				|  |  |  |  |     /// This is performed lazily and therefore requires calling `next` on the resulting cursor.
 | 
		
	
		
			
				|  |  |  |  |     pub fn command( | 
		
	
	
		
			
				
					|  |  |  | 
 |