diff options
Diffstat (limited to 'Swiften/Disco/CapsFileStorage.cpp')
| -rw-r--r-- | Swiften/Disco/CapsFileStorage.cpp | 40 | 
1 files changed, 6 insertions, 34 deletions
diff --git a/Swiften/Disco/CapsFileStorage.cpp b/Swiften/Disco/CapsFileStorage.cpp index 17fe37b..81e9551 100644 --- a/Swiften/Disco/CapsFileStorage.cpp +++ b/Swiften/Disco/CapsFileStorage.cpp @@ -6,57 +6,29 @@  #include "Swiften/Disco/CapsFileStorage.h" -#include <iostream> -#include <boost/filesystem/fstream.hpp> -#include <boost/filesystem.hpp> - -#include "Swiften/Base/ByteArray.h" +#include <Swiften/Entity/GenericPayloadPersister.h>  #include "Swiften/Serializer/PayloadSerializers/DiscoInfoSerializer.h" -#include "Swiften/Parser/PayloadParsers/UnitTest/PayloadParserTester.h"  #include "Swiften/Parser/PayloadParsers/DiscoInfoParser.h"  #include "Swiften/StringCodecs/Hexify.h"  #include "Swiften/StringCodecs/Base64.h" -namespace Swift { +using namespace Swift; + +typedef GenericPayloadPersister<DiscoInfo, DiscoInfoParser, DiscoInfoSerializer> DiscoInfoPersister;  CapsFileStorage::CapsFileStorage(const boost::filesystem::path& path) : path(path) {  }  DiscoInfo::ref CapsFileStorage::getDiscoInfo(const std::string& hash) const { -	boost::filesystem::path capsPath(getCapsPath(hash)); -	if (boost::filesystem::exists(capsPath)) { -		ByteArray data; -		data.readFromFile(capsPath.string()); - -		DiscoInfoParser parser; -		PayloadParserTester tester(&parser); -		tester.parse(data.toString()); -		return boost::dynamic_pointer_cast<DiscoInfo>(parser.getPayload()); -	} -	else { -		return DiscoInfo::ref(); -	} +	return DiscoInfoPersister().loadPayloadGeneric(getCapsPath(hash));  }  void CapsFileStorage::setDiscoInfo(const std::string& hash, DiscoInfo::ref discoInfo) { -	boost::filesystem::path capsPath(getCapsPath(hash)); -	if (!boost::filesystem::exists(capsPath.parent_path())) { -		try { -			boost::filesystem::create_directories(capsPath.parent_path()); -		} -		catch (const boost::filesystem::filesystem_error& e) { -			std::cerr << "ERROR: " << e.what() << std::endl; -		} -	}  	DiscoInfo::ref bareDiscoInfo(new DiscoInfo(*discoInfo.get()));  	bareDiscoInfo->setNode(""); -	boost::filesystem::ofstream file(capsPath); -	file << DiscoInfoSerializer().serializePayload(bareDiscoInfo); -	file.close(); +	DiscoInfoPersister().savePayload(bareDiscoInfo, getCapsPath(hash));  }  boost::filesystem::path CapsFileStorage::getCapsPath(const std::string& hash) const {  	return path / (Hexify::hexify(Base64::decode(hash)) + ".xml");  } - -}  | 
 Swift