| 
									
										
										
										
											2009-03-25 13:22:28 -04:00
										 |  |  | USING: accessors assocs bson.reader bson.writer byte-arrays | 
					
						
							| 
									
										
										
										
											2010-02-26 10:57:49 -05:00
										 |  |  | byte-vectors combinators formatting fry io io.binary io.encodings.private | 
					
						
							|  |  |  | io.encodings.binary io.encodings.string io.encodings.utf8 io.encodings.utf8.private io.files | 
					
						
							|  |  |  | kernel locals math mongodb.msg namespaces sequences uuid bson.writer.private ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | FROM: mongodb.connection => connection-buffer ;
 | 
					
						
							|  |  |  | FROM: alien => byte-length ;
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | IN: mongodb.operations | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  | M: byte-vector byte-length length ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PREDICATE: mdb-reply-op < integer OP_Reply = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-query-op < integer OP_Query = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-insert-op < integer OP_Insert = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-update-op < integer OP_Update = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-delete-op < integer OP_Delete = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-getmore-op < integer OP_GetMore = ;
 | 
					
						
							|  |  |  | PREDICATE: mdb-killcursors-op < integer OP_KillCursors = ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CONSTANT: MSG-HEADER-SIZE 16
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  | SYMBOL: msg-bytes-read | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bytes-read> ( -- integer )
 | 
					
						
							|  |  |  |     msg-bytes-read get ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : >bytes-read ( integer -- )
 | 
					
						
							|  |  |  |     msg-bytes-read set ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : change-bytes-read ( integer -- )
 | 
					
						
							|  |  |  |     bytes-read> [ 0 ] unless* + >bytes-read ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : read-int32 ( -- int32 ) 4 [ read le> ] [ change-bytes-read ] bi ; inline
 | 
					
						
							|  |  |  | : read-longlong ( -- longlong ) 8 [ read le> ] [ change-bytes-read ] bi ; inline
 | 
					
						
							|  |  |  | : read-byte-raw ( -- byte-raw ) 1 [ read le> ] [ change-bytes-read ] bi ; inline
 | 
					
						
							|  |  |  | : read-byte ( -- byte ) read-byte-raw first ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : copy-header ( message msg-stub -- message )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     { | 
					
						
							|  |  |  |         [ length>> >>length ] | 
					
						
							|  |  |  |         [ req-id>> >>req-id ] | 
					
						
							|  |  |  |         [ resp-id>> >>resp-id ] | 
					
						
							|  |  |  |         [ opcode>> >>opcode ] | 
					
						
							|  |  |  |         [ flags>> >>flags ] | 
					
						
							|  |  |  |     } cleave ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : reply-read-message ( msg-stub -- message )
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  |     [ <mdb-reply-msg> ] dip copy-header | 
					
						
							|  |  |  |     read-longlong >>cursor | 
					
						
							|  |  |  |     read-int32 >>start# | 
					
						
							|  |  |  |     read-int32 [ >>returned# ] keep
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     [ H{ } clone stream>assoc ] collector [ times ] dip >>objects ;
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  | : (read-message) ( message opcode -- message )
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     OP_Reply =
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ reply-read-message ] | 
					
						
							|  |  |  |     [ "unknown message type" throw ] if ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | : read-header ( message -- message )
 | 
					
						
							|  |  |  |     read-int32 >>length | 
					
						
							|  |  |  |     read-int32 >>req-id | 
					
						
							|  |  |  |     read-int32 >>resp-id | 
					
						
							|  |  |  |     read-int32 >>opcode | 
					
						
							|  |  |  |     read-int32 >>flags ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-07 07:54:53 -05:00
										 |  |  | : write-header ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ req-id>> write-int32 ] | 
					
						
							|  |  |  |     [ resp-id>> write-int32 ] | 
					
						
							|  |  |  |     [ opcode>> write-int32 ] tri ; inline
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : read-message ( -- message )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |         mdb-msg new 0 >bytes-read read-header | 
					
						
							|  |  |  |         [ ] [ opcode>> ] bi (read-message) | 
					
						
							|  |  |  |     ] with-scope ;
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  | : (write-message) ( message quot -- )
 | 
					
						
							|  |  |  |     [ connection-buffer dup ] 2dip
 | 
					
						
							|  |  |  |     '[ | 
					
						
							|  |  |  |         [ _ [ write-header ] [ @ ] bi ] with-length-prefix | 
					
						
							|  |  |  |     ] with-output-stream* write flush ; inline
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-28 14:56:15 -04:00
										 |  |  | :: build-query-object ( query -- selector )
 | 
					
						
							| 
									
										
										
										
											2009-10-27 22:50:31 -04:00
										 |  |  |     H{ } clone :> selector
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     query { | 
					
						
							|  |  |  |         [ orderby>> [ "$orderby" selector set-at ] when* ] | 
					
						
							|  |  |  |         [ explain>> [ "$explain" selector set-at ] when* ] | 
					
						
							|  |  |  |         [ hint>> [ "$hint" selector set-at ] when* ] | 
					
						
							|  |  |  |         [ query>> "query" selector set-at ] | 
					
						
							|  |  |  |     } cleave selector ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-query-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             [ flags>> write-int32 ] | 
					
						
							|  |  |  |             [ collection>> write-cstring ] | 
					
						
							|  |  |  |             [ skip#>> write-int32 ] | 
					
						
							|  |  |  |             [ return#>> write-int32 ] | 
					
						
							|  |  |  |             [ build-query-object assoc>stream ] | 
					
						
							|  |  |  |             [ returnfields>> [ assoc>stream ] when* ] | 
					
						
							|  |  |  |         } cleave
 | 
					
						
							|  |  |  |     ] (write-message) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-insert-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |        [ flags>> write-int32 ] | 
					
						
							|  |  |  |        [ collection>> write-cstring ] | 
					
						
							|  |  |  |        [ objects>> [ assoc>stream ] each ] tri
 | 
					
						
							|  |  |  |     ] (write-message) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-update-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |             [ flags>> write-int32 ] | 
					
						
							|  |  |  |             [ collection>> write-cstring ] | 
					
						
							| 
									
										
										
										
											2010-07-31 04:48:49 -04:00
										 |  |  |             [ update-flags>> write-int32 ] | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |             [ selector>> assoc>stream ] | 
					
						
							|  |  |  |             [ object>> assoc>stream ] | 
					
						
							|  |  |  |         } cleave
 | 
					
						
							|  |  |  |     ] (write-message) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-delete-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							| 
									
										
										
										
											2010-07-31 05:41:07 -04:00
										 |  |  |         { | 
					
						
							|  |  |  |             [ flags>> write-int32 ] | 
					
						
							|  |  |  |             [ collection>> write-cstring ] | 
					
						
							|  |  |  |             [ delete-flags>> write-int32 ] | 
					
						
							|  |  |  |             [ selector>> assoc>stream ] | 
					
						
							|  |  |  |         } cleave
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     ] (write-message) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-getmore-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |            [ flags>> write-int32 ] | 
					
						
							|  |  |  |            [ collection>> write-cstring ] | 
					
						
							|  |  |  |            [ return#>> write-int32 ] | 
					
						
							|  |  |  |            [ cursor>> write-longlong ] | 
					
						
							|  |  |  |         } cleave
 | 
					
						
							|  |  |  |     ] (write-message) ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  | : write-killcursors-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     [ | 
					
						
							|  |  |  |        [ flags>> write-int32 ] | 
					
						
							|  |  |  |        [ cursors#>> write-int32 ] | 
					
						
							|  |  |  |        [ cursors>> [ write-longlong ] each ] tri
 | 
					
						
							|  |  |  |     ] (write-message) ; inline
 | 
					
						
							| 
									
										
										
										
											2009-03-01 16:45:38 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  | : write-message ( message -- )
 | 
					
						
							| 
									
										
										
										
											2015-06-29 19:43:15 -04:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2010-04-09 04:28:32 -04:00
										 |  |  |         { [ dup mdb-query-msg? ] [ write-query-message ] } | 
					
						
							|  |  |  |         { [ dup mdb-insert-msg? ] [ write-insert-message ] } | 
					
						
							|  |  |  |         { [ dup mdb-update-msg? ] [ write-update-message ] } | 
					
						
							|  |  |  |         { [ dup mdb-delete-msg? ] [ write-delete-message ] } | 
					
						
							|  |  |  |         { [ dup mdb-getmore-msg? ] [ write-getmore-message ] } | 
					
						
							|  |  |  |         { [ dup mdb-killcursors-msg? ] [ write-killcursors-message ] } | 
					
						
							| 
									
										
										
										
											2010-01-12 14:40:57 -05:00
										 |  |  |     } cond ;
 |