#ifndef __SERIALIZER__ #define __SERIALIZER__ #include #include #include "key.h" #include "uint256.h" class Serializer { public: typedef boost::shared_ptr pointer; protected: std::vector mData; public: Serializer(int n=256) { mData.reserve(n); } Serializer(const std::vector &data) : mData(data) { ; } // assemble functions int add32(uint32); // ledger indexes, account sequence int add64(uint64); // timestamps, amounts int add160(const uint160&); // account names, hankos int add256(const uint256&); // transaction and ledger hashes int addRaw(const std::vector &vector); // disassemble functions bool get32(uint32&, int offset) const; bool get64(uint64&, int offset) const; bool get160(uint160&, int offset) const; bool get256(uint256&, int offset) const; uint256 get256(int offset) const; bool getRaw(std::vector&, int offset, int length) const; std::vector getRaw(int offset, int length) const; // hash functions uint160 getRIPEMD160(int size=0) const; uint256 getSHA256(int size=0) const; uint256 getSHA512Half(int size=0) const; // totality functions int getLength() const { return mData.size(); } const std::vector& peekData() const { return mData; } std::vector getData() const { return mData; } // signature functions bool checkSignature(int pubkeyOffset, int signatureOffset) const; bool checkSignature(const std::vector &signature, CKey& rkey) const; bool makeSignature(std::vector &signature, CKey& rkey) const; bool addSignature(CKey& rkey); static void TestSerializer(void); }; #endif