mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 02:06:04 +02:00 
			
		
		
		
	Make it work again
This commit is contained in:
		| @@ -59,13 +59,20 @@ public: | |||||||
| 		/// Destructor | 		/// Destructor | ||||||
|  |  | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| // BSON Embedded Array | // BSON Embedded Array | ||||||
| // spec: document | // spec: document | ||||||
| template<> | template<> | ||||||
| struct ElementTraits<Array::Ptr> | struct ElementTraits<Array::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x04 }; | 	enum { TypeId = 0x04 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Array::Ptr& value) | ||||||
|  | 	{ | ||||||
|  | 		//TODO: | ||||||
|  | 		return value.isNull() ? "null" : "[]"; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| @@ -79,7 +86,7 @@ inline void BSONWriter::write<Array::Ptr>(Array::Ptr& from) | |||||||
| { | { | ||||||
| 	from->write(_writer); | 	from->write(_writer); | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
|   | |||||||
| @@ -39,7 +39,6 @@ | |||||||
| #define _MongoDB_BSONReader_included | #define _MongoDB_BSONReader_included | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/MongoDB/Document.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -50,7 +49,7 @@ class MongoDB_API BSONReader | |||||||
| 	/// Class for reading BSON from a Poco::BinaryReader | 	/// Class for reading BSON from a Poco::BinaryReader | ||||||
| { | { | ||||||
| public: | public: | ||||||
| 	BSONReader(Poco::BinaryReader& reader) : _reader(reader) | 	BSONReader(const Poco::BinaryReader& reader) : _reader(reader) | ||||||
| 		/// Constructor | 		/// Constructor | ||||||
| 	{ | 	{ | ||||||
| 	} | 	} | ||||||
| @@ -60,9 +59,13 @@ public: | |||||||
| 	{ | 	{ | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	void read(Document& v); | 	template<typename T> | ||||||
|  | 	void read(T& t) | ||||||
| 		/// Reads the value from the reader. The default implementation uses the >> operator to | 		/// Reads the value from the reader. The default implementation uses the >> operator to | ||||||
| 		/// the given argument. Special types can write their own version. | 		/// the given argument. Special types can write their own version. | ||||||
|  | 	{ | ||||||
|  | 		_reader >> t; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	std::string readCString(); | 	std::string readCString(); | ||||||
| 		/// Reads a cstring from the reader. | 		/// Reads a cstring from the reader. | ||||||
|   | |||||||
| @@ -38,10 +38,8 @@ | |||||||
| #ifndef _MongoDB_BSONWriter_included | #ifndef _MongoDB_BSONWriter_included | ||||||
| #define _MongoDB_BSONWriter_included | #define _MongoDB_BSONWriter_included | ||||||
|  |  | ||||||
| #include "Poco/BinaryWriter.h" |  | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/MongoDB/Document.h" | #include "Poco/BinaryWriter.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -53,15 +51,23 @@ class MongoDB_API BSONWriter | |||||||
| 	/// Class for writing BSON to a Poco::BinaryWriter. | 	/// Class for writing BSON to a Poco::BinaryWriter. | ||||||
| { | { | ||||||
| public: | public: | ||||||
| 	BSONWriter(Poco::BinaryWriter& writer); | 	BSONWriter(const Poco::BinaryWriter& writer) : _writer(writer) | ||||||
| 		/// Constructor | 		/// Constructor | ||||||
|  | 	{ | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	virtual ~BSONWriter(); | 	virtual ~BSONWriter() | ||||||
| 		/// Destructor | 		/// Destructor | ||||||
|  | 	{ | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	template<typename T> | ||||||
| 	void write(const Document& v); | 	void write(T& t) | ||||||
|  | 		/// Writes the value to the writer. The default implementation uses | ||||||
|  | 		/// the << operator. Special types can write their own version. | ||||||
|  | 	{ | ||||||
|  | 		_writer << t; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	void writeCString(const std::string& value); | 	void writeCString(const std::string& value); | ||||||
| 		/// Writes a cstring to the writer. A cstring is a string | 		/// Writes a cstring to the writer. A cstring is a string | ||||||
| @@ -72,6 +78,12 @@ private: | |||||||
| 	Poco::BinaryWriter _writer; | 	Poco::BinaryWriter _writer; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | inline void BSONWriter::writeCString(const std::string& value) | ||||||
|  | { | ||||||
|  | 	_writer.writeRaw(value); | ||||||
|  | 	_writer << (unsigned char) 0x00; | ||||||
|  | } | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
| #endif //  _MongoDB_BSONWriter_included | #endif //  _MongoDB_BSONWriter_included | ||||||
|   | |||||||
| @@ -39,13 +39,16 @@ | |||||||
| #define _MongoDB_Binary_included | #define _MongoDB_Binary_included | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/Buffer.h" |  | ||||||
| #include "Poco/MongoDB/Element.h" | #include "Poco/MongoDB/Element.h" | ||||||
|  | #include "Poco/Base64Encoder.h" | ||||||
|  | #include "Poco/Buffer.h" | ||||||
|  | #include "Poco/StreamCopier.h" | ||||||
|  | #include "Poco/MemoryStream.h" | ||||||
|  |  | ||||||
| namespace Poco | #include <sstream> | ||||||
| { |  | ||||||
| namespace MongoDB | namespace Poco { | ||||||
| { | namespace MongoDB { | ||||||
|  |  | ||||||
| class MongoDB_API Binary | class MongoDB_API Binary | ||||||
| 	/// Implements BSON Binary. It's a wrapper around a Poco::Buffer<unsigned char>. | 	/// Implements BSON Binary. It's a wrapper around a Poco::Buffer<unsigned char>. | ||||||
| @@ -63,14 +66,11 @@ public: | |||||||
|  |  | ||||||
|  |  | ||||||
| 	virtual ~Binary(); | 	virtual ~Binary(); | ||||||
|  | 		/// Destructor | ||||||
|  |  | ||||||
|  |  | ||||||
| 	unsigned char* begin(); | 	Buffer<unsigned char>& buffer(); | ||||||
| 		/// Returns the start of the buffer | 		/// Returns a reference to the buffer | ||||||
|  |  | ||||||
|  |  | ||||||
| 	Poco::Int32 size() const; |  | ||||||
| 		/// Returns the size of the buffer |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 	unsigned char subtype() const; | 	unsigned char subtype() const; | ||||||
| @@ -81,27 +81,18 @@ public: | |||||||
| 		/// Sets the subtype | 		/// Sets the subtype | ||||||
|  |  | ||||||
|  |  | ||||||
| 	void resize(std::size_t newSize); | 	std::string toString() const; | ||||||
| 		/// Resizes the buffer | 		/// Returns the binary encoded in Base64 | ||||||
|  |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  |  | ||||||
| 	Poco::Buffer<unsigned char> _buffer; | 	Buffer<unsigned char> _buffer; | ||||||
|  |  | ||||||
|  |  | ||||||
| 	unsigned char _subtype; | 	unsigned char _subtype; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline unsigned char* Binary::begin() |  | ||||||
| { |  | ||||||
| 	return _buffer.begin(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| inline Poco::Int32 Binary::size() const |  | ||||||
| { |  | ||||||
| 	return _buffer.size(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| inline unsigned char Binary::subtype() const | inline unsigned char Binary::subtype() const | ||||||
| { | { | ||||||
| @@ -114,13 +105,24 @@ inline void Binary::subtype(unsigned char type) | |||||||
| 	_subtype = type; | 	_subtype = type; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
|  | inline Buffer<unsigned char>& Binary::buffer() | ||||||
|  | { | ||||||
|  | 	return _buffer; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // BSON Embedded Document | // BSON Embedded Document | ||||||
| // spec: binary | // spec: binary | ||||||
| template<> | template<> | ||||||
| struct ElementTraits<Binary::Ptr> | struct ElementTraits<Binary::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x05 }; | 	enum { TypeId = 0x05 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Binary::Ptr& value) | ||||||
|  | 	{ | ||||||
|  | 		return value.isNull() ? "" : value->toString(); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| @@ -129,22 +131,22 @@ inline void BSONReader::read<Binary::Ptr>(Binary::Ptr& to) | |||||||
| 	Poco::Int32 size; | 	Poco::Int32 size; | ||||||
| 	_reader >> size; | 	_reader >> size; | ||||||
|  |  | ||||||
| 	to->resize(size); | 	to->buffer().resize(size); | ||||||
|  |  | ||||||
| 	unsigned char subtype; | 	unsigned char subtype; | ||||||
| 	_reader >> subtype; | 	_reader >> subtype; | ||||||
| 	to->subtype(subtype); | 	to->subtype(subtype); | ||||||
| 	 | 	 | ||||||
| 	_reader.readRaw((char*) to->begin(), size); | 	_reader.readRaw((char*) to->buffer().begin(), size); | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| inline void BSONWriter::write<Binary::Ptr>(Binary::Ptr& from) | inline void BSONWriter::write<Binary::Ptr>(Binary::Ptr& from) | ||||||
| { | { | ||||||
| 	_writer << from->subtype(); | 	_writer << from->subtype(); | ||||||
| 	_writer.writeRaw((char*) from->begin(), from->size()); | 	_writer.writeRaw((char*) from->buffer().begin(), from->buffer().size()); | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										69
									
								
								MongoDB/include/Poco/MongoDB/Database.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								MongoDB/include/Poco/MongoDB/Database.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | // | ||||||
|  | // Database.h | ||||||
|  | // | ||||||
|  | // $Id$ | ||||||
|  | // | ||||||
|  | // Library: MongoDB | ||||||
|  | // Package: MongoDB | ||||||
|  | // Module:  Database | ||||||
|  | // | ||||||
|  | // Definition of the Database class. | ||||||
|  | // | ||||||
|  | // Copyright (c) 2012, Applied Informatics Software Engineering GmbH. | ||||||
|  | // and Contributors. | ||||||
|  | // | ||||||
|  | // Permission is hereby granted, free of charge, to any person or organization | ||||||
|  | // obtaining a copy of the software and accompanying documentation covered by | ||||||
|  | // this license (the "Software") to use, reproduce, display, distribute, | ||||||
|  | // execute, and transmit the Software, and to prepare derivative works of the | ||||||
|  | // Software, and to permit third-parties to whom the Software is furnished to | ||||||
|  | // do so, all subject to the following: | ||||||
|  | // | ||||||
|  | // The copyright notices in the Software and this entire statement, including | ||||||
|  | // the above license grant, this restriction and the following disclaimer, | ||||||
|  | // must be included in all copies of the Software, in whole or in part, and | ||||||
|  | // all derivative works of the Software, unless such copies or derivative | ||||||
|  | // works are solely in the form of machine-executable object code generated by | ||||||
|  | // a source language processor. | ||||||
|  | // | ||||||
|  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT | ||||||
|  | // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE | ||||||
|  | // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, | ||||||
|  | // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||||
|  | // DEALINGS IN THE SOFTWARE. | ||||||
|  | // | ||||||
|  | #ifndef _MongoDB_Database_included | ||||||
|  | #define _MongoDB_Database_included | ||||||
|  |  | ||||||
|  | #include "Poco/MongoDB/MongoDB.h" | ||||||
|  | #include "Poco/MongoDB/Document.h" | ||||||
|  | #include "Poco/MongoDB/QueryRequest.h" | ||||||
|  |  | ||||||
|  | namespace Poco { | ||||||
|  | namespace MongoDB { | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class MongoDB_API Database | ||||||
|  | { | ||||||
|  | public: | ||||||
|  | 	Database(const std::string& db); | ||||||
|  |  | ||||||
|  | 	 | ||||||
|  | 	virtual ~Database(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	Poco::SharedPtr<Poco::MongoDB::QueryRequest> createQueryRequest(const std::string& collectionName); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	Poco::SharedPtr<Poco::MongoDB::QueryRequest> createCountRequest(const std::string& collectionName); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | private: | ||||||
|  | 	std::string _dbname; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
|  | #endif // _MongoDB_Database_included | ||||||
| @@ -38,18 +38,19 @@ | |||||||
| #ifndef _MongoDB_Document_included | #ifndef _MongoDB_Document_included | ||||||
| #define _MongoDB_Document_included | #define _MongoDB_Document_included | ||||||
|  |  | ||||||
| #include "Poco/SharedPtr.h" | #include <algorithm> | ||||||
| #include "Poco/Dynamic/Struct.h" |  | ||||||
|  | #include "Poco/BinaryReader.h" | ||||||
|  | #include "Poco/BinaryWriter.h" | ||||||
|  |  | ||||||
|  | #include "Poco/MongoDB/MongoDB.h" | ||||||
|  | #include "Poco/MongoDB/Element.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| namespace MongoDB | namespace MongoDB | ||||||
| { | { | ||||||
|  |  | ||||||
| 	typedef Dynamic::Struct<std::string> Document; |  | ||||||
| 	typedef SharedPtr<Document> DocumentPtr; |  | ||||||
| 	typedef std::vector<DocumentPtr> Documents; |  | ||||||
| /* |  | ||||||
| class ElementFindByName | class ElementFindByName | ||||||
| { | { | ||||||
| public: | public: | ||||||
| @@ -184,6 +185,12 @@ template<> | |||||||
| struct ElementTraits<Document::Ptr> | struct ElementTraits<Document::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x03 }; | 	enum { TypeId = 0x03 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Document::Ptr& value) | ||||||
|  | 	{ | ||||||
|  | 		//TODO | ||||||
|  | 		return value.isNull() ? "null" : "{}"; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| @@ -197,7 +204,7 @@ inline void BSONWriter::write<Document::Ptr>(Document::Ptr& from) | |||||||
| { | { | ||||||
| 	from->write(_writer); | 	from->write(_writer); | ||||||
| } | } | ||||||
| */ |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
| #endif //  _MongoDB_Document_included | #endif //  _MongoDB_Document_included | ||||||
|   | |||||||
| @@ -47,7 +47,8 @@ | |||||||
| #include "Poco/Timestamp.h" | #include "Poco/Timestamp.h" | ||||||
| #include "Poco/RegularExpression.h" | #include "Poco/RegularExpression.h" | ||||||
| #include "Poco/Nullable.h" | #include "Poco/Nullable.h" | ||||||
|  | #include "Poco/NumberFormatter.h" | ||||||
|  | #include "Poco/DateTimeFormatter.h" | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/MongoDB/BSONReader.h" | #include "Poco/MongoDB/BSONReader.h" | ||||||
| #include "Poco/MongoDB/BSONWriter.h" | #include "Poco/MongoDB/BSONWriter.h" | ||||||
| @@ -68,6 +69,9 @@ public: | |||||||
| 	virtual ~Element(); | 	virtual ~Element(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	virtual std::string toString() const = 0; | ||||||
|  |  | ||||||
|  |  | ||||||
| 	virtual int type() const = 0; | 	virtual int type() const = 0; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -77,11 +81,11 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|  |  | ||||||
| //	virtual void read(BinaryReader& reader) = 0; | 	virtual void read(BinaryReader& reader) = 0; | ||||||
|  |  | ||||||
| //	virtual void write(BinaryWriter& writer) = 0; | 	virtual void write(BinaryWriter& writer) = 0; | ||||||
|  |  | ||||||
| //	friend class Document; | 	friend class Document; | ||||||
|  |  | ||||||
| 	std::string _name; | 	std::string _name; | ||||||
| }; | }; | ||||||
| @@ -116,6 +120,11 @@ template<> | |||||||
| struct ElementTraits<double> | struct ElementTraits<double> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x01 }; | 	enum { TypeId = 0x01 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const double& value) | ||||||
|  | 	{ | ||||||
|  | 		return Poco::NumberFormatter::format(value); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // BSON UTF-8 string | // BSON UTF-8 string | ||||||
| @@ -125,8 +134,13 @@ template<> | |||||||
| struct ElementTraits<std::string> | struct ElementTraits<std::string> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x02 }; | 	enum { TypeId = 0x02 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const std::string& value) | ||||||
|  | 	{ | ||||||
|  | 		return value; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<std::string>(std::string& to) | inline void BSONReader::read<std::string>(std::string& to) | ||||||
| { | { | ||||||
| @@ -142,7 +156,7 @@ inline void BSONWriter::write<std::string>(std::string& from) | |||||||
| 	_writer << (Poco::Int32) (from.length() + 1); | 	_writer << (Poco::Int32) (from.length() + 1); | ||||||
| 	writeCString(from); | 	writeCString(from); | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| // BSON bool | // BSON bool | ||||||
| @@ -151,8 +165,13 @@ template<> | |||||||
| struct ElementTraits<bool> | struct ElementTraits<bool> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x08 }; | 	enum { TypeId = 0x08 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const bool& value) | ||||||
|  | 	{ | ||||||
|  | 		return value ? "true" : "false"; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<bool>(bool& to) | inline void BSONReader::read<bool>(bool& to) | ||||||
| { | { | ||||||
| @@ -166,13 +185,19 @@ inline void BSONWriter::write<bool>(bool& from) | |||||||
| { | { | ||||||
| 	_writer << (from ? 0x01 : 0x00); | 	_writer << (from ? 0x01 : 0x00); | ||||||
| } | } | ||||||
| */ |  | ||||||
| // BSON 32-bit integer | // BSON 32-bit integer | ||||||
| // spec: int32 | // spec: int32 | ||||||
| template<> | template<> | ||||||
| struct ElementTraits<Int32> | struct ElementTraits<Int32> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x10 }; | 	enum { TypeId = 0x10 }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Int32& value) | ||||||
|  | 	{ | ||||||
|  | 		return Poco::NumberFormatter::format(value); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // BSON UTC datetime | // BSON UTC datetime | ||||||
| @@ -181,8 +206,13 @@ template<> | |||||||
| struct ElementTraits<Timestamp> | struct ElementTraits<Timestamp> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x09 }; | 	enum { TypeId = 0x09 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Timestamp& value) | ||||||
|  | 	{ | ||||||
|  | 		return DateTimeFormatter::format(value, "%Y-%m-%dT%H:%M:%s%z"); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<Timestamp>(Timestamp& to) | inline void BSONReader::read<Timestamp>(Timestamp& to) | ||||||
| { | { | ||||||
| @@ -197,7 +227,7 @@ inline void BSONWriter::write<Timestamp>(Timestamp& from) | |||||||
| { | { | ||||||
| 	_writer << (from.epochMicroseconds() / 1000); | 	_writer << (from.epochMicroseconds() / 1000); | ||||||
| } | } | ||||||
| */ |  | ||||||
| typedef Nullable<unsigned char> NullValue; | typedef Nullable<unsigned char> NullValue; | ||||||
|  |  | ||||||
| // BSON Null Value | // BSON Null Value | ||||||
| @@ -206,8 +236,13 @@ template<> | |||||||
| struct ElementTraits<NullValue> | struct ElementTraits<NullValue> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x0A }; | 	enum { TypeId = 0x0A }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const NullValue& value) | ||||||
|  | 	{ | ||||||
|  | 		return "null"; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<NullValue>(NullValue& to) | inline void BSONReader::read<NullValue>(NullValue& to) | ||||||
| { | { | ||||||
| @@ -217,7 +252,7 @@ template<> | |||||||
| inline void BSONWriter::write<NullValue>(NullValue& from) | inline void BSONWriter::write<NullValue>(NullValue& from) | ||||||
| { | { | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
| class RegularExpression | class RegularExpression | ||||||
| { | { | ||||||
| @@ -318,8 +353,14 @@ template<> | |||||||
| struct ElementTraits<RegularExpression::Ptr> | struct ElementTraits<RegularExpression::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x0B }; | 	enum { TypeId = 0x0B }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const RegularExpression::Ptr& value) | ||||||
|  | 	{ | ||||||
|  | 		//TODO | ||||||
|  | 		return "RE: not implemented yet"; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<RegularExpression::Ptr>(RegularExpression::Ptr& to) | inline void BSONReader::read<RegularExpression::Ptr>(RegularExpression::Ptr& to) | ||||||
| { | { | ||||||
| @@ -335,7 +376,7 @@ inline void BSONWriter::write<RegularExpression::Ptr>(RegularExpression::Ptr& fr | |||||||
| 	writeCString(from->getPattern()); | 	writeCString(from->getPattern()); | ||||||
| 	writeCString(from->getOptions()); | 	writeCString(from->getOptions()); | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
| class JavaScriptCode | class JavaScriptCode | ||||||
| { | { | ||||||
| @@ -381,8 +422,13 @@ template<> | |||||||
| struct ElementTraits<JavaScriptCode::Ptr> | struct ElementTraits<JavaScriptCode::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x0D }; | 	enum { TypeId = 0x0D }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const JavaScriptCode::Ptr& value) | ||||||
|  | 	{ | ||||||
|  | 		return value.isNull() ? "" : value->code(); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| template<> | template<> | ||||||
| inline void BSONReader::read<JavaScriptCode::Ptr>(JavaScriptCode::Ptr& to) | inline void BSONReader::read<JavaScriptCode::Ptr>(JavaScriptCode::Ptr& to) | ||||||
| { | { | ||||||
| @@ -398,13 +444,18 @@ inline void BSONWriter::write<JavaScriptCode::Ptr>(JavaScriptCode::Ptr& from) | |||||||
| 	std::string code = from->code(); | 	std::string code = from->code(); | ||||||
| 	BSONWriter(_writer).write(code); | 	BSONWriter(_writer).write(code); | ||||||
| } | } | ||||||
| */ |  | ||||||
| // BSON 64-bit integer | // BSON 64-bit integer | ||||||
| // spec: int64 | // spec: int64 | ||||||
| template<> | template<> | ||||||
| struct ElementTraits<Int64> | struct ElementTraits<Int64> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x12 }; | 	enum { TypeId = 0x12 }; | ||||||
|  |  | ||||||
|  | 	static std::string toString(const Int64& value) | ||||||
|  | 	{ | ||||||
|  | 		return NumberFormatter::format(value); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -424,9 +475,12 @@ public: | |||||||
| 	T value() const { return _value; } | 	T value() const { return _value; } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	std::string toString() const { return ElementTraits<T>::toString(_value); } | ||||||
|  |  | ||||||
|  | 	 | ||||||
| 	int type() const { return ElementTraits<T>::TypeId; } | 	int type() const { return ElementTraits<T>::TypeId; } | ||||||
|  |  | ||||||
| /* |  | ||||||
| 	void read(BinaryReader& reader) | 	void read(BinaryReader& reader) | ||||||
| 	{ | 	{ | ||||||
| 		BSONReader(reader).read(_value); | 		BSONReader(reader).read(_value); | ||||||
| @@ -436,7 +490,7 @@ public: | |||||||
| 	{ | 	{ | ||||||
| 		BSONWriter(writer).write(_value); | 		BSONWriter(writer).write(_value); | ||||||
| 	} | 	} | ||||||
| */ |  | ||||||
| private: | private: | ||||||
|  |  | ||||||
| 	T _value; | 	T _value; | ||||||
| @@ -445,4 +499,3 @@ private: | |||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
| #endif //  _MongoDB_Element_included | #endif //  _MongoDB_Element_included | ||||||
|  |  | ||||||
|   | |||||||
| @@ -71,7 +71,7 @@ public: | |||||||
| 		/// Destructor | 		/// Destructor | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| 	Documents& documents(); | 	Document::Vector& documents(); | ||||||
| 		/// Returns the documents to insert into the database | 		/// Returns the documents to insert into the database | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
| @@ -85,11 +85,11 @@ private: | |||||||
|  |  | ||||||
| 	std::string _fullCollectionName; | 	std::string _fullCollectionName; | ||||||
|  |  | ||||||
| 	Documents _documents; | 	Document::Vector _documents; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| inline Documents& InsertRequest::documents() | inline Document::Vector& InsertRequest::documents() | ||||||
| { | { | ||||||
| 	return _documents; | 	return _documents; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -63,14 +63,23 @@ public: | |||||||
|  |  | ||||||
| private: | private: | ||||||
| 	unsigned char _id[12]; | 	unsigned char _id[12]; | ||||||
|  |  | ||||||
|  | 	friend class BSONWriter; | ||||||
|  | 	friend class BSONReader; | ||||||
| }; | }; | ||||||
| /* |  | ||||||
| // BSON Embedded Document | // BSON Embedded Document | ||||||
| // spec: ObjectId | // spec: ObjectId | ||||||
| template<> | template<> | ||||||
| struct ElementTraits<ObjectId::Ptr> | struct ElementTraits<ObjectId::Ptr> | ||||||
| { | { | ||||||
| 	enum { TypeId = 0x07 }; | 	enum { TypeId = 0x07 }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	static std::string toString(const ObjectId::Ptr& id) | ||||||
|  | 	{ | ||||||
|  | 		return id->toString(); | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| @@ -84,19 +93,9 @@ inline void BSONWriter::write<ObjectId::Ptr>(ObjectId::Ptr& from) | |||||||
| { | { | ||||||
| 	_writer.writeRaw((char*) from->_id, 12); | 	_writer.writeRaw((char*) from->_id, 12); | ||||||
| } | } | ||||||
| */ |  | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|  |  | ||||||
| namespace Poco { |  | ||||||
| namespace Dynamic { |  | ||||||
|  |  | ||||||
| template<> |  | ||||||
| class VarHolderImpl<MongoDB::ObjectId>: public VarHolder |  | ||||||
| { |  | ||||||
|  |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| }} // Poco::Dynamic |  | ||||||
|  |  | ||||||
| #endif //_MongoDB_ObjectId_included | #endif //_MongoDB_ObjectId_included | ||||||
|   | |||||||
| @@ -6,12 +6,10 @@ | |||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| namespace MongoDB |  | ||||||
| { |  | ||||||
|  |  | ||||||
|  |  | ||||||
| template<> | template<> | ||||||
| class PoolableObjectFactory<Connection, Connection::Ptr> | class PoolableObjectFactory<MongoDB::Connection, MongoDB::Connection::Ptr> | ||||||
| { | { | ||||||
| public: | public: | ||||||
| 	PoolableObjectFactory(Net::SocketAddress& address) | 	PoolableObjectFactory(Net::SocketAddress& address) | ||||||
| @@ -26,29 +24,29 @@ public: | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
| 	Connection::Ptr createObject() | 	MongoDB::Connection::Ptr createObject() | ||||||
| 	{ | 	{ | ||||||
| 		return new Connection(_address); | 		return new MongoDB::Connection(_address); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	 | 	 | ||||||
| 	bool validateObject(Connection::Ptr pObject) | 	bool validateObject(MongoDB::Connection::Ptr pObject) | ||||||
| 	{ | 	{ | ||||||
| 		return true; | 		return true; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
| 	void activateObject(Connection::Ptr pObject) | 	void activateObject(MongoDB::Connection::Ptr pObject) | ||||||
| 	{ | 	{ | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
| 	void deactivateObject(Connection::Ptr pObject) | 	void deactivateObject(MongoDB::Connection::Ptr pObject) | ||||||
| 	{ | 	{ | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
| 	void destroyObject(Connection::Ptr pObject) | 	void destroyObject(MongoDB::Connection::Ptr pObject) | ||||||
| 	{ | 	{ | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| @@ -58,7 +56,34 @@ private: | |||||||
| 	Net::SocketAddress _address; | 	Net::SocketAddress _address; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | namespace MongoDB | ||||||
|  | { | ||||||
| 	 | 	 | ||||||
| }} // Poco::MongoDB |  | ||||||
|  | class PooledConnection | ||||||
|  | { | ||||||
|  | public: | ||||||
|  | 	PooledConnection(Poco::ObjectPool<Connection, Connection::Ptr>& pool) : _pool(pool) | ||||||
|  | 	{ | ||||||
|  | 		_connection = _pool.borrowObject(); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	virtual ~PooledConnection() | ||||||
|  | 	{ | ||||||
|  | 		_pool.returnObject(_connection); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	operator Connection::Ptr () { return _connection; } | ||||||
|  |  | ||||||
|  | private: | ||||||
|  | 	Poco::ObjectPool<Connection, Connection::Ptr>& _pool; | ||||||
|  |  | ||||||
|  | 	Connection::Ptr _connection; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | } // MongoDB | ||||||
|  |  | ||||||
|  |  | ||||||
|  | } // Poco | ||||||
|  |  | ||||||
| #endif //_MongoDB_PoolableConnectionFactory_included | #endif //_MongoDB_PoolableConnectionFactory_included | ||||||
|   | |||||||
| @@ -40,8 +40,7 @@ | |||||||
|  |  | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/MongoDB/RequestMessage.h" | #include "Poco/MongoDB/RequestMessage.h" | ||||||
|  | #include "Poco/MongoDB/Document.h" | ||||||
| #include "Poco/Dynamic/Struct.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -86,11 +85,11 @@ public: | |||||||
| 	void flags(Flags flag); | 	void flags(Flags flag); | ||||||
| 		/// Set the flags | 		/// Set the flags | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string>& query(); | 	Document& query(); | ||||||
| 		/// Returns the query document | 		/// Returns the query document | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string>& returnFieldSelector(); | 	Document& returnFieldSelector(); | ||||||
| 		/// Returns the selector document | 		/// Returns the selector document | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| @@ -123,9 +122,9 @@ private: | |||||||
|  |  | ||||||
| 	Int32 _numberToReturn; | 	Int32 _numberToReturn; | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string> _query; | 	Document _query; | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string> _returnFieldSelector; | 	Document _returnFieldSelector; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| inline QueryRequest::Flags QueryRequest::flags() const | inline QueryRequest::Flags QueryRequest::flags() const | ||||||
| @@ -138,12 +137,12 @@ inline void QueryRequest::flags(QueryRequest::Flags flags) | |||||||
| 	_flags = flags; | 	_flags = flags; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Dynamic::Struct<std::string>& QueryRequest::query() | inline Document& QueryRequest::query() | ||||||
| { | { | ||||||
| 	return _query; | 	return _query; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Dynamic::Struct<std::string>& QueryRequest::returnFieldSelector() | inline Document& QueryRequest::returnFieldSelector() | ||||||
| { | { | ||||||
| 	return _returnFieldSelector; | 	return _returnFieldSelector; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -66,7 +66,7 @@ public: | |||||||
| 		/// Reads the response from the stream | 		/// Reads the response from the stream | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| 	Documents& documents(); | 	Document::Vector& documents(); | ||||||
| 		/// Returns the retrieved documents | 		/// Returns the retrieved documents | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| @@ -90,11 +90,11 @@ private: | |||||||
| 	Int32 _numberReturned; | 	Int32 _numberReturned; | ||||||
|  |  | ||||||
|  |  | ||||||
| 	Documents _documents; | 	Document::Vector _documents; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| inline Documents& ResponseMessage::documents() | inline Document::Vector& ResponseMessage::documents() | ||||||
| { | { | ||||||
| 	return _documents; | 	return _documents; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -40,8 +40,7 @@ | |||||||
|  |  | ||||||
| #include "Poco/MongoDB/MongoDB.h" | #include "Poco/MongoDB/MongoDB.h" | ||||||
| #include "Poco/MongoDB/RequestMessage.h" | #include "Poco/MongoDB/RequestMessage.h" | ||||||
|  | #include "Poco/MongoDB/Document.h" | ||||||
| #include "Poco/Dynamic/Struct.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -78,11 +77,11 @@ public: | |||||||
| 		/// Destructor | 		/// Destructor | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string>& selector(); | 	Document& selector(); | ||||||
| 		/// Returns the selector document | 		/// Returns the selector document | ||||||
| 		 | 		 | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string>& update(); | 	Document& update(); | ||||||
| 		/// The document to update | 		/// The document to update | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -105,9 +104,9 @@ private: | |||||||
|  |  | ||||||
| 	std::string _fullCollectionName; | 	std::string _fullCollectionName; | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string> _selector; | 	Document _selector; | ||||||
|  |  | ||||||
| 	Dynamic::Struct<std::string> _update; | 	Document _update; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -121,12 +120,12 @@ inline void UpdateRequest::flags(UpdateRequest::Flags flags) | |||||||
| 	_flags = flags; | 	_flags = flags; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Dynamic::Struct<std::string>& UpdateRequest::selector() | inline Document& UpdateRequest::selector() | ||||||
| { | { | ||||||
| 	return _selector; | 	return _selector; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Dynamic::Struct<std::string>& UpdateRequest::update() | inline Document& UpdateRequest::update() | ||||||
| { | { | ||||||
| 	return _update; | 	return _update; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -37,10 +37,8 @@ | |||||||
|  |  | ||||||
| #include "Poco/MongoDB/Array.h" | #include "Poco/MongoDB/Array.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco { | ||||||
| { | namespace MongoDB { | ||||||
| namespace MongoDB |  | ||||||
| { |  | ||||||
|  |  | ||||||
| Array::Array() : Document() | Array::Array() : Document() | ||||||
| { | { | ||||||
|   | |||||||
| @@ -37,10 +37,8 @@ | |||||||
|  |  | ||||||
| #include "Poco/MongoDB/Binary.h" | #include "Poco/MongoDB/Binary.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco { | ||||||
| { | namespace MongoDB { | ||||||
| namespace MongoDB |  | ||||||
| { |  | ||||||
|  |  | ||||||
|  |  | ||||||
| Binary::Binary() : _buffer(0) | Binary::Binary() : _buffer(0) | ||||||
| @@ -52,14 +50,20 @@ Binary::Binary(Poco::Int32 size, unsigned char subtype) : _buffer(size), _subtyp | |||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| Binary::~Binary() | Binary::~Binary() | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| void Binary::resize(std::size_t newSize) |  | ||||||
|  | std::string Binary::toString() const | ||||||
| { | { | ||||||
| 	//TODO: | 	std::ostringstream oss; | ||||||
| 	//_buffer.resize(newSize); | 	Base64Encoder encoder(oss); | ||||||
|  | 	MemoryInputStream mis((const char*) _buffer.begin(), _buffer.size()); | ||||||
|  | 	StreamCopier::copyStream(mis, encoder); | ||||||
|  | 	return oss.str(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|   | |||||||
							
								
								
									
										68
									
								
								MongoDB/src/Database.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								MongoDB/src/Database.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | // | ||||||
|  | // Database.cpp | ||||||
|  | // | ||||||
|  | // $Id$ | ||||||
|  | // | ||||||
|  | // Library: MongoDB | ||||||
|  | // Package: MongoDB | ||||||
|  | // Module:  Database | ||||||
|  | // | ||||||
|  | // Implementation of the Database class. | ||||||
|  | // | ||||||
|  | // Copyright (c) 2012, Applied Informatics Software Engineering GmbH. | ||||||
|  | // and Contributors. | ||||||
|  | // | ||||||
|  | // Permission is hereby granted, free of charge, to any person or organization | ||||||
|  | // obtaining a copy of the software and accompanying documentation covered by | ||||||
|  | // this license (the "Software") to use, reproduce, display, distribute, | ||||||
|  | // execute, and transmit the Software, and to prepare derivative works of the | ||||||
|  | // Software, and to permit third-parties to whom the Software is furnished to | ||||||
|  | // do so, all subject to the following: | ||||||
|  | // | ||||||
|  | // The copyright notices in the Software and this entire statement, including | ||||||
|  | // the above license grant, this restriction and the following disclaimer, | ||||||
|  | // must be included in all copies of the Software, in whole or in part, and | ||||||
|  | // all derivative works of the Software, unless such copies or derivative | ||||||
|  | // works are solely in the form of machine-executable object code generated by | ||||||
|  | // a source language processor. | ||||||
|  | // | ||||||
|  | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT | ||||||
|  | // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE | ||||||
|  | // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, | ||||||
|  | // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||||
|  | // DEALINGS IN THE SOFTWARE. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include "Poco/MongoDB/Database.h" | ||||||
|  |  | ||||||
|  | namespace Poco | ||||||
|  | { | ||||||
|  | namespace MongoDB | ||||||
|  | { | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Database::Database( const std::string& db) : _dbname(db) | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | Database::~Database() | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | Poco::SharedPtr<Poco::MongoDB::QueryRequest> Database::createQueryRequest(const std::string& collectionName) | ||||||
|  | { | ||||||
|  | 	return new Poco::MongoDB::QueryRequest(_dbname + '.' + collectionName); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | Poco::SharedPtr<Poco::MongoDB::QueryRequest> Database::createCountRequest(const std::string& collectionName) | ||||||
|  | { | ||||||
|  | 	Poco::SharedPtr<Poco::MongoDB::QueryRequest> request = createQueryRequest("$cmd"); | ||||||
|  | 	request->numberToReturn(1); | ||||||
|  | 	request->query().add("count", collectionName); | ||||||
|  | 	return request; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | }} // Namespace Poco::MongoDB | ||||||
| @@ -36,7 +36,6 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/DeleteRequest.h" | #include "Poco/MongoDB/DeleteRequest.h" | ||||||
| #include "Poco/MongoDB/BSONWriter.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -58,11 +57,10 @@ DeleteRequest::~DeleteRequest() | |||||||
|  |  | ||||||
| void DeleteRequest::buildRequest(BinaryWriter& writer) | void DeleteRequest::buildRequest(BinaryWriter& writer) | ||||||
| { | { | ||||||
| 	BSONWriter bsonWriter(writer); |  | ||||||
| 	writer << 0; // 0 - reserved for future use | 	writer << 0; // 0 - reserved for future use | ||||||
| 	bsonWriter.writeCString(_fullCollectionName); | 	BSONWriter(writer).writeCString(_fullCollectionName); | ||||||
| 	writer << _flags; | 	writer << _flags; | ||||||
| 	bsonWriter.write(_selector); | 	_selector.write(writer); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -133,7 +133,7 @@ void Document::read(BinaryReader& reader) | |||||||
| std::string Document::toString() const | std::string Document::toString() const | ||||||
| { | { | ||||||
| 	std::ostringstream oss; | 	std::ostringstream oss; | ||||||
| 	for(ElementSet::iterator it = _elements.begin(); it != _elements.end(); ++it) | 	for(ElementSet::const_iterator it = _elements.begin(); it != _elements.end(); ++it) | ||||||
| 	{ | 	{ | ||||||
| 		oss << (*it)->name() << " "; | 		oss << (*it)->name() << " "; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ | |||||||
| // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | ||||||
| // DEALINGS IN THE SOFTWARE. | // DEALINGS IN THE SOFTWARE. | ||||||
| // | // | ||||||
| #include "Poco/MongoDB/BSONWriter.h" |  | ||||||
| #include "Poco/MongoDB/InsertRequest.h" | #include "Poco/MongoDB/InsertRequest.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| @@ -57,13 +57,13 @@ InsertRequest::~InsertRequest() | |||||||
| void InsertRequest::buildRequest(BinaryWriter& writer) | void InsertRequest::buildRequest(BinaryWriter& writer) | ||||||
| { | { | ||||||
| 	//TODO: throw exception when no document is added | 	//TODO: throw exception when no document is added | ||||||
| 	BSONWriter bsonWriter(writer); |  | ||||||
| 	writer << _flags; | 	writer << _flags; | ||||||
|  | 	BSONWriter bsonWriter(writer); | ||||||
| 	bsonWriter.writeCString(_fullCollectionName); | 	bsonWriter.writeCString(_fullCollectionName); | ||||||
| 	for(Documents::iterator it = _documents.begin(); it != _documents.end(); ++it) | 	for(Document::Vector::iterator it = _documents.begin(); it != _documents.end(); ++it) | ||||||
| 	{ | 	{ | ||||||
| 		BSONWriter bsonWriter(writer); | 		bsonWriter.write(*it); | ||||||
| 		bsonWriter.write(**it); |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -56,7 +56,13 @@ ObjectId::~ObjectId() | |||||||
|  |  | ||||||
| std::string ObjectId::toString() const | std::string ObjectId::toString() const | ||||||
| { | { | ||||||
| 	return format("%X:%X:%X", (unsigned int) _id[0], (unsigned int) _id[4], (unsigned int) _id[8]); | 	std::string s; | ||||||
|  |  | ||||||
|  | 	for(int i = 0; i < 12; ++i) | ||||||
|  | 	{ | ||||||
|  | 		s += format("%x", (unsigned int) _id[i]); | ||||||
|  | 	} | ||||||
|  | 	return s; | ||||||
| } | } | ||||||
|  |  | ||||||
| }} // Namespace Poco::MongoDB | }} // Namespace Poco::MongoDB | ||||||
|   | |||||||
| @@ -36,7 +36,6 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/QueryRequest.h" | #include "Poco/MongoDB/QueryRequest.h" | ||||||
| #include "Poco/MongoDB/BSONWriter.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -55,22 +54,22 @@ QueryRequest::QueryRequest(const std::string& collectionName, QueryRequest::Flag | |||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QueryRequest::~QueryRequest() | QueryRequest::~QueryRequest() | ||||||
| { | { | ||||||
| } | } | ||||||
|  |  | ||||||
| void QueryRequest::buildRequest(BinaryWriter& writer) | void QueryRequest::buildRequest(BinaryWriter& writer) | ||||||
| { | { | ||||||
| 	BSONWriter bsonWriter(writer); |  | ||||||
| 	writer << _flags; | 	writer << _flags; | ||||||
| 	bsonWriter.writeCString(_fullCollectionName); | 	BSONWriter(writer).writeCString(_fullCollectionName); | ||||||
| 	writer << _numberToSkip; | 	writer << _numberToSkip; | ||||||
| 	writer << _numberToReturn; | 	writer << _numberToReturn; | ||||||
| 	bsonWriter.write(_query); | 	_query.write(writer); | ||||||
|  |  | ||||||
| 	if ( ! _returnFieldSelector.empty() ) | 	if ( ! _returnFieldSelector.empty() ) | ||||||
| 	{ | 	{ | ||||||
| 		bsonWriter.write(_returnFieldSelector); | 		_returnFieldSelector.write(writer); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -78,24 +78,21 @@ Connection::Ptr ReplicaSet::isMaster(const Net::SocketAddress& address) | |||||||
|  |  | ||||||
| 		QueryRequest request("admin.$cmd"); | 		QueryRequest request("admin.$cmd"); | ||||||
| 		request.numberToReturn(1); | 		request.numberToReturn(1); | ||||||
| 		request.query().insert("isMaster", 1); | 		request.query().add("isMaster", 1); | ||||||
|  |  | ||||||
| 		ResponseMessage response; | 		ResponseMessage response; | ||||||
| 		conn->sendRequest(request, response); | 		conn->sendRequest(request, response); | ||||||
|  |  | ||||||
| 		if ( response.documents().size() > 0 ) | 		if ( response.documents().size() > 0 ) | ||||||
| 		{ | 		{ | ||||||
| 			DocumentPtr doc = response.documents()[0]; | 			Document::Ptr doc = response.documents()[0]; | ||||||
| 			Dynamic::Var isMasterVar = (*doc)["ismaster"]; | 			if ( doc->get<bool>("ismaster") ) | ||||||
| 			if ( !isMasterVar.isEmpty() && isMasterVar ) |  | ||||||
| 			{ | 			{ | ||||||
| 				return conn; | 				return conn; | ||||||
| 			} | 			} | ||||||
| 			else if ( doc->contains("primary") ) | 			else if ( doc->exists("primary") ) | ||||||
| 			{ | 			{ | ||||||
| 				Dynamic::Var& primary = (*doc)["primary"]; | 				return isMaster(Net::SocketAddress(doc->get<std::string>("primary"))); | ||||||
| 				Net::SocketAddress primaryAddress(primary.convert<std::string>()); |  | ||||||
| 				return isMaster(primaryAddress); |  | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -36,7 +36,6 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/ResponseMessage.h" | #include "Poco/MongoDB/ResponseMessage.h" | ||||||
| #include "Poco/MongoDB/BSONReader.h" |  | ||||||
| #include "Poco/Net/SocketStream.h" | #include "Poco/Net/SocketStream.h" | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| @@ -75,9 +74,8 @@ void ResponseMessage::read(std::istream& istr) | |||||||
|  |  | ||||||
| 	for(int i = 0; i < _numberReturned; ++i) | 	for(int i = 0; i < _numberReturned; ++i) | ||||||
| 	{ | 	{ | ||||||
| 		DocumentPtr doc = new Document(); | 		Document::Ptr doc = new Document(); | ||||||
| 		BSONReader bsonReader(reader); | 		doc->read(reader); | ||||||
| 		bsonReader.read(*doc); |  | ||||||
| 		_documents.push_back(doc); | 		_documents.push_back(doc); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -36,7 +36,6 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/UpdateRequest.h" | #include "Poco/MongoDB/UpdateRequest.h" | ||||||
| #include "Poco/MongoDB/BSONWriter.h" |  | ||||||
|  |  | ||||||
| namespace Poco | namespace Poco | ||||||
| { | { | ||||||
| @@ -59,12 +58,11 @@ UpdateRequest::~UpdateRequest() | |||||||
|  |  | ||||||
| void UpdateRequest::buildRequest(BinaryWriter& writer) | void UpdateRequest::buildRequest(BinaryWriter& writer) | ||||||
| { | { | ||||||
| 	BSONWriter bsonWriter(writer); |  | ||||||
| 	writer << 0; // 0 - reserved for future use | 	writer << 0; // 0 - reserved for future use | ||||||
| 	bsonWriter.writeCString(_fullCollectionName); | 	BSONWriter(writer).writeCString(_fullCollectionName); | ||||||
| 	writer << _flags; | 	writer << _flags; | ||||||
| 	bsonWriter.write(_selector); | 	_selector.write(writer); | ||||||
| 	bsonWriter.write(_update); | 	_update.write(writer); | ||||||
| } | } | ||||||
|  |  | ||||||
| }} // Namespace MongoDB | }} // Namespace MongoDB | ||||||
|   | |||||||
| @@ -31,10 +31,13 @@ | |||||||
| #include <iostream> | #include <iostream> | ||||||
|  |  | ||||||
| #include "Poco/DateTime.h" | #include "Poco/DateTime.h" | ||||||
|  | #include "Poco/ObjectPool.h" | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/InsertRequest.h" | #include "Poco/MongoDB/InsertRequest.h" | ||||||
| #include "Poco/MongoDB/QueryRequest.h" | #include "Poco/MongoDB/QueryRequest.h" | ||||||
| #include "Poco/MongoDB/DeleteRequest.h" | #include "Poco/MongoDB/DeleteRequest.h" | ||||||
|  | #include "Poco/MongoDB/PoolableConnectionFactory.h" | ||||||
|  | #include "Poco/MongoDB/Database.h" | ||||||
|  |  | ||||||
| #include "Poco/Net/NetException.h" | #include "Poco/Net/NetException.h" | ||||||
|  |  | ||||||
| @@ -141,6 +144,9 @@ void MongoDBTest::testQueryRequest() | |||||||
| 			assert(birthDate.year() == 1969 && birthDate.month() == 3 && birthDate.day() == 9); | 			assert(birthDate.year() == 1969 && birthDate.month() == 3 && birthDate.day() == 9); | ||||||
| 			Poco::Timestamp lastupdatedTimestamp = doc->get<Poco::Timestamp>("lastupdated"); | 			Poco::Timestamp lastupdatedTimestamp = doc->get<Poco::Timestamp>("lastupdated"); | ||||||
| 			assert(doc->isType<NullValue>("unknown")); | 			assert(doc->isType<NullValue>("unknown")); | ||||||
|  |  | ||||||
|  | 			std::string id = doc->get("_id")->toString(); | ||||||
|  | 			std::cout << id << std::endl; | ||||||
| 		} | 		} | ||||||
| 		catch(Poco::NotFoundException& nfe) | 		catch(Poco::NotFoundException& nfe) | ||||||
| 		{ | 		{ | ||||||
| @@ -153,6 +159,52 @@ void MongoDBTest::testQueryRequest() | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void MongoDBTest::testDBQueryRequest() | ||||||
|  | { | ||||||
|  | 	if ( ! _connected ) | ||||||
|  | 	{ | ||||||
|  | 		std::cout << "test skipped." << std::endl; | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	Database db("team"); | ||||||
|  | 	Poco::SharedPtr<Poco::MongoDB::QueryRequest> request = db.createQueryRequest("players"); | ||||||
|  | 	request->query().add("lastname" , std::string("Braem")); | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::ResponseMessage response; | ||||||
|  | 	_mongo.sendRequest(*request, response); | ||||||
|  |  | ||||||
|  | 	if ( response.documents().size() > 0 ) | ||||||
|  | 	{ | ||||||
|  | 		Poco::MongoDB::Document::Ptr doc = response.documents()[0]; | ||||||
|  |  | ||||||
|  | 		try | ||||||
|  | 		{ | ||||||
|  | 			std::string lastname = doc->get<std::string>("lastname"); | ||||||
|  | 			assert(lastname.compare("Braem") == 0); | ||||||
|  | 			std::string firstname = doc->get<std::string>("firstname"); | ||||||
|  | 			assert(firstname.compare("Franky") == 0); | ||||||
|  | 			Poco::Timestamp birthDateTimestamp = doc->get<Poco::Timestamp>("birthdate"); | ||||||
|  | 			Poco::DateTime birthDate(birthDateTimestamp); | ||||||
|  | 			assert(birthDate.year() == 1969 && birthDate.month() == 3 && birthDate.day() == 9); | ||||||
|  | 			Poco::Timestamp lastupdatedTimestamp = doc->get<Poco::Timestamp>("lastupdated"); | ||||||
|  | 			assert(doc->isType<NullValue>("unknown")); | ||||||
|  |  | ||||||
|  | 			std::string id = doc->get("_id")->toString(); | ||||||
|  | 			std::cout << id << std::endl; | ||||||
|  | 		} | ||||||
|  | 		catch(Poco::NotFoundException& nfe) | ||||||
|  | 		{ | ||||||
|  | 			fail(nfe.message() + " not found."); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		fail("No document returned"); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void MongoDBTest::testCountCommand() | void MongoDBTest::testCountCommand() | ||||||
| { | { | ||||||
| 	if ( ! _connected ) | 	if ( ! _connected ) | ||||||
| @@ -181,6 +233,34 @@ void MongoDBTest::testCountCommand() | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void MongoDBTest::testDBCountCommand() | ||||||
|  | { | ||||||
|  | 	if ( ! _connected ) | ||||||
|  | 	{ | ||||||
|  | 		std::cout << "test skipped." << std::endl; | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::Database db("team"); | ||||||
|  | 	Poco::SharedPtr<Poco::MongoDB::QueryRequest> request = db.createCountRequest("players"); | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::ResponseMessage response; | ||||||
|  | 	_mongo.sendRequest(*request, response); | ||||||
|  |  | ||||||
|  | 	if ( response.documents().size() > 0 ) | ||||||
|  | 	{ | ||||||
|  | 		Poco::MongoDB::Document::Ptr doc = response.documents()[0]; | ||||||
|  | 		double count = doc->get<double>("n"); | ||||||
|  | 		assert(count == 1); | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		fail("Didn't get a response from the count command"); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void MongoDBTest::testDeleteRequest() | void MongoDBTest::testDeleteRequest() | ||||||
| { | { | ||||||
| 	if ( ! _connected ) | 	if ( ! _connected ) | ||||||
| @@ -195,13 +275,55 @@ void MongoDBTest::testDeleteRequest() | |||||||
| 	_mongo.sendRequest(request); | 	_mongo.sendRequest(request); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void MongoDBTest::testConnectionPool() | ||||||
|  | { | ||||||
|  | 	Poco::PoolableObjectFactory<Poco::MongoDB::Connection, Poco::MongoDB::Connection::Ptr> factory("localhost:27017"); | ||||||
|  | 	Poco::ObjectPool<Poco::MongoDB::Connection, Poco::MongoDB::Connection::Ptr> pool(factory, 10, 15); | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::PooledConnection pooledConnection(pool); | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::QueryRequest request("team.$cmd"); | ||||||
|  | 	request.numberToReturn(1); | ||||||
|  | 	request.query().add("count", std::string("players")); | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::ResponseMessage response; | ||||||
|  | 	((Connection::Ptr) pooledConnection)->sendRequest(request, response); | ||||||
|  |  | ||||||
|  | 	if ( response.documents().size() > 0 ) | ||||||
|  | 	{ | ||||||
|  | 		Poco::MongoDB::Document::Ptr doc = response.documents()[0]; | ||||||
|  | 		double count = doc->get<double>("n"); | ||||||
|  | 		assert(count == 1); | ||||||
|  | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		fail("Didn't get a response from the count command"); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	Poco::MongoDB::Connection::Ptr pooledConnection1 = pool.borrowObject(); | ||||||
|  | 	assert(!pooledConnection1.isNull()); | ||||||
|  | 	pool.returnObject(pooledConnection1); | ||||||
|  |  | ||||||
|  | 	std::cout << "Available: " << pool.available() << std::endl; | ||||||
|  |  | ||||||
|  | 	Poco::MongoDB::Connection::Ptr pooledConnection2 = pool.borrowObject(); | ||||||
|  | 	assert(!pooledConnection2.isNull()); | ||||||
|  |  | ||||||
|  | 	pool.returnObject(pooledConnection2);*/ | ||||||
|  | } | ||||||
|  |  | ||||||
| CppUnit::Test* MongoDBTest::suite() | CppUnit::Test* MongoDBTest::suite() | ||||||
| { | { | ||||||
| 	CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("MongoDBTest"); | 	CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("MongoDBTest"); | ||||||
|  |  | ||||||
| 	CppUnit_addTest(pSuite, MongoDBTest, testInsertRequest); | 	CppUnit_addTest(pSuite, MongoDBTest, testInsertRequest); | ||||||
| 	CppUnit_addTest(pSuite, MongoDBTest, testQueryRequest); | 	CppUnit_addTest(pSuite, MongoDBTest, testQueryRequest); | ||||||
|  | 	CppUnit_addTest(pSuite, MongoDBTest, testDBQueryRequest); | ||||||
| 	CppUnit_addTest(pSuite, MongoDBTest, testCountCommand); | 	CppUnit_addTest(pSuite, MongoDBTest, testCountCommand); | ||||||
|  | 	CppUnit_addTest(pSuite, MongoDBTest, testDBCountCommand); | ||||||
|  | 	CppUnit_addTest(pSuite, MongoDBTest, testConnectionPool); | ||||||
| 	CppUnit_addTest(pSuite, MongoDBTest, testDeleteRequest); | 	CppUnit_addTest(pSuite, MongoDBTest, testDeleteRequest); | ||||||
|  |  | ||||||
| 	return pSuite; | 	return pSuite; | ||||||
|   | |||||||
| @@ -57,12 +57,21 @@ public: | |||||||
| 	void testQueryRequest(); | 	void testQueryRequest(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	void testDBQueryRequest(); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	void testCountCommand(); | 	void testCountCommand(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	void testDBCountCommand(); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	void testDeleteRequest(); | 	void testDeleteRequest(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 	void testConnectionPool(); | ||||||
|  |  | ||||||
|  |  | ||||||
| 	void setUp(); | 	void setUp(); | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,36 +0,0 @@ | |||||||
| #include <stdio.h> |  | ||||||
| #include <stdlib.h> |  | ||||||
|  |  | ||||||
| #include <iostream> |  | ||||||
|  |  | ||||||
| #include "Poco/MongoDB/Document.h" |  | ||||||
| #include "Poco/MongoDB/QueryRequest.h" |  | ||||||
| #include "Poco/MongoDB/Connection.h" |  | ||||||
|  |  | ||||||
| int main(void) |  | ||||||
| { |  | ||||||
| 	Poco::MongoDB::Document doc; |  | ||||||
| 	doc.add("test", 10); |  | ||||||
|  |  | ||||||
| 	Poco::MongoDB::Connection mongo("localhost", 27017); |  | ||||||
|  |  | ||||||
| 	Poco::MongoDB::ResponseMessage response; |  | ||||||
|  |  | ||||||
| 	// Count |  | ||||||
|  |  | ||||||
| 	Poco::MongoDB::QueryRequest request("test.$cmd"); |  | ||||||
| 	request.numberToReturn(1); |  | ||||||
| 	request.query().add("count", std::string("players")); |  | ||||||
|  |  | ||||||
| 	mongo.sendRequest(request, response); |  | ||||||
|  |  | ||||||
| 	if ( response.documents().size() > 0 ) |  | ||||||
| 	{ |  | ||||||
| 		Poco::MongoDB::Document::Ptr doc = response.documents()[0]; |  | ||||||
| 		std::cout << "n= " << doc->get<double>("n") << std::endl; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	std::cout << "Number of documents returned: " << response.documents().size() << std::endl; |  | ||||||
|  |  | ||||||
| 	return 0; |  | ||||||
| } |  | ||||||
		Reference in New Issue
	
	Block a user
	 fbraem
					fbraem