vn-verdnaturachat/ios/Pods/MMKVCore/Core/MiniPBCoder.h

130 lines
3.9 KiB
C
Raw Normal View History

[NEW] Encrypt user credentials and preferences (#2247) * install react-native-mmkv-storage * wip ios migration * change all js rn-user-defaults -> react-native-mmkv-storage * remove all rn-user-defaults native references (iOS) * android migration from rn-user-defaults to react-native-mmkv-storage * ios app group accessible mmkv * handle get errors * remove access of credentials from legacy native apps * remove data of user defaults * remove no longer necessary import * js mmkv encryption * run migration only once * reply from notification android * fix app group key access at native level ios * encrypt user credentials using a specific key * ios encrypt with random key * use a random key at the first encryption * encrypt migrated data on js land * remove unused function * reply notifications ios should be working * use fix instanceID * android ejson retrieve encrypted data * remove encryption migrated data for a while * encryption working between app and share extension * fix patch react-native-notifications * ssl pinning working using mmkv encrypted data * improve react-native-notifications * run encrypt migration data only once * fix build * fix patches magic string * fix mmkv id * mmkv -> userPreferences * fix instance id on android migration * cast our oldest sharedPreferences string into an object * revert log remove * create currentServer Rocket.Chat key * wrap mmkv api class * change the get logic * move userPreferences to lib * move encrypt migrated data to userPreferences class * check if the new object is new before insert * invalidate ci yarn cache * fix sort migration from android shared preferences * fix splashscreen forever * invalidate yarn cache * invalidate yarn cache * fix patch * Minor change * fix android notifications looking for wrong mmkv instance * Fix some issues on iOS mmkv native access * Remove unnecessary code * Fix notification reply and ssl pinning * WIP NotificationService use MMKV credentials * Add KeychainGroup * Notification idOnly get credentials from mmkv * Some fixes * Invalidate yarn cache * Pods * Use MMKVAppExtension on NotificationService Co-authored-by: Diego Mello <diegolmello@gmail.com>
2020-08-19 17:14:22 +00:00
/*
* Tencent is pleased to support the open source community by making
* MMKV available.
*
* Copyright (C) 2018 THL A29 Limited, a Tencent company.
* All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License"); you may not use
* this file except in compliance with the License. You may obtain a copy of
* the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef MMKV_MINIPBCODER_H
#define MMKV_MINIPBCODER_H
#ifdef __cplusplus
#include "MMKVPredef.h"
#include "KeyValueHolder.h"
#include "MMBuffer.h"
#include "MMBuffer.h"
#include "MMKVLog.h"
#include "PBUtility.h"
#include <cstdint>
namespace mmkv {
class CodedInputData;
class CodedOutputData;
class AESCrypt;
class CodedInputDataCrypt;
struct PBEncodeItem;
class MiniPBCoder {
const MMBuffer *m_inputBuffer = nullptr;
CodedInputData *m_inputData = nullptr;
CodedInputDataCrypt *m_inputDataDecrpt = nullptr;
MMBuffer *m_outputBuffer = nullptr;
CodedOutputData *m_outputData = nullptr;
std::vector<PBEncodeItem> *m_encodeItems = nullptr;
MiniPBCoder();
explicit MiniPBCoder(const MMBuffer *inputBuffer, AESCrypt *crypter = nullptr);
~MiniPBCoder();
void writeRootObject();
size_t prepareObjectForEncode(const MMKVVector &vec);
size_t prepareObjectForEncode(const MMBuffer &buffer);
template <typename T>
MMBuffer getEncodeData(const T &obj) {
size_t index = prepareObjectForEncode(obj);
return writePreparedItems(index);
}
MMBuffer writePreparedItems(size_t index);
void decodeOneMap(MMKVMap &dic, size_t position, bool greedy);
#ifndef MMKV_DISABLE_CRYPT
void decodeOneMap(MMKVMapCrypt &dic, size_t position, bool greedy);
#endif
#ifndef MMKV_APPLE
size_t prepareObjectForEncode(const std::string &str);
size_t prepareObjectForEncode(const std::vector<std::string> &vector);
std::vector<std::string> decodeOneVector();
#else
// NSString, NSData, NSDate
size_t prepareObjectForEncode(__unsafe_unretained NSObject *obj);
#endif
public:
template <typename T>
static MMBuffer encodeDataWithObject(const T &obj) {
try {
MiniPBCoder pbcoder;
return pbcoder.getEncodeData(obj);
} catch (const std::exception &exception) {
MMKVError("%s", exception.what());
return MMBuffer();
}
}
// opt encoding a single MMBuffer
static MMBuffer encodeDataWithObject(const MMBuffer &obj);
// return empty result if there's any error
static void decodeMap(MMKVMap &dic, const MMBuffer &oData, size_t position = 0);
// decode as much data as possible before any error happens
static void greedyDecodeMap(MMKVMap &dic, const MMBuffer &oData, size_t position = 0);
#ifndef MMKV_DISABLE_CRYPT
// return empty result if there's any error
static void decodeMap(MMKVMapCrypt &dic, const MMBuffer &oData, AESCrypt *crypter, size_t position = 0);
// decode as much data as possible before any error happens
static void greedyDecodeMap(MMKVMapCrypt &dic, const MMBuffer &oData, AESCrypt *crypter, size_t position = 0);
#endif // MMKV_DISABLE_CRYPT
#ifndef MMKV_APPLE
static std::vector<std::string> decodeVector(const MMBuffer &oData);
#else
// NSString, NSData, NSDate
static NSObject *decodeObject(const MMBuffer &oData, Class cls);
static bool isCompatibleClass(Class cls);
#endif
// just forbid it for possibly misuse
explicit MiniPBCoder(const MiniPBCoder &other) = delete;
MiniPBCoder &operator=(const MiniPBCoder &other) = delete;
};
} // namespace mmkv
#endif
#endif //MMKV_MINIPBCODER_H