NAME
MongoDBx::Protocol - pure perl implementation of MongoDB protocol
VERSION
version 0.02
SYNOPSIS
my $p = MongoDBx::Protocol->new;
my $msg = $p->insert({
header => { requestID => 3, responseTo => 2 },
fullCollectionName => 'test.test',
documents => [ { a => b }, { c => d } ],
});
my $sock = IO::Socket::INET->new(
PeerAddr => 'localhost', PeerPort => 27017, Proto => 'tcp'
);
$sock->print($msg);
DESCRIPTION
This is a pure perl implementation of MongoDB protocol as described at http://www.mongodb.org/display/DOCS/Mongo+Wire+Protocol. Such modules as MongoDB and AnyMongo haven't public API for dealing with MongoDB protocol at low level. Using MongoDBx::Protocol you can encode/decode messages which you can send/recieve to/from MongoDB.
This module doesn't try to work very effectively, for this purposes you should use some XS code from MongoDB module.
For encoding and decoding BSON documents this module uses BSON module.
METHODS
All encoding/decoding methods takes/returns hashref. See the key names for hashes and detailed description of this keys at MongoDB site.
- new()
-
Creates new instance of MongoDBx::Protocol.
- update($options)
-
Returns binary string that represents updating a documents in MongoDB.
$options
is a hashref that contains following keys:- header (optional)
-
Hashref with
requestID
andresponseTo
keys. Default value for this keys is 0. - flags (optional)
-
Hashref with possible flags
Upsert
,MultiUpdate
. - fullCollectionName
-
Fully qualified name of colllection (for example, "foo.bar").
- selector
-
Hashref that will be passed to BSON module for encoding to BSON document.
This hashref represents the query to select the document.
- update
-
Hashref with specification of the update to perform.
- insert($options)
-
$options
contains: - query($options)
-
$options
contains:- header (optional)
- flags (optional)
-
Possible flags are:
TailableCursor
,SlaveOk
,OplogReplay
,NoCursorTimeout
,AwaitData
,Exhaust
,Partial
. - fullCollectionName
- numberToSkip (optional)
-
Default is 0.
- numberToReturn (optional)
-
Default is 1.
- query
- returnFieldSelector (optional)
-
Which fields will be returned.
- getmore($options)
-
$options
contains: - delete($options)
-
$options
contains: - kill_cursors($options)
-
$options
contains: - msg($options)
-
$options
contains - decode_reply($reply_str)
-
Decodes binary response
$reply_str
from MongoDB and returns hashref with a following structure:- header
- responseFlags
- cursorID
- startingFrom
- numberReturned
- documents
KNOWN BUGS
Works only on 64-bit Perl. I'll fix it soon.
SEE ALSO
http://www.mongodb.org/display/DOCS/Mongo+Wire+Protocol
AUTHOR
Yury Zavarin <yury.zavarin@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2011 by Yury Zavarin.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.