From 22f3e049d7949e7943ed94ae548269aee10277cf Mon Sep 17 00:00:00 2001
From: DarkSky <25152247+darkskygit@users.noreply.github.com>
Date: Fri, 20 Oct 2023 08:29:18 -0500
Subject: [PATCH] fix: workspace export logic (#552)
---
.../java/com/example/jwst_demo/MainActivity.kt | 9 +++++++--
.../RustXcframework.xcframework/Info.plist | 8 ++++----
.../ios-arm64-simulator/Headers/jwst-swift.h | 4 ++--
.../ios-arm64/Headers/jwst-swift.h | 4 ++--
.../macos-arm64/Headers/jwst-swift.h | 4 ++--
.../Sources/OctoBase/jwst-swift.swift | 8 ++++----
libs/jwst-binding/jwst-jni/android/build.gradle | 2 +-
.../src/main/java/com/toeverything/jwst/JWST.kt | 4 ++--
.../com/toeverything/jwst/lib/JwstStorage.java | 12 ++++++------
libs/jwst-binding/jwst-jni/build.rs | 4 ++--
libs/jwst-binding/jwst-jni/src/java_glue.rs.in | 4 ++--
libs/jwst-binding/jwst-jni/src/storage.rs | 13 ++++++-------
libs/jwst-binding/jwst-swift/src/lib.rs | 4 ++--
libs/jwst-binding/jwst-swift/src/storage.rs | 17 ++++++++++-------
14 files changed, 52 insertions(+), 45 deletions(-)
diff --git a/apps/android/app/src/main/java/com/example/jwst_demo/MainActivity.kt b/apps/android/app/src/main/java/com/example/jwst_demo/MainActivity.kt
index 62715036..6a6fe3ae 100644
--- a/apps/android/app/src/main/java/com/example/jwst_demo/MainActivity.kt
+++ b/apps/android/app/src/main/java/com/example/jwst_demo/MainActivity.kt
@@ -40,9 +40,14 @@ class MainActivity : AppCompatActivity() {
val database = File(filesDir, "jwst.db")
val storage = Storage(database.absolutePath, "ws://10.0.2.2:3000/collaboration", "debug")
- storage.initWorkspace(getRandomId(), getStaticWorkspace().hexStringToByteArray())
- val text = storage.getWorkspace("test1").get().get("test").get().get("test").get()
+ val randomId = getRandomId()
+ storage.initWorkspace(randomId, getStaticWorkspace().hexStringToByteArray())
+ val text = storage.getWorkspace(randomId).get().get("test").get().get("test").get()
Log.i("jwst", "text: $text")
+ storage.exportWorkspace(randomId).getOrNull()?.let { data ->
+ val isSame = data.contentEquals(getStaticWorkspace().hexStringToByteArray())
+ Log.i("jwst", "exported data: $isSame")
+ }
storage.getWorkspace("test").unwrap()?.let { workspace ->
setupWorkspace(workspace)
diff --git a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/Info.plist b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/Info.plist
index 1809eda0..9bf2c5d0 100644
--- a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/Info.plist
+++ b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/Info.plist
@@ -26,7 +26,7 @@
HeadersPath
Headers
LibraryIdentifier
- ios-arm64
+ ios-arm64-simulator
LibraryPath
liboctobase.a
SupportedArchitectures
@@ -35,6 +35,8 @@
SupportedPlatform
ios
+ SupportedPlatformVariant
+ simulator
BinaryPath
@@ -42,7 +44,7 @@
HeadersPath
Headers
LibraryIdentifier
- ios-arm64-simulator
+ ios-arm64
LibraryPath
liboctobase.a
SupportedArchitectures
@@ -51,8 +53,6 @@
SupportedPlatform
ios
- SupportedPlatformVariant
- simulator
CFBundlePackageType
diff --git a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64-simulator/Headers/jwst-swift.h b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64-simulator/Headers/jwst-swift.h
index 98c97d3a..18792a98 100644
--- a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64-simulator/Headers/jwst-swift.h
+++ b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64-simulator/Headers/jwst-swift.h
@@ -122,8 +122,8 @@ bool __swift_bridge__$Storage$is_connected(void* self);
bool __swift_bridge__$Storage$is_finished(void* self);
bool __swift_bridge__$Storage$is_error(void* self);
void* __swift_bridge__$Storage$get_sync_state(void* self);
-bool __swift_bridge__$Storage$init(void* self, void* workspace_id, void* data);
-void* __swift_bridge__$Storage$export(void* self, void* workspace_id);
+bool __swift_bridge__$Storage$import_workspace(void* self, void* workspace_id, void* data);
+void* __swift_bridge__$Storage$export_workspace(void* self, void* workspace_id);
void* __swift_bridge__$Storage$connect(void* self, void* workspace_id, void* remote);
void* __swift_bridge__$Storage$get_last_synced(void* self);
diff --git a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64/Headers/jwst-swift.h b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64/Headers/jwst-swift.h
index 98c97d3a..18792a98 100644
--- a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64/Headers/jwst-swift.h
+++ b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/ios-arm64/Headers/jwst-swift.h
@@ -122,8 +122,8 @@ bool __swift_bridge__$Storage$is_connected(void* self);
bool __swift_bridge__$Storage$is_finished(void* self);
bool __swift_bridge__$Storage$is_error(void* self);
void* __swift_bridge__$Storage$get_sync_state(void* self);
-bool __swift_bridge__$Storage$init(void* self, void* workspace_id, void* data);
-void* __swift_bridge__$Storage$export(void* self, void* workspace_id);
+bool __swift_bridge__$Storage$import_workspace(void* self, void* workspace_id, void* data);
+void* __swift_bridge__$Storage$export_workspace(void* self, void* workspace_id);
void* __swift_bridge__$Storage$connect(void* self, void* workspace_id, void* remote);
void* __swift_bridge__$Storage$get_last_synced(void* self);
diff --git a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/macos-arm64/Headers/jwst-swift.h b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/macos-arm64/Headers/jwst-swift.h
index 98c97d3a..18792a98 100644
--- a/apps/swift/OctoBaseSwift/RustXcframework.xcframework/macos-arm64/Headers/jwst-swift.h
+++ b/apps/swift/OctoBaseSwift/RustXcframework.xcframework/macos-arm64/Headers/jwst-swift.h
@@ -122,8 +122,8 @@ bool __swift_bridge__$Storage$is_connected(void* self);
bool __swift_bridge__$Storage$is_finished(void* self);
bool __swift_bridge__$Storage$is_error(void* self);
void* __swift_bridge__$Storage$get_sync_state(void* self);
-bool __swift_bridge__$Storage$init(void* self, void* workspace_id, void* data);
-void* __swift_bridge__$Storage$export(void* self, void* workspace_id);
+bool __swift_bridge__$Storage$import_workspace(void* self, void* workspace_id, void* data);
+void* __swift_bridge__$Storage$export_workspace(void* self, void* workspace_id);
void* __swift_bridge__$Storage$connect(void* self, void* workspace_id, void* remote);
void* __swift_bridge__$Storage$get_last_synced(void* self);
diff --git a/apps/swift/OctoBaseSwift/Sources/OctoBase/jwst-swift.swift b/apps/swift/OctoBaseSwift/Sources/OctoBase/jwst-swift.swift
index 98decd0d..2cbb9c22 100644
--- a/apps/swift/OctoBaseSwift/Sources/OctoBase/jwst-swift.swift
+++ b/apps/swift/OctoBaseSwift/Sources/OctoBase/jwst-swift.swift
@@ -578,12 +578,12 @@ public class StorageRefMut: StorageRef {
}
}
extension StorageRefMut {
- public func init(_ workspace_id: GenericIntoRustString, _ data: RustVec) -> Bool {
- __swift_bridge__$Storage$init(ptr, { let rustString = workspace_id.intoRustString(); rustString.isOwned = false; return rustString.ptr }(), { let val = data; val.isOwned = false; return val.ptr }())
+ public func import_workspace(_ workspace_id: GenericIntoRustString, _ data: RustVec) -> Bool {
+ __swift_bridge__$Storage$import_workspace(ptr, { let rustString = workspace_id.intoRustString(); rustString.isOwned = false; return rustString.ptr }(), { let val = data; val.isOwned = false; return val.ptr }())
}
- public func export(_ workspace_id: GenericIntoRustString) -> Optional> {
- { let val = __swift_bridge__$Storage$export(ptr, { let rustString = workspace_id.intoRustString(); rustString.isOwned = false; return rustString.ptr }()); if val != nil { return RustVec(ptr: val!) } else { return nil } }()
+ public func export_workspace(_ workspace_id: GenericIntoRustString) -> Optional> {
+ { let val = __swift_bridge__$Storage$export_workspace(ptr, { let rustString = workspace_id.intoRustString(); rustString.isOwned = false; return rustString.ptr }()); if val != nil { return RustVec(ptr: val!) } else { return nil } }()
}
public func connect(_ workspace_id: GenericIntoRustString, _ remote: GenericIntoRustString) -> Optional {
diff --git a/libs/jwst-binding/jwst-jni/android/build.gradle b/libs/jwst-binding/jwst-jni/android/build.gradle
index 3e664058..195ea74d 100644
--- a/libs/jwst-binding/jwst-jni/android/build.gradle
+++ b/libs/jwst-binding/jwst-jni/android/build.gradle
@@ -117,7 +117,7 @@ publishing {
release(MavenPublication) {
groupId = 'com.toeverything'
artifactId = 'octobase'
- version = '0.2.7'
+ version = '0.2.8'
afterEvaluate {
from components.release
diff --git a/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/JWST.kt b/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/JWST.kt
index 3a9ee62f..d06aa383 100644
--- a/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/JWST.kt
+++ b/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/JWST.kt
@@ -183,7 +183,7 @@ class Storage constructor(path: String, private val remote: String = "", private
val error get() = this.storage.error()
fun initWorkspace(id: String, data: ByteArray): Result {
- val success = this.storage.init(id,data)
+ val success = this.storage.import_workspace(id,data)
return if (success) {
Result.success(Unit)
} else {
@@ -193,7 +193,7 @@ class Storage constructor(path: String, private val remote: String = "", private
}
fun exportWorkspace(id: String): Result {
- val data = this.storage.export(id)
+ val data = this.storage.export_workspace(id)
return if (data.isNotEmpty()) {
Result.success(data)
} else {
diff --git a/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/lib/JwstStorage.java b/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/lib/JwstStorage.java
index 0e776e38..c3032a94 100644
--- a/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/lib/JwstStorage.java
+++ b/libs/jwst-binding/jwst-jni/android/src/main/java/com/toeverything/jwst/lib/JwstStorage.java
@@ -58,19 +58,19 @@ public final boolean is_error() {
}
private static native @NonNull String do_get_sync_state(long self);
- public final boolean import(@NonNull String workspace_id, @NonNull byte [] data) {
- boolean ret = do_import(mNativeObj, workspace_id, data);
+ public final boolean import_workspace(@NonNull String workspace_id, @NonNull byte [] data) {
+ boolean ret = do_import_workspace(mNativeObj, workspace_id, data);
return ret;
}
- private static native boolean do_import(long self, @NonNull String workspace_id, byte [] data);
+ private static native boolean do_import_workspace(long self, @NonNull String workspace_id, byte [] data);
- public final byte [] export(@NonNull String workspace_id) {
- byte [] ret = do_export(mNativeObj, workspace_id);
+ public final byte [] export_workspace(@NonNull String workspace_id) {
+ byte [] ret = do_export_workspace(mNativeObj, workspace_id);
return ret;
}
- private static native byte [] do_export(long self, @NonNull String workspace_id);
+ private static native byte [] do_export_workspace(long self, @NonNull String workspace_id);
public final @NonNull java.util.Optional connect(@NonNull String workspace_id, @NonNull String remote) {
long ret = do_connect(mNativeObj, workspace_id, remote);
diff --git a/libs/jwst-binding/jwst-jni/build.rs b/libs/jwst-binding/jwst-jni/build.rs
index a8507f8e..7bda352e 100644
--- a/libs/jwst-binding/jwst-jni/build.rs
+++ b/libs/jwst-binding/jwst-jni/build.rs
@@ -56,8 +56,8 @@ foreign_typemap!(
fn JwstStorage::is_finished(&self) -> bool;
fn JwstStorage::is_error(&self) -> bool;
fn JwstStorage::get_sync_state(&self) -> String;
- fn JwstStorage::import(&mut self, workspace_id: String, data: &[u8]) -> bool; alias import;
- fn JwstStorage::export(&mut self, workspace_id: String) -> Vec; alias export;
+ fn JwstStorage::import_workspace(&mut self, workspace_id: String, data: &[u8]) -> bool; alias import_workspace;
+ fn JwstStorage::export_workspace(&mut self, workspace_id: String) -> Vec; alias export_workspace;
fn JwstStorage::connect(&mut self, workspace_id: String, remote: String) -> Option; alias connect;
fn JwstStorage::get_last_synced(&self) ->Vec;
}
diff --git a/libs/jwst-binding/jwst-jni/src/java_glue.rs.in b/libs/jwst-binding/jwst-jni/src/java_glue.rs.in
index b10ccdf6..6b5c4cd2 100644
--- a/libs/jwst-binding/jwst-jni/src/java_glue.rs.in
+++ b/libs/jwst-binding/jwst-jni/src/java_glue.rs.in
@@ -39,8 +39,8 @@ foreign_class!(
fn JwstStorage::is_finished(&self) -> bool;
fn JwstStorage::is_error(&self) -> bool;
fn JwstStorage::get_sync_state(&self) -> String;
- fn JwstStorage::import(&mut self, workspace_id: String, data: &[u8]) -> bool; alias import;
- fn JwstStorage::export(&mut self, workspace_id: String) -> Vec; alias export;
+ fn JwstStorage::import_workspace(&mut self, workspace_id: String, data: &[u8]) -> bool; alias import_workspace;
+ fn JwstStorage::export_workspace(&mut self, workspace_id: String) -> Vec; alias export_workspace;
fn JwstStorage::connect(&mut self, workspace_id: String, remote: String) -> Option; alias connect;
fn JwstStorage::get_last_synced(&self) ->Vec;
}
diff --git a/libs/jwst-binding/jwst-jni/src/storage.rs b/libs/jwst-binding/jwst-jni/src/storage.rs
index e364f82c..08e6b1b0 100644
--- a/libs/jwst-binding/jwst-jni/src/storage.rs
+++ b/libs/jwst-binding/jwst-jni/src/storage.rs
@@ -91,8 +91,8 @@ impl JwstStorage {
}
}
- pub fn import(&mut self, workspace_id: String, data: &[u8]) -> bool {
- match self.import_workspace(workspace_id, data) {
+ pub fn import_workspace(&mut self, workspace_id: String, data: &[u8]) -> bool {
+ match self.import_workspace_inner(workspace_id, data) {
Ok(_) => true,
Err(e) => {
let error = format!("Failed to init workspace: {:?}", e);
@@ -103,7 +103,7 @@ impl JwstStorage {
}
}
- fn import_workspace(&self, workspace_id: String, data: &[u8]) -> JwstStorageResult {
+ fn import_workspace_inner(&self, workspace_id: String, data: &[u8]) -> JwstStorageResult {
let rt = Arc::new(
Builder::new_multi_thread()
.worker_threads(1)
@@ -115,8 +115,8 @@ impl JwstStorage {
rt.block_on(self.storage.init_workspace(workspace_id, data.to_vec()))
}
- pub fn export(&mut self, workspace_id: String) -> Vec {
- match self.export_workspace(workspace_id) {
+ pub fn export_workspace(&mut self, workspace_id: String) -> Vec {
+ match self.export_workspace_inner(workspace_id) {
Ok(data) => data,
Err(e) => {
let error = format!("Failed to export workspace: {:?}", e);
@@ -127,7 +127,7 @@ impl JwstStorage {
}
}
- fn export_workspace(&self, workspace_id: String) -> JwstStorageResult> {
+ fn export_workspace_inner(&self, workspace_id: String) -> JwstStorageResult> {
let rt = Arc::new(
Builder::new_multi_thread()
.worker_threads(1)
@@ -165,7 +165,6 @@ impl JwstStorage {
match workspace {
Ok(mut workspace) => {
- warn!("is_offline: {}, remote: {}", is_offline, remote);
if is_offline {
let identifier = nanoid!();
let (last_synced_tx, last_synced_rx) = channel::(128);
diff --git a/libs/jwst-binding/jwst-swift/src/lib.rs b/libs/jwst-binding/jwst-swift/src/lib.rs
index 74634e57..466e149b 100644
--- a/libs/jwst-binding/jwst-swift/src/lib.rs
+++ b/libs/jwst-binding/jwst-swift/src/lib.rs
@@ -134,9 +134,9 @@ mod ffi {
fn get_sync_state(self: &Storage) -> String;
- fn import(self: &mut Storage, workspace_id: String, data: Vec) -> bool;
+ fn import_workspace(self: &mut Storage, workspace_id: String, data: Vec) -> bool;
- fn export(self: &mut Storage, workspace_id: String) -> Option>;
+ fn export_workspace(self: &mut Storage, workspace_id: String) -> Option>;
fn connect(self: &mut Storage, workspace_id: String, remote: String) -> Option;
diff --git a/libs/jwst-binding/jwst-swift/src/storage.rs b/libs/jwst-binding/jwst-swift/src/storage.rs
index 704704d4..39a36e23 100644
--- a/libs/jwst-binding/jwst-swift/src/storage.rs
+++ b/libs/jwst-binding/jwst-swift/src/storage.rs
@@ -88,8 +88,8 @@ impl Storage {
}
}
- pub fn import(&mut self, workspace_id: String, data: Vec) -> bool {
- match self.import_workspace(workspace_id, data) {
+ pub fn import_workspace(&mut self, workspace_id: String, data: Vec) -> bool {
+ match self.import_workspace_inner(workspace_id, data) {
Ok(_) => true,
Err(e) => {
let error = format!("Failed to init workspace: {:?}", e);
@@ -100,7 +100,7 @@ impl Storage {
}
}
- fn import_workspace(&self, workspace_id: String, data: Vec) -> JwstStorageResult {
+ fn import_workspace_inner(&self, workspace_id: String, data: Vec) -> JwstStorageResult {
let rt = Arc::new(
Builder::new_multi_thread()
.worker_threads(1)
@@ -112,8 +112,8 @@ impl Storage {
rt.block_on(self.storage.init_workspace(workspace_id, data))
}
- pub fn export(&mut self, workspace_id: String) -> Option> {
- match self.export_workspace(workspace_id) {
+ pub fn export_workspace(&mut self, workspace_id: String) -> Option> {
+ match self.export_workspace_inner(workspace_id) {
Ok(data) => Some(data),
Err(e) => {
let error = format!("Failed to export workspace: {:?}", e);
@@ -124,7 +124,7 @@ impl Storage {
}
}
- fn export_workspace(&self, workspace_id: String) -> JwstStorageResult> {
+ fn export_workspace_inner(&self, workspace_id: String) -> JwstStorageResult> {
let rt = Arc::new(
Builder::new_multi_thread()
.worker_threads(1)
@@ -133,7 +133,10 @@ impl Storage {
.build()
.map_err(JwstStorageError::SyncThread)?,
);
- rt.block_on(self.storage.export_workspace(workspace_id))
+ let workspace = rt.block_on(async { self.get_workspace(&workspace_id).await })?;
+ let binary = workspace.to_binary()?;
+
+ Ok(binary)
}
pub fn connect(&mut self, workspace_id: String, remote: String) -> Option {