diff --git a/native/backup/use-client-backup.js b/native/backup/use-client-backup.js index 1145f66bde..d7cbe6cb0f 100644 --- a/native/backup/use-client-backup.js +++ b/native/backup/use-client-backup.js @@ -14,8 +14,8 @@ import { commCoreModule } from '../native-modules.js'; import { useSelector } from '../redux/redux-utils.js'; type ClientBackup = { - +createFullBackup: () => Promise, - +createUserKeysBackup: () => Promise, + +createFullBackup: () => Promise, + +createUserKeysBackup: () => Promise, +retrieveLatestBackupInfo: () => Promise, }; @@ -33,7 +33,7 @@ function useClientBackup(): ClientBackup { } const backupSecret = await getBackupSecret(); - await commCoreModule.createFullBackup(backupSecret); + return commCoreModule.createFullBackup(backupSecret); }, [loggedIn, currentUserID, getBackupSecret]); const createUserKeysBackup = React.useCallback(async () => { @@ -42,7 +42,7 @@ function useClientBackup(): ClientBackup { } const backupSecret = await getBackupSecret(); - await commCoreModule.createUserKeysBackup(backupSecret); + return commCoreModule.createUserKeysBackup(backupSecret); }, [loggedIn, currentUserID, getBackupSecret]); const retrieveLatestBackupInfo = React.useCallback(async () => { diff --git a/native/native_rust_library/src/backup/compaction_upload_promises.rs b/native/native_rust_library/src/backup/compaction_upload_promises.rs index 6f84d4855b..930103bda7 100644 --- a/native/native_rust_library/src/backup/compaction_upload_promises.rs +++ b/native/native_rust_library/src/backup/compaction_upload_promises.rs @@ -1,4 +1,4 @@ -use crate::handle_void_result_as_callback; +use crate::handle_string_result_as_callback; use lazy_static::lazy_static; use std::{collections::HashMap, sync::Mutex}; @@ -20,5 +20,9 @@ pub fn resolve(backup_id: &str, result: Result<(), String>) { let Some(promise_id) = backups_to_promises.remove(backup_id) else { return; }; - handle_void_result_as_callback(result, promise_id); + + let backup_id_result: Result = + result.map(|_| backup_id.to_string()); + + handle_string_result_as_callback(backup_id_result, promise_id); } diff --git a/native/profile/backup-menu.react.js b/native/profile/backup-menu.react.js index 3a5903b28b..86646b7204 100644 --- a/native/profile/backup-menu.react.js +++ b/native/profile/backup-menu.react.js @@ -43,9 +43,10 @@ function BackupMenu(props: Props): React.Node { useClientBackup(); const uploadBackup = React.useCallback(async () => { - let message = 'Success'; + let message; try { - await createFullBackup(); + const backupID = await createFullBackup(); + message = `Success!\n` + `Backup ID: ${backupID}`; } catch (e) { message = `Backup upload error: ${String(getMessageForException(e))}`; console.error(message); @@ -54,9 +55,10 @@ function BackupMenu(props: Props): React.Node { }, [createFullBackup]); const uploadUserKeys = React.useCallback(async () => { - let message = 'Success'; + let message; try { - await createUserKeysBackup(); + const backupID = await createUserKeysBackup(); + message = `Success!\n` + `Backup ID: ${backupID}`; } catch (e) { message = `User Keys upload error: ${String(getMessageForException(e))}`; console.error(message); diff --git a/native/schema/CommCoreModuleSchema.js b/native/schema/CommCoreModuleSchema.js index 5789a655c1..483d1341fd 100644 --- a/native/schema/CommCoreModuleSchema.js +++ b/native/schema/CommCoreModuleSchema.js @@ -156,8 +156,8 @@ interface Spec extends TurboModule { +clearCommServicesAccessToken: () => Promise; +startBackupHandler: () => void; +stopBackupHandler: () => void; - +createUserKeysBackup: (backupSecret: string) => Promise; - +createFullBackup: (backupSecret: string) => Promise; + +createUserKeysBackup: (backupSecret: string) => Promise; + +createFullBackup: (backupSecret: string) => Promise; +restoreBackup: ( backupSecret: string, maxVersion: string,