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

88 lines
2.4 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) 2020 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 CodedInputDataCrypt_h
#define CodedInputDataCrypt_h
#ifdef __cplusplus
#include "MMKVPredef.h"
#include "KeyValueHolder.h"
#include "MMBuffer.h"
#include "aes/AESCrypt.h"
#include <cstdint>
#ifdef MMKV_DISABLE_CRYPT
namespace mmkv {
class CodedInputDataCrypt;
}
#else
namespace mmkv {
class CodedInputDataCrypt {
uint8_t *const m_ptr;
size_t m_size;
size_t m_position;
size_t m_decryptPosition; // position of text that has beed decrypted
AESCrypt &m_decrypter;
uint8_t *m_decryptBuffer; // internal decrypt buffer, grows by (n * AES_KEY_LEN) bytes
size_t m_decryptBufferSize;
size_t m_decryptBufferPosition; // reader position in the buffer, synced with m_position
size_t m_decryptBufferDecryptLength; // length of the buffer that has been used
size_t m_decryptBufferDiscardPosition; // recycle position, any data before that can be discarded
void consumeBytes(size_t length, bool discardPreData = false);
void skipBytes(size_t length);
void statusBeforeDecrypt(size_t rollbackSize, AESCryptStatus &status);
int8_t readRawByte();
int32_t readRawVarint32(bool discardPreData = false);
public:
CodedInputDataCrypt(const void *oData, size_t length, AESCrypt &crypt);
~CodedInputDataCrypt();
bool isAtEnd() { return m_position == m_size; };
void seek(size_t addedSize);
int32_t readInt32();
void readData(KeyValueHolderCrypt &kvHolder);
#ifndef MMKV_APPLE
std::string readString(KeyValueHolderCrypt &kvHolder);
#else
NSString *readString(KeyValueHolderCrypt &kvHolder);
#endif
};
} // namespace mmkv
#endif // MMKV_DISABLE_CRYPT
#endif // __cplusplus
#endif /* CodedInputDataCrypt_h */