Electroneum
Loading...
Searching...
No Matches
crypted_storage.h
Go to the documentation of this file.
1// Copyright (c) 2006-2013, Andrey N. Sabelnikov, www.sabelnikov.net
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are met:
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above copyright
9// notice, this list of conditions and the following disclaimer in the
10// documentation and/or other materials provided with the distribution.
11// * Neither the name of the Andrey N. Sabelnikov nor the
12// names of its contributors may be used to endorse or promote products
13// derived from this software without specific prior written permission.
14//
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER BE LIABLE FOR ANY
19// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25//
26
27
28#ifndef _CRYPTED_STORAGE_H_
29#define _CRYPTED_STORAGE_H_
30
31#include "cryptopp_helper.h"
32
33namespace epee
34{
35template<class t_base_storage, class crypt_provider, class t_key_provider>
36class crypted_storage: public t_base_storage
37{
38public:
39 size_t PackToSolidBuffer(std::string& targetObj)
40 {
41 size_t res = t_base_storage::PackToSolidBuffer(targetObj);
42 if(res <= 0)
43 return res;
44
45 if(!crypt_provider::encrypt(targetObj, t_key_provider::get_storage_default_key()))
46 return 0;
47
48 return targetObj.size();
49 }
50
51 size_t LoadFromSolidBuffer(const std::string& pTargetObj)
52 {
53 std::string buff_to_decrypt = pTargetObj;
54 if(crypt_provider::decrypt(buff_to_decrypt, t_key_provider::get_storage_default_key()))
55 return t_base_storage::LoadFromSolidBuffer(buff_to_decrypt);
56
57 return 0;
58 }
59};
60}
61
62#endif //_CRYPTED_STORAGE_H_
size_t PackToSolidBuffer(std::string &targetObj)
size_t LoadFromSolidBuffer(const std::string &pTargetObj)
const char * res