diff --git a/native/cpp/CommonCpp/CryptoTools/Tools.cpp b/native/cpp/CommonCpp/CryptoTools/Tools.cpp index 5ac37db5c9..7bb8ebc096 100644 --- a/native/cpp/CommonCpp/CryptoTools/Tools.cpp +++ b/native/cpp/CommonCpp/CryptoTools/Tools.cpp @@ -29,5 +29,11 @@ std::string Tools::generateRandomHexString(size_t size) { return Tools::generateRandomString(size, hexSigns); } +std::string Tools::generateRandomURLSafeString(size_t size) { + static std::string urlSafeSigns = + "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_"; + return Tools::generateRandomString(size, urlSafeSigns); +} + } // namespace crypto } // namespace comm diff --git a/native/cpp/CommonCpp/CryptoTools/Tools.h b/native/cpp/CommonCpp/CryptoTools/Tools.h index cd26db852b..f332383343 100644 --- a/native/cpp/CommonCpp/CryptoTools/Tools.h +++ b/native/cpp/CommonCpp/CryptoTools/Tools.h @@ -36,6 +36,7 @@ class Tools { public: static std::string generateRandomString(size_t size); static std::string generateRandomHexString(size_t size); + static std::string generateRandomURLSafeString(size_t size); }; } // namespace crypto diff --git a/native/cpp/CommonCpp/NativeModules/CommCoreModule.cpp b/native/cpp/CommonCpp/NativeModules/CommCoreModule.cpp index e611381394..92f159eadf 100644 --- a/native/cpp/CommonCpp/NativeModules/CommCoreModule.cpp +++ b/native/cpp/CommonCpp/NativeModules/CommCoreModule.cpp @@ -2502,7 +2502,7 @@ jsi::Value CommCoreModule::createNewBackupInternal( std::string backupID; try { - backupID = crypto::Tools::generateRandomString(32); + backupID = crypto::Tools::generateRandomURLSafeString(32); } catch (const std::exception &e) { error = "Failed to generate backupID"; }