mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
chore: update client api commit id (#3745)
* chore: update client api commit id * chore: fix test * chore: remove check_visual_studio_installation task * chore: update client api
This commit is contained in:
parent
8e5b6b6e27
commit
1e9137fcfe
65
frontend/appflowy_tauri/src-tauri/Cargo.lock
generated
65
frontend/appflowy_tauri/src-tauri/Cargo.lock
generated
@ -762,7 +762,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "client-api"
|
name = "client-api"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -775,6 +775,7 @@ dependencies = [
|
|||||||
"gotrue-entity",
|
"gotrue-entity",
|
||||||
"lib0",
|
"lib0",
|
||||||
"mime",
|
"mime",
|
||||||
|
"mime_guess",
|
||||||
"parking_lot",
|
"parking_lot",
|
||||||
"realtime-entity",
|
"realtime-entity",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
@ -1437,15 +1438,17 @@ checksum = "c2e66c9d817f1720209181c316d28635c050fa304f9c79e47a520882661b7308"
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "database-entity"
|
name = "database-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"chrono",
|
"chrono",
|
||||||
"collab-entity",
|
"collab-entity",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
|
"serde_repr",
|
||||||
"sqlx",
|
"sqlx",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
|
"tracing",
|
||||||
"uuid",
|
"uuid",
|
||||||
"validator",
|
"validator",
|
||||||
]
|
]
|
||||||
@ -2778,7 +2781,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gotrue"
|
name = "gotrue"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
@ -2794,9 +2797,11 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gotrue-entity"
|
name = "gotrue-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
|
"jsonwebtoken",
|
||||||
|
"lazy_static",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
@ -3227,7 +3232,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "infra"
|
name = "infra"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
@ -3373,6 +3378,20 @@ dependencies = [
|
|||||||
"treediff",
|
"treediff",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "jsonwebtoken"
|
||||||
|
version = "8.3.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6971da4d9c3aa03c3d8f3ff0f4155b534aad021292003895a469716b2a230378"
|
||||||
|
dependencies = [
|
||||||
|
"base64 0.21.2",
|
||||||
|
"pem",
|
||||||
|
"ring",
|
||||||
|
"serde",
|
||||||
|
"serde_json",
|
||||||
|
"simple_asn1",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "kuchiki"
|
name = "kuchiki"
|
||||||
version = "0.8.1"
|
version = "0.8.1"
|
||||||
@ -3894,6 +3913,17 @@ dependencies = [
|
|||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "num-bigint"
|
||||||
|
version = "0.4.3"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "f93ab6289c7b344a8a9f60f88d80aa20032336fe78da341afc91c8a2341fc75f"
|
||||||
|
dependencies = [
|
||||||
|
"autocfg",
|
||||||
|
"num-integer",
|
||||||
|
"num-traits",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "num-integer"
|
name = "num-integer"
|
||||||
version = "0.1.45"
|
version = "0.1.45"
|
||||||
@ -4190,6 +4220,15 @@ version = "0.1.2"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099"
|
checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "pem"
|
||||||
|
version = "1.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a8835c273a76a90455d7344889b0964598e3316e2a79ede8e36f16bdcf2228b8"
|
||||||
|
dependencies = [
|
||||||
|
"base64 0.13.1",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "percent-encoding"
|
name = "percent-encoding"
|
||||||
version = "2.3.0"
|
version = "2.3.0"
|
||||||
@ -4876,7 +4915,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "realtime-entity"
|
name = "realtime-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes",
|
"bytes",
|
||||||
"collab",
|
"collab",
|
||||||
@ -5598,7 +5637,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "shared_entity"
|
name = "shared_entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"database-entity",
|
"database-entity",
|
||||||
@ -5653,6 +5692,18 @@ version = "2.2.1"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "420acb44afdae038210c99e69aae24109f32f15500aa708e81d46c9f29d55fcf"
|
checksum = "420acb44afdae038210c99e69aae24109f32f15500aa708e81d46c9f29d55fcf"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "simple_asn1"
|
||||||
|
version = "0.6.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "adc4e5204eb1910f40f9cfa375f6f05b68c3abac4b6fd879c8ff5e7ae8a0a085"
|
||||||
|
dependencies = [
|
||||||
|
"num-bigint",
|
||||||
|
"num-traits",
|
||||||
|
"thiserror",
|
||||||
|
"time",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "siphasher"
|
name = "siphasher"
|
||||||
version = "0.3.10"
|
version = "0.3.10"
|
||||||
|
@ -38,7 +38,7 @@ custom-protocol = ["tauri/custom-protocol"]
|
|||||||
# Run the script:
|
# Run the script:
|
||||||
# scripts/tool/update_client_api_rev.sh new_rev_id
|
# scripts/tool/update_client_api_rev.sh new_rev_id
|
||||||
# ⚠️⚠️⚠️️
|
# ⚠️⚠️⚠️️
|
||||||
client-api = { git = "https://github.com/AppFlowy-IO/AppFlowy-Cloud", rev = "52b82e68" }
|
client-api = { git = "https://github.com/AppFlowy-IO/AppFlowy-Cloud", rev = "7a309c6f69d8b34709292052e9ef0561e16c82a1" }
|
||||||
# Please use the following script to update collab.
|
# Please use the following script to update collab.
|
||||||
# Working directory: frontend
|
# Working directory: frontend
|
||||||
#
|
#
|
||||||
|
75
frontend/rust-lib/Cargo.lock
generated
75
frontend/rust-lib/Cargo.lock
generated
@ -660,7 +660,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "client-api"
|
name = "client-api"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"bytes",
|
"bytes",
|
||||||
@ -673,6 +673,7 @@ dependencies = [
|
|||||||
"gotrue-entity",
|
"gotrue-entity",
|
||||||
"lib0",
|
"lib0",
|
||||||
"mime",
|
"mime",
|
||||||
|
"mime_guess",
|
||||||
"parking_lot",
|
"parking_lot",
|
||||||
"realtime-entity",
|
"realtime-entity",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
@ -1264,15 +1265,17 @@ checksum = "c2e66c9d817f1720209181c316d28635c050fa304f9c79e47a520882661b7308"
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "database-entity"
|
name = "database-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"chrono",
|
"chrono",
|
||||||
"collab-entity",
|
"collab-entity",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
|
"serde_repr",
|
||||||
"sqlx",
|
"sqlx",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
|
"tracing",
|
||||||
"uuid",
|
"uuid",
|
||||||
"validator",
|
"validator",
|
||||||
]
|
]
|
||||||
@ -2437,7 +2440,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gotrue"
|
name = "gotrue"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
@ -2453,9 +2456,11 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "gotrue-entity"
|
name = "gotrue-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
|
"jsonwebtoken",
|
||||||
|
"lazy_static",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
@ -2811,7 +2816,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "infra"
|
name = "infra"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
@ -2885,6 +2890,20 @@ dependencies = [
|
|||||||
"wasm-bindgen",
|
"wasm-bindgen",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "jsonwebtoken"
|
||||||
|
version = "8.3.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6971da4d9c3aa03c3d8f3ff0f4155b534aad021292003895a469716b2a230378"
|
||||||
|
dependencies = [
|
||||||
|
"base64 0.21.3",
|
||||||
|
"pem",
|
||||||
|
"ring",
|
||||||
|
"serde",
|
||||||
|
"serde_json",
|
||||||
|
"simple_asn1",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "lazy_static"
|
name = "lazy_static"
|
||||||
version = "1.4.0"
|
version = "1.4.0"
|
||||||
@ -3309,6 +3328,27 @@ dependencies = [
|
|||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "num-bigint"
|
||||||
|
version = "0.4.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "608e7659b5c3d7cba262d894801b9ec9d00de989e8a82bd4bef91d08da45cdc0"
|
||||||
|
dependencies = [
|
||||||
|
"autocfg",
|
||||||
|
"num-integer",
|
||||||
|
"num-traits",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "num-integer"
|
||||||
|
version = "0.1.45"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9"
|
||||||
|
dependencies = [
|
||||||
|
"autocfg",
|
||||||
|
"num-traits",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "num-traits"
|
name = "num-traits"
|
||||||
version = "0.2.16"
|
version = "0.2.16"
|
||||||
@ -3517,6 +3557,15 @@ version = "0.1.2"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099"
|
checksum = "19b17cddbe7ec3f8bc800887bab5e717348c95ea2ca0b1bf0837fb964dc67099"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "pem"
|
||||||
|
version = "1.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a8835c273a76a90455d7344889b0964598e3316e2a79ede8e36f16bdcf2228b8"
|
||||||
|
dependencies = [
|
||||||
|
"base64 0.13.1",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "percent-encoding"
|
name = "percent-encoding"
|
||||||
version = "2.3.0"
|
version = "2.3.0"
|
||||||
@ -4202,7 +4251,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "realtime-entity"
|
name = "realtime-entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes",
|
"bytes",
|
||||||
"collab",
|
"collab",
|
||||||
@ -4823,7 +4872,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "shared_entity"
|
name = "shared_entity"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=52b82e68#52b82e68f6e61e9e38606b9110d782870ee911e4"
|
source = "git+https://github.com/AppFlowy-IO/AppFlowy-Cloud?rev=7a309c6f69d8b34709292052e9ef0561e16c82a1#7a309c6f69d8b34709292052e9ef0561e16c82a1"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"database-entity",
|
"database-entity",
|
||||||
@ -4872,6 +4921,18 @@ version = "2.2.1"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "420acb44afdae038210c99e69aae24109f32f15500aa708e81d46c9f29d55fcf"
|
checksum = "420acb44afdae038210c99e69aae24109f32f15500aa708e81d46c9f29d55fcf"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "simple_asn1"
|
||||||
|
version = "0.6.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "adc4e5204eb1910f40f9cfa375f6f05b68c3abac4b6fd879c8ff5e7ae8a0a085"
|
||||||
|
dependencies = [
|
||||||
|
"num-bigint",
|
||||||
|
"num-traits",
|
||||||
|
"thiserror",
|
||||||
|
"time",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "siphasher"
|
name = "siphasher"
|
||||||
version = "0.3.11"
|
version = "0.3.11"
|
||||||
|
@ -82,7 +82,7 @@ incremental = false
|
|||||||
# Run the script:
|
# Run the script:
|
||||||
# scripts/tool/update_client_api_rev.sh new_rev_id
|
# scripts/tool/update_client_api_rev.sh new_rev_id
|
||||||
# ⚠️⚠️⚠️️
|
# ⚠️⚠️⚠️️
|
||||||
client-api = { git = "https://github.com/AppFlowy-IO/AppFlowy-Cloud", rev = "52b82e68" }
|
client-api = { git = "https://github.com/AppFlowy-IO/AppFlowy-Cloud", rev = "7a309c6f69d8b34709292052e9ef0561e16c82a1" }
|
||||||
# Please use the following script to update collab.
|
# Please use the following script to update collab.
|
||||||
# Working directory: frontend
|
# Working directory: frontend
|
||||||
#
|
#
|
||||||
|
@ -87,9 +87,10 @@ impl FlowyCoreTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_document_update(&self, document_id: &str) -> Vec<u8> {
|
pub async fn get_document_update(&self, document_id: &str) -> Vec<u8> {
|
||||||
|
let workspace_id = self.user_manager.workspace_id().unwrap();
|
||||||
let cloud_service = self.document_manager.get_cloud_service().clone();
|
let cloud_service = self.document_manager.get_cloud_service().clone();
|
||||||
let remote_updates = cloud_service
|
let remote_updates = cloud_service
|
||||||
.get_document_updates(document_id)
|
.get_document_updates(document_id, &workspace_id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
@ -212,7 +213,7 @@ impl FlowyCoreTest {
|
|||||||
|
|
||||||
let mut map = HashMap::new();
|
let mut map = HashMap::new();
|
||||||
map.insert(USER_SIGN_IN_URL.to_string(), sign_in_url);
|
map.insert(USER_SIGN_IN_URL.to_string(), sign_in_url);
|
||||||
map.insert(USER_DEVICE_ID.to_string(), uuid::Uuid::new_v4().to_string());
|
map.insert(USER_DEVICE_ID.to_string(), Uuid::new_v4().to_string());
|
||||||
let payload = OauthSignInPB {
|
let payload = OauthSignInPB {
|
||||||
map,
|
map,
|
||||||
auth_type: AuthTypePB::AFCloud,
|
auth_type: AuthTypePB::AFCloud,
|
||||||
@ -261,7 +262,7 @@ impl FlowyCoreTest {
|
|||||||
.event(FolderEvent::GetCurrentWorkspace)
|
.event(FolderEvent::GetCurrentWorkspace)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::WorkspaceSettingPB>()
|
.parse::<WorkspaceSettingPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_all_workspace_views(&self) -> Vec<ViewPB> {
|
pub async fn get_all_workspace_views(&self) -> Vec<ViewPB> {
|
||||||
@ -269,7 +270,7 @@ impl FlowyCoreTest {
|
|||||||
.event(FolderEvent::ReadWorkspaceViews)
|
.event(FolderEvent::ReadWorkspaceViews)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::RepeatedViewPB>()
|
.parse::<RepeatedViewPB>()
|
||||||
.items
|
.items
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -281,7 +282,7 @@ impl FlowyCoreTest {
|
|||||||
})
|
})
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn delete_view(&self, view_id: &str) {
|
pub async fn delete_view(&self, view_id: &str) {
|
||||||
@ -333,7 +334,7 @@ impl FlowyCoreTest {
|
|||||||
.payload(payload)
|
.payload(payload)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn create_document(
|
pub async fn create_document(
|
||||||
@ -391,7 +392,7 @@ impl FlowyCoreTest {
|
|||||||
.payload(payload)
|
.payload(payload)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn open_database(&self, view_id: &str) {
|
pub async fn open_database(&self, view_id: &str) {
|
||||||
@ -434,7 +435,7 @@ impl FlowyCoreTest {
|
|||||||
.payload(payload)
|
.payload(payload)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn create_calendar(
|
pub async fn create_calendar(
|
||||||
@ -459,7 +460,7 @@ impl FlowyCoreTest {
|
|||||||
.payload(payload)
|
.payload(payload)
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_database(&self, view_id: &str) -> DatabasePB {
|
pub async fn get_database(&self, view_id: &str) -> DatabasePB {
|
||||||
@ -470,7 +471,7 @@ impl FlowyCoreTest {
|
|||||||
})
|
})
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_database2::entities::DatabasePB>()
|
.parse::<DatabasePB>()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_all_database_fields(&self, view_id: &str) -> RepeatedFieldPB {
|
pub async fn get_all_database_fields(&self, view_id: &str) -> RepeatedFieldPB {
|
||||||
@ -836,7 +837,7 @@ impl FlowyCoreTest {
|
|||||||
})
|
})
|
||||||
.async_send()
|
.async_send()
|
||||||
.await
|
.await
|
||||||
.parse::<flowy_folder2::entities::ViewPB>()
|
.parse::<ViewPB>()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -71,9 +71,10 @@ impl FlowySupabaseDatabaseTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_database_collab_update(&self, database_id: &str) -> Vec<u8> {
|
pub async fn get_database_collab_update(&self, database_id: &str) -> Vec<u8> {
|
||||||
|
let workspace_id = self.user_manager.workspace_id().unwrap();
|
||||||
let cloud_service = self.database_manager.get_cloud_service().clone();
|
let cloud_service = self.database_manager.get_cloud_service().clone();
|
||||||
let remote_updates = cloud_service
|
let remote_updates = cloud_service
|
||||||
.get_collab_update(database_id, CollabType::Database)
|
.get_collab_update(database_id, CollabType::Database, &workspace_id)
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
@ -273,12 +273,13 @@ async fn migrate_anon_document_on_cloud_signup() {
|
|||||||
|
|
||||||
let _ = test.supabase_party_sign_up().await;
|
let _ = test.supabase_party_sign_up().await;
|
||||||
|
|
||||||
|
let workspace_id = test.user_manager.workspace_id().unwrap();
|
||||||
// After sign up, the documents should be migrated to the cloud
|
// After sign up, the documents should be migrated to the cloud
|
||||||
// So, we can get the document data from the cloud
|
// So, we can get the document data from the cloud
|
||||||
let data: DocumentData = test
|
let data: DocumentData = test
|
||||||
.document_manager
|
.document_manager
|
||||||
.get_cloud_service()
|
.get_cloud_service()
|
||||||
.get_document_data(&view.id)
|
.get_document_data(&view.id, &workspace_id)
|
||||||
.await
|
.await
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -372,6 +373,7 @@ async fn migrate_anon_data_on_cloud_signup() {
|
|||||||
let rows = editor.get_rows(&database_view.id).await.unwrap();
|
let rows = editor.get_rows(&database_view.id).await.unwrap();
|
||||||
assert_eq!(rows.len(), 3);
|
assert_eq!(rows.len(), 3);
|
||||||
|
|
||||||
|
let workspace_id = test.user_manager.workspace_id().unwrap();
|
||||||
if i == 0 {
|
if i == 0 {
|
||||||
let first_row = rows.first().unwrap().as_ref();
|
let first_row = rows.first().unwrap().as_ref();
|
||||||
let icon_url = first_row.meta.icon_url.clone().unwrap();
|
let icon_url = first_row.meta.icon_url.clone().unwrap();
|
||||||
@ -381,7 +383,7 @@ async fn migrate_anon_data_on_cloud_signup() {
|
|||||||
let document_data: DocumentData = test
|
let document_data: DocumentData = test
|
||||||
.document_manager
|
.document_manager
|
||||||
.get_cloud_service()
|
.get_cloud_service()
|
||||||
.get_document_data(&document_id)
|
.get_document_data(&document_id, &workspace_id)
|
||||||
.await
|
.await
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
@ -407,7 +409,7 @@ async fn migrate_anon_data_on_cloud_signup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
assert!(cloud_service
|
assert!(cloud_service
|
||||||
.get_collab_update(&database_id, CollabType::Database)
|
.get_collab_update(&database_id, CollabType::Database, &workspace_id)
|
||||||
.await
|
.await
|
||||||
.is_ok());
|
.is_ok());
|
||||||
}
|
}
|
||||||
|
@ -38,6 +38,14 @@ impl DocumentUser for DocumentUserImpl {
|
|||||||
.user_id()
|
.user_id()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn workspace_id(&self) -> Result<String, FlowyError> {
|
||||||
|
self
|
||||||
|
.0
|
||||||
|
.upgrade()
|
||||||
|
.ok_or(FlowyError::internal().with_context("Unexpected error: UserSession is None"))?
|
||||||
|
.workspace_id()
|
||||||
|
}
|
||||||
|
|
||||||
fn token(&self) -> Result<Option<String>, FlowyError> {
|
fn token(&self) -> Result<Option<String>, FlowyError> {
|
||||||
self
|
self
|
||||||
.0
|
.0
|
||||||
|
@ -190,13 +190,15 @@ impl DatabaseCloudService for ServerProvider {
|
|||||||
&self,
|
&self,
|
||||||
object_id: &str,
|
object_id: &str,
|
||||||
collab_type: CollabType,
|
collab_type: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdate, Error> {
|
) -> FutureResult<CollabObjectUpdate, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let server = self.get_server(&self.get_server_type());
|
let server = self.get_server(&self.get_server_type());
|
||||||
let database_id = object_id.to_string();
|
let database_id = object_id.to_string();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
server?
|
server?
|
||||||
.database_service()
|
.database_service()
|
||||||
.get_collab_update(&database_id, collab_type)
|
.get_collab_update(&database_id, collab_type, &workspace_id)
|
||||||
.await
|
.await
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -205,12 +207,14 @@ impl DatabaseCloudService for ServerProvider {
|
|||||||
&self,
|
&self,
|
||||||
object_ids: Vec<String>,
|
object_ids: Vec<String>,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let server = self.get_server(&self.get_server_type());
|
let server = self.get_server(&self.get_server_type());
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
server?
|
server?
|
||||||
.database_service()
|
.database_service()
|
||||||
.batch_get_collab_updates(object_ids, object_ty)
|
.batch_get_collab_updates(object_ids, object_ty, &workspace_id)
|
||||||
.await
|
.await
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -232,13 +236,18 @@ impl DatabaseCloudService for ServerProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl DocumentCloudService for ServerProvider {
|
impl DocumentCloudService for ServerProvider {
|
||||||
fn get_document_updates(&self, document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error> {
|
fn get_document_updates(
|
||||||
let server = self.get_server(&self.get_server_type());
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
|
let server = self.get_server(&self.get_server_type());
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
server?
|
server?
|
||||||
.document_service()
|
.document_service()
|
||||||
.get_document_updates(&document_id)
|
.get_document_updates(&document_id, &workspace_id)
|
||||||
.await
|
.await
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -247,24 +256,31 @@ impl DocumentCloudService for ServerProvider {
|
|||||||
&self,
|
&self,
|
||||||
document_id: &str,
|
document_id: &str,
|
||||||
limit: usize,
|
limit: usize,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let server = self.get_server(&self.get_server_type());
|
let server = self.get_server(&self.get_server_type());
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
server?
|
server?
|
||||||
.document_service()
|
.document_service()
|
||||||
.get_document_snapshots(&document_id, limit)
|
.get_document_snapshots(&document_id, limit, &workspace_id)
|
||||||
.await
|
.await
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_document_data(&self, document_id: &str) -> FutureResult<Option<DocumentData>, Error> {
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let server = self.get_server(&self.get_server_type());
|
let server = self.get_server(&self.get_server_type());
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
server?
|
server?
|
||||||
.document_service()
|
.document_service()
|
||||||
.get_document_data(&document_id)
|
.get_document_data(&document_id, &workspace_id)
|
||||||
.await
|
.await
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -125,6 +125,7 @@ impl AppFlowyCore {
|
|||||||
server_provider.clone(),
|
server_provider.clone(),
|
||||||
Arc::downgrade(&collab_builder),
|
Arc::downgrade(&collab_builder),
|
||||||
);
|
);
|
||||||
|
|
||||||
collab_builder
|
collab_builder
|
||||||
.set_snapshot_persistence(Arc::new(SnapshotDBImpl(Arc::downgrade(&user_manager))));
|
.set_snapshot_persistence(Arc::new(SnapshotDBImpl(Arc::downgrade(&user_manager))));
|
||||||
|
|
||||||
@ -179,8 +180,8 @@ impl AppFlowyCore {
|
|||||||
|
|
||||||
let cloned_user_session = Arc::downgrade(&user_manager);
|
let cloned_user_session = Arc::downgrade(&user_manager);
|
||||||
runtime.block_on(async move {
|
runtime.block_on(async move {
|
||||||
if let Some(user_session) = cloned_user_session.upgrade() {
|
if let Some(user_manager) = cloned_user_session.upgrade() {
|
||||||
if let Err(err) = user_session
|
if let Err(err) = user_manager
|
||||||
.init(user_status_callback, collab_interact_impl)
|
.init(user_status_callback, collab_interact_impl)
|
||||||
.await
|
.await
|
||||||
{
|
{
|
||||||
|
@ -16,12 +16,14 @@ pub trait DatabaseCloudService: Send + Sync {
|
|||||||
&self,
|
&self,
|
||||||
object_id: &str,
|
object_id: &str,
|
||||||
collab_type: CollabType,
|
collab_type: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdate, Error>;
|
) -> FutureResult<CollabObjectUpdate, Error>;
|
||||||
|
|
||||||
fn batch_get_collab_updates(
|
fn batch_get_collab_updates(
|
||||||
&self,
|
&self,
|
||||||
object_ids: Vec<String>,
|
object_ids: Vec<String>,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdateByOid, Error>;
|
) -> FutureResult<CollabObjectUpdateByOid, Error>;
|
||||||
|
|
||||||
fn get_collab_snapshots(
|
fn get_collab_snapshots(
|
||||||
|
@ -76,11 +76,12 @@ impl DatabaseManager {
|
|||||||
pub async fn initialize(
|
pub async fn initialize(
|
||||||
&self,
|
&self,
|
||||||
uid: i64,
|
uid: i64,
|
||||||
_workspace_id: String,
|
workspace_id: String,
|
||||||
database_views_aggregate_id: String,
|
database_views_aggregate_id: String,
|
||||||
) -> FlowyResult<()> {
|
) -> FlowyResult<()> {
|
||||||
let collab_db = self.user.collab_db(uid)?;
|
let collab_db = self.user.collab_db(uid)?;
|
||||||
let collab_builder = UserDatabaseCollabServiceImpl {
|
let collab_builder = UserDatabaseCollabServiceImpl {
|
||||||
|
workspace_id: workspace_id.clone(),
|
||||||
collab_builder: self.collab_builder.clone(),
|
collab_builder: self.collab_builder.clone(),
|
||||||
cloud_service: self.cloud_service.clone(),
|
cloud_service: self.cloud_service.clone(),
|
||||||
};
|
};
|
||||||
@ -92,7 +93,11 @@ impl DatabaseManager {
|
|||||||
trace!("workspace database not exist, try to fetch from remote");
|
trace!("workspace database not exist, try to fetch from remote");
|
||||||
match self
|
match self
|
||||||
.cloud_service
|
.cloud_service
|
||||||
.get_collab_update(&database_views_aggregate_id, CollabType::WorkspaceDatabase)
|
.get_collab_update(
|
||||||
|
&database_views_aggregate_id,
|
||||||
|
CollabType::WorkspaceDatabase,
|
||||||
|
&workspace_id,
|
||||||
|
)
|
||||||
.await
|
.await
|
||||||
{
|
{
|
||||||
Ok(updates) => {
|
Ok(updates) => {
|
||||||
@ -370,6 +375,7 @@ fn subscribe_block_event(workspace_database: &WorkspaceDatabase) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct UserDatabaseCollabServiceImpl {
|
struct UserDatabaseCollabServiceImpl {
|
||||||
|
workspace_id: String,
|
||||||
collab_builder: Arc<AppFlowyCollabBuilder>,
|
collab_builder: Arc<AppFlowyCollabBuilder>,
|
||||||
cloud_service: Arc<dyn DatabaseCloudService>,
|
cloud_service: Arc<dyn DatabaseCloudService>,
|
||||||
}
|
}
|
||||||
@ -380,6 +386,7 @@ impl DatabaseCollabService for UserDatabaseCollabServiceImpl {
|
|||||||
object_id: &str,
|
object_id: &str,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
) -> CollabFuture<Result<CollabObjectUpdate, DatabaseError>> {
|
) -> CollabFuture<Result<CollabObjectUpdate, DatabaseError>> {
|
||||||
|
let workspace_id = self.workspace_id.clone();
|
||||||
let object_id = object_id.to_string();
|
let object_id = object_id.to_string();
|
||||||
let weak_cloud_service = Arc::downgrade(&self.cloud_service);
|
let weak_cloud_service = Arc::downgrade(&self.cloud_service);
|
||||||
Box::pin(async move {
|
Box::pin(async move {
|
||||||
@ -390,7 +397,7 @@ impl DatabaseCollabService for UserDatabaseCollabServiceImpl {
|
|||||||
},
|
},
|
||||||
Some(cloud_service) => {
|
Some(cloud_service) => {
|
||||||
let updates = cloud_service
|
let updates = cloud_service
|
||||||
.get_collab_update(&object_id, object_ty)
|
.get_collab_update(&object_id, object_ty, &workspace_id)
|
||||||
.await?;
|
.await?;
|
||||||
Ok(updates)
|
Ok(updates)
|
||||||
},
|
},
|
||||||
@ -403,6 +410,7 @@ impl DatabaseCollabService for UserDatabaseCollabServiceImpl {
|
|||||||
object_ids: Vec<String>,
|
object_ids: Vec<String>,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
) -> CollabFuture<Result<CollabObjectUpdateByOid, DatabaseError>> {
|
) -> CollabFuture<Result<CollabObjectUpdateByOid, DatabaseError>> {
|
||||||
|
let workspace_id = self.workspace_id.clone();
|
||||||
let weak_cloud_service = Arc::downgrade(&self.cloud_service);
|
let weak_cloud_service = Arc::downgrade(&self.cloud_service);
|
||||||
Box::pin(async move {
|
Box::pin(async move {
|
||||||
match weak_cloud_service.upgrade() {
|
match weak_cloud_service.upgrade() {
|
||||||
@ -412,7 +420,7 @@ impl DatabaseCollabService for UserDatabaseCollabServiceImpl {
|
|||||||
},
|
},
|
||||||
Some(cloud_service) => {
|
Some(cloud_service) => {
|
||||||
let updates = cloud_service
|
let updates = cloud_service
|
||||||
.batch_get_collab_updates(object_ids, object_ty)
|
.batch_get_collab_updates(object_ids, object_ty, &workspace_id)
|
||||||
.await?;
|
.await?;
|
||||||
Ok(updates)
|
Ok(updates)
|
||||||
},
|
},
|
||||||
|
@ -7,15 +7,24 @@ use lib_infra::future::FutureResult;
|
|||||||
/// Each kind of server should implement this trait. Check out the [AppFlowyServerProvider] of
|
/// Each kind of server should implement this trait. Check out the [AppFlowyServerProvider] of
|
||||||
/// [flowy-server] crate for more information.
|
/// [flowy-server] crate for more information.
|
||||||
pub trait DocumentCloudService: Send + Sync + 'static {
|
pub trait DocumentCloudService: Send + Sync + 'static {
|
||||||
fn get_document_updates(&self, document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error>;
|
fn get_document_updates(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error>;
|
||||||
|
|
||||||
fn get_document_snapshots(
|
fn get_document_snapshots(
|
||||||
&self,
|
&self,
|
||||||
document_id: &str,
|
document_id: &str,
|
||||||
limit: usize,
|
limit: usize,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error>;
|
) -> FutureResult<Vec<DocumentSnapshot>, Error>;
|
||||||
|
|
||||||
fn get_document_data(&self, document_id: &str) -> FutureResult<Option<DocumentData>, Error>;
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error>;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct DocumentSnapshot {
|
pub struct DocumentSnapshot {
|
||||||
|
@ -22,6 +22,9 @@ use crate::reminder::DocumentReminderAction;
|
|||||||
|
|
||||||
pub trait DocumentUser: Send + Sync {
|
pub trait DocumentUser: Send + Sync {
|
||||||
fn user_id(&self) -> Result<i64, FlowyError>;
|
fn user_id(&self) -> Result<i64, FlowyError>;
|
||||||
|
|
||||||
|
fn workspace_id(&self) -> Result<String, FlowyError>;
|
||||||
|
|
||||||
fn token(&self) -> Result<Option<String>, FlowyError>; // unused now.
|
fn token(&self) -> Result<Option<String>, FlowyError>; // unused now.
|
||||||
fn collab_db(&self, uid: i64) -> Result<Weak<RocksCollabDB>, FlowyError>;
|
fn collab_db(&self, uid: i64) -> Result<Weak<RocksCollabDB>, FlowyError>;
|
||||||
}
|
}
|
||||||
@ -101,7 +104,10 @@ impl DocumentManager {
|
|||||||
let mut updates = vec![];
|
let mut updates = vec![];
|
||||||
if !self.is_doc_exist(doc_id)? {
|
if !self.is_doc_exist(doc_id)? {
|
||||||
// Try to get the document from the cloud service
|
// Try to get the document from the cloud service
|
||||||
updates = self.cloud_service.get_document_updates(doc_id).await?;
|
updates = self
|
||||||
|
.cloud_service
|
||||||
|
.get_document_updates(&self.user.workspace_id()?, doc_id)
|
||||||
|
.await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
let uid = self.user.user_id()?;
|
let uid = self.user.user_id()?;
|
||||||
@ -120,7 +126,10 @@ impl DocumentManager {
|
|||||||
pub async fn get_document_data(&self, doc_id: &str) -> FlowyResult<DocumentData> {
|
pub async fn get_document_data(&self, doc_id: &str) -> FlowyResult<DocumentData> {
|
||||||
let mut updates = vec![];
|
let mut updates = vec![];
|
||||||
if !self.is_doc_exist(doc_id)? {
|
if !self.is_doc_exist(doc_id)? {
|
||||||
updates = self.cloud_service.get_document_updates(doc_id).await?;
|
updates = self
|
||||||
|
.cloud_service
|
||||||
|
.get_document_updates(doc_id, &self.user.workspace_id()?)
|
||||||
|
.await?;
|
||||||
}
|
}
|
||||||
let uid = self.user.user_id()?;
|
let uid = self.user.user_id()?;
|
||||||
let collab = self.collab_for_document(uid, doc_id, updates).await?;
|
let collab = self.collab_for_document(uid, doc_id, updates).await?;
|
||||||
@ -152,9 +161,10 @@ impl DocumentManager {
|
|||||||
document_id: &str,
|
document_id: &str,
|
||||||
limit: usize,
|
limit: usize,
|
||||||
) -> FlowyResult<Vec<DocumentSnapshotPB>> {
|
) -> FlowyResult<Vec<DocumentSnapshotPB>> {
|
||||||
|
let workspace_id = self.user.workspace_id()?;
|
||||||
let snapshots = self
|
let snapshots = self
|
||||||
.cloud_service
|
.cloud_service
|
||||||
.get_document_snapshots(document_id, limit)
|
.get_document_snapshots(document_id, limit, &workspace_id)
|
||||||
.await?
|
.await?
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|snapshot| DocumentSnapshotPB {
|
.map(|snapshot| DocumentSnapshotPB {
|
||||||
|
@ -9,6 +9,7 @@ use nanoid::nanoid;
|
|||||||
use parking_lot::Once;
|
use parking_lot::Once;
|
||||||
use tempfile::TempDir;
|
use tempfile::TempDir;
|
||||||
use tracing_subscriber::{fmt::Subscriber, util::SubscriberInitExt, EnvFilter};
|
use tracing_subscriber::{fmt::Subscriber, util::SubscriberInitExt, EnvFilter};
|
||||||
|
use uuid::Uuid;
|
||||||
|
|
||||||
use collab_integrate::collab_builder::{AppFlowyCollabBuilder, DefaultCollabStorageProvider};
|
use collab_integrate::collab_builder::{AppFlowyCollabBuilder, DefaultCollabStorageProvider};
|
||||||
use collab_integrate::RocksCollabDB;
|
use collab_integrate::RocksCollabDB;
|
||||||
@ -61,6 +62,10 @@ impl DocumentUser for FakeUser {
|
|||||||
Ok(1)
|
Ok(1)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn workspace_id(&self) -> Result<String, FlowyError> {
|
||||||
|
Ok(Uuid::new_v4().to_string())
|
||||||
|
}
|
||||||
|
|
||||||
fn token(&self) -> Result<Option<String>, FlowyError> {
|
fn token(&self) -> Result<Option<String>, FlowyError> {
|
||||||
Ok(None)
|
Ok(None)
|
||||||
}
|
}
|
||||||
@ -120,7 +125,11 @@ pub fn gen_id() -> String {
|
|||||||
|
|
||||||
pub struct LocalTestDocumentCloudServiceImpl();
|
pub struct LocalTestDocumentCloudServiceImpl();
|
||||||
impl DocumentCloudService for LocalTestDocumentCloudServiceImpl {
|
impl DocumentCloudService for LocalTestDocumentCloudServiceImpl {
|
||||||
fn get_document_updates(&self, _document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error> {
|
fn get_document_updates(
|
||||||
|
&self,
|
||||||
|
_document_id: &str,
|
||||||
|
_workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,11 +137,16 @@ impl DocumentCloudService for LocalTestDocumentCloudServiceImpl {
|
|||||||
&self,
|
&self,
|
||||||
_document_id: &str,
|
_document_id: &str,
|
||||||
_limit: usize,
|
_limit: usize,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_document_data(&self, _document_id: &str) -> FutureResult<Option<DocumentData>, Error> {
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
_document_id: &str,
|
||||||
|
_workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error> {
|
||||||
FutureResult::new(async move { Ok(None) })
|
FutureResult::new(async move { Ok(None) })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
use anyhow::Error;
|
use anyhow::Error;
|
||||||
use client_api::entity::QueryCollabResult::{Failed, Success};
|
use client_api::entity::QueryCollabResult::{Failed, Success};
|
||||||
use client_api::entity::{BatchQueryCollabParams, QueryCollabParams};
|
use client_api::entity::{BatchQueryCollab, BatchQueryCollabParams, QueryCollabParams};
|
||||||
use client_api::error::ErrorCode::RecordNotFound;
|
use client_api::error::ErrorCode::RecordNotFound;
|
||||||
use collab_entity::CollabType;
|
use collab_entity::CollabType;
|
||||||
use tracing::error;
|
use tracing::error;
|
||||||
@ -22,11 +22,14 @@ where
|
|||||||
&self,
|
&self,
|
||||||
object_id: &str,
|
object_id: &str,
|
||||||
collab_type: CollabType,
|
collab_type: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdate, Error> {
|
) -> FutureResult<CollabObjectUpdate, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let object_id = object_id.to_string();
|
let object_id = object_id.to_string();
|
||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let params = QueryCollabParams {
|
let params = QueryCollabParams {
|
||||||
|
workspace_id,
|
||||||
object_id,
|
object_id,
|
||||||
collab_type,
|
collab_type,
|
||||||
};
|
};
|
||||||
@ -47,20 +50,22 @@ where
|
|||||||
&self,
|
&self,
|
||||||
object_ids: Vec<String>,
|
object_ids: Vec<String>,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
|
workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
let params = BatchQueryCollabParams(
|
let params = BatchQueryCollabParams(
|
||||||
object_ids
|
object_ids
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|object_id| QueryCollabParams {
|
.map(|object_id| BatchQueryCollab {
|
||||||
object_id,
|
object_id,
|
||||||
collab_type: object_ty.clone(),
|
collab_type: object_ty.clone(),
|
||||||
})
|
})
|
||||||
.collect(),
|
.collect(),
|
||||||
);
|
);
|
||||||
let results = client.batch_get_collab(params).await?;
|
let results = client.batch_get_collab(&workspace_id, params).await?;
|
||||||
Ok(
|
Ok(
|
||||||
results
|
results
|
||||||
.0
|
.0
|
||||||
|
@ -16,11 +16,17 @@ impl<T> DocumentCloudService for AFCloudDocumentCloudServiceImpl<T>
|
|||||||
where
|
where
|
||||||
T: AFServer,
|
T: AFServer,
|
||||||
{
|
{
|
||||||
fn get_document_updates(&self, document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error> {
|
fn get_document_updates(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error> {
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let params = QueryCollabParams {
|
let params = QueryCollabParams {
|
||||||
|
workspace_id,
|
||||||
object_id: document_id.to_string(),
|
object_id: document_id.to_string(),
|
||||||
collab_type: CollabType::Document,
|
collab_type: CollabType::Document,
|
||||||
};
|
};
|
||||||
@ -36,15 +42,22 @@ where
|
|||||||
&self,
|
&self,
|
||||||
_document_id: &str,
|
_document_id: &str,
|
||||||
_limit: usize,
|
_limit: usize,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_document_data(&self, document_id: &str) -> FutureResult<Option<DocumentData>, Error> {
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error> {
|
||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
|
let workspace_id = workspace_id.to_string();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let params = QueryCollabParams {
|
let params = QueryCollabParams {
|
||||||
|
workspace_id,
|
||||||
object_id: document_id.clone(),
|
object_id: document_id.clone(),
|
||||||
collab_type: CollabType::Document,
|
collab_type: CollabType::Document,
|
||||||
};
|
};
|
||||||
|
@ -33,10 +33,10 @@ where
|
|||||||
.to_string();
|
.to_string();
|
||||||
let mut buffer = Vec::new();
|
let mut buffer = Vec::new();
|
||||||
file.read_to_end(&mut buffer).await?;
|
file.read_to_end(&mut buffer).await?;
|
||||||
Ok(client.put_file(&object.workspace_id, buffer, mime).await?)
|
Ok(client.put_blob(&object.workspace_id, buffer, mime).await?)
|
||||||
},
|
},
|
||||||
ObjectValue::Bytes { bytes, mime } => {
|
ObjectValue::Bytes { bytes, mime } => {
|
||||||
Ok(client.put_file(&object.workspace_id, bytes, mime).await?)
|
Ok(client.put_blob(&object.workspace_id, bytes, mime).await?)
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -46,7 +46,7 @@ where
|
|||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
client.delete_file(&object_url).await?;
|
client.delete_blob(&object_url).await?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -55,7 +55,7 @@ where
|
|||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
let bytes = client.get_file(&object_url).await?;
|
let bytes = client.get_blob(&object_url).await?;
|
||||||
Ok(bytes)
|
Ok(bytes)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,7 @@ where
|
|||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let params = QueryCollabParams {
|
let params = QueryCollabParams {
|
||||||
object_id: workspace_id.clone(),
|
object_id: workspace_id.clone(),
|
||||||
|
workspace_id: workspace_id.clone(),
|
||||||
collab_type: CollabType::Folder,
|
collab_type: CollabType::Folder,
|
||||||
};
|
};
|
||||||
let updates = vec![try_get_client?
|
let updates = vec![try_get_client?
|
||||||
@ -50,7 +51,8 @@ where
|
|||||||
let try_get_client = self.0.try_get_client();
|
let try_get_client = self.0.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let params = QueryCollabParams {
|
let params = QueryCollabParams {
|
||||||
object_id: workspace_id,
|
object_id: workspace_id.clone(),
|
||||||
|
workspace_id,
|
||||||
collab_type: CollabType::Folder,
|
collab_type: CollabType::Folder,
|
||||||
};
|
};
|
||||||
let update = try_get_client?
|
let update = try_get_client?
|
||||||
|
@ -2,9 +2,10 @@ use std::collections::HashMap;
|
|||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use anyhow::{anyhow, Error};
|
use anyhow::{anyhow, Error};
|
||||||
use client_api::entity::dto::UserUpdateParams;
|
use client_api::entity::dto::auth_dto::UpdateUsernameParams;
|
||||||
|
use client_api::entity::dto::workspace_dto::CreateWorkspaceMember;
|
||||||
use client_api::entity::{
|
use client_api::entity::{
|
||||||
AFUserProfileView, AFWorkspace, AFWorkspaces, InsertCollabParams, OAuthProvider,
|
AFRole, AFUserProfileView, AFWorkspace, AFWorkspaces, InsertCollabParams, OAuthProvider,
|
||||||
};
|
};
|
||||||
use collab_entity::CollabObject;
|
use collab_entity::CollabObject;
|
||||||
|
|
||||||
@ -91,10 +92,11 @@ where
|
|||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
client
|
client
|
||||||
.update(UserUpdateParams {
|
.update_user(UpdateUsernameParams {
|
||||||
name: params.name,
|
name: params.name,
|
||||||
email: params.email,
|
email: params.email,
|
||||||
password: params.password,
|
password: params.password,
|
||||||
|
metadata: None,
|
||||||
})
|
})
|
||||||
.await?;
|
.await?;
|
||||||
Ok(())
|
Ok(())
|
||||||
@ -108,7 +110,7 @@ where
|
|||||||
let try_get_client = self.server.try_get_client();
|
let try_get_client = self.server.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
let profile = client.profile().await?;
|
let profile = client.get_profile().await?;
|
||||||
let encryption_type = encryption_type_from_profile(&profile);
|
let encryption_type = encryption_type_from_profile(&profile);
|
||||||
Ok(Some(UserProfile {
|
Ok(Some(UserProfile {
|
||||||
email: profile.email.unwrap_or("".to_string()),
|
email: profile.email.unwrap_or("".to_string()),
|
||||||
@ -131,7 +133,7 @@ where
|
|||||||
fn get_user_workspaces(&self, _uid: i64) -> FutureResult<Vec<UserWorkspace>, Error> {
|
fn get_user_workspaces(&self, _uid: i64) -> FutureResult<Vec<UserWorkspace>, Error> {
|
||||||
let try_get_client = self.server.try_get_client();
|
let try_get_client = self.server.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
let workspaces = try_get_client?.workspaces().await?;
|
let workspaces = try_get_client?.get_workspaces().await?;
|
||||||
Ok(to_user_workspaces(workspaces)?)
|
Ok(to_user_workspaces(workspaces)?)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -145,7 +147,7 @@ where
|
|||||||
|
|
||||||
// from cloud
|
// from cloud
|
||||||
let client = try_get_client?;
|
let client = try_get_client?;
|
||||||
let profile = client.profile().await?;
|
let profile = client.get_profile().await?;
|
||||||
let client_token = client.access_token()?;
|
let client_token = client.access_token()?;
|
||||||
|
|
||||||
// compare and check
|
// compare and check
|
||||||
@ -167,7 +169,13 @@ where
|
|||||||
let try_get_client = self.server.try_get_client();
|
let try_get_client = self.server.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
try_get_client?
|
try_get_client?
|
||||||
.add_workspace_members(workspace_id.parse()?, vec![user_email])
|
.add_workspace_members(
|
||||||
|
workspace_id,
|
||||||
|
vec![CreateWorkspaceMember {
|
||||||
|
email: user_email,
|
||||||
|
role: AFRole::Member,
|
||||||
|
}],
|
||||||
|
)
|
||||||
.await?;
|
.await?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@ -181,7 +189,7 @@ where
|
|||||||
let try_get_client = self.server.try_get_client();
|
let try_get_client = self.server.try_get_client();
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
try_get_client?
|
try_get_client?
|
||||||
.remove_workspace_members(workspace_id.parse()?, vec![user_email])
|
.remove_workspace_members(workspace_id, vec![user_email])
|
||||||
.await?;
|
.await?;
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
@ -230,7 +238,7 @@ pub async fn user_sign_in_with_url(
|
|||||||
params: AFCloudOAuthParams,
|
params: AFCloudOAuthParams,
|
||||||
) -> Result<AuthResponse, FlowyError> {
|
) -> Result<AuthResponse, FlowyError> {
|
||||||
let is_new_user = client.sign_in_with_url(¶ms.sign_in_url).await?;
|
let is_new_user = client.sign_in_with_url(¶ms.sign_in_url).await?;
|
||||||
let (profile, af_workspaces) = tokio::try_join!(client.profile(), client.workspaces())?;
|
let (profile, af_workspaces) = tokio::try_join!(client.get_profile(), client.get_workspaces())?;
|
||||||
|
|
||||||
let latest_workspace = to_user_workspace(
|
let latest_workspace = to_user_workspace(
|
||||||
af_workspaces
|
af_workspaces
|
||||||
|
@ -13,6 +13,7 @@ impl DatabaseCloudService for LocalServerDatabaseCloudServiceImpl {
|
|||||||
&self,
|
&self,
|
||||||
_object_id: &str,
|
_object_id: &str,
|
||||||
_collab_type: CollabType,
|
_collab_type: CollabType,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdate, Error> {
|
) -> FutureResult<CollabObjectUpdate, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
@ -21,6 +22,7 @@ impl DatabaseCloudService for LocalServerDatabaseCloudServiceImpl {
|
|||||||
&self,
|
&self,
|
||||||
_object_ids: Vec<String>,
|
_object_ids: Vec<String>,
|
||||||
_object_ty: CollabType,
|
_object_ty: CollabType,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
||||||
FutureResult::new(async move { Ok(CollabObjectUpdateByOid::default()) })
|
FutureResult::new(async move { Ok(CollabObjectUpdateByOid::default()) })
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,11 @@ use lib_infra::future::FutureResult;
|
|||||||
pub(crate) struct LocalServerDocumentCloudServiceImpl();
|
pub(crate) struct LocalServerDocumentCloudServiceImpl();
|
||||||
|
|
||||||
impl DocumentCloudService for LocalServerDocumentCloudServiceImpl {
|
impl DocumentCloudService for LocalServerDocumentCloudServiceImpl {
|
||||||
fn get_document_updates(&self, _document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error> {
|
fn get_document_updates(
|
||||||
|
&self,
|
||||||
|
_document_id: &str,
|
||||||
|
_workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -14,11 +18,16 @@ impl DocumentCloudService for LocalServerDocumentCloudServiceImpl {
|
|||||||
&self,
|
&self,
|
||||||
_document_id: &str,
|
_document_id: &str,
|
||||||
_limit: usize,
|
_limit: usize,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
||||||
FutureResult::new(async move { Ok(vec![]) })
|
FutureResult::new(async move { Ok(vec![]) })
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_document_data(&self, _document_id: &str) -> FutureResult<Option<DocumentData>, Error> {
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
_document_id: &str,
|
||||||
|
_workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error> {
|
||||||
FutureResult::new(async move { Ok(None) })
|
FutureResult::new(async move { Ok(None) })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,7 @@ where
|
|||||||
&self,
|
&self,
|
||||||
object_id: &str,
|
object_id: &str,
|
||||||
collab_type: CollabType,
|
collab_type: CollabType,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdate, Error> {
|
) -> FutureResult<CollabObjectUpdate, Error> {
|
||||||
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
||||||
let object_id = object_id.to_string();
|
let object_id = object_id.to_string();
|
||||||
@ -53,6 +54,7 @@ where
|
|||||||
&self,
|
&self,
|
||||||
object_ids: Vec<String>,
|
object_ids: Vec<String>,
|
||||||
object_ty: CollabType,
|
object_ty: CollabType,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
) -> FutureResult<CollabObjectUpdateByOid, Error> {
|
||||||
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
||||||
let (tx, rx) = channel();
|
let (tx, rx) = channel();
|
||||||
|
@ -27,7 +27,11 @@ where
|
|||||||
T: SupabaseServerService,
|
T: SupabaseServerService,
|
||||||
{
|
{
|
||||||
#[tracing::instrument(level = "debug", skip(self))]
|
#[tracing::instrument(level = "debug", skip(self))]
|
||||||
fn get_document_updates(&self, document_id: &str) -> FutureResult<Vec<Vec<u8>>, Error> {
|
fn get_document_updates(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Vec<Vec<u8>>, Error> {
|
||||||
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
let (tx, rx) = channel();
|
let (tx, rx) = channel();
|
||||||
@ -52,6 +56,7 @@ where
|
|||||||
&self,
|
&self,
|
||||||
document_id: &str,
|
document_id: &str,
|
||||||
limit: usize,
|
limit: usize,
|
||||||
|
_workspace_id: &str,
|
||||||
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
) -> FutureResult<Vec<DocumentSnapshot>, Error> {
|
||||||
let try_get_postgrest = self.server.try_get_postgrest();
|
let try_get_postgrest = self.server.try_get_postgrest();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
@ -72,7 +77,11 @@ where
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[tracing::instrument(level = "debug", skip(self))]
|
#[tracing::instrument(level = "debug", skip(self))]
|
||||||
fn get_document_data(&self, document_id: &str) -> FutureResult<Option<DocumentData>, Error> {
|
fn get_document_data(
|
||||||
|
&self,
|
||||||
|
document_id: &str,
|
||||||
|
workspace_id: &str,
|
||||||
|
) -> FutureResult<Option<DocumentData>, Error> {
|
||||||
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
let try_get_postgrest = self.server.try_get_weak_postgrest();
|
||||||
let document_id = document_id.to_string();
|
let document_id = document_id.to_string();
|
||||||
let (tx, rx) = channel();
|
let (tx, rx) = channel();
|
||||||
|
@ -45,7 +45,7 @@ async fn supabase_create_database_test() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let updates_by_oid = database_service
|
let updates_by_oid = database_service
|
||||||
.batch_get_collab_updates(row_ids, CollabType::DatabaseRow)
|
.batch_get_collab_updates(row_ids, CollabType::DatabaseRow, "fake_workspace_id")
|
||||||
.await
|
.await
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ use collab_user::core::MutexUserAwareness;
|
|||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
use tokio::sync::{Mutex, RwLock};
|
use tokio::sync::{Mutex, RwLock};
|
||||||
use tokio_stream::StreamExt;
|
use tokio_stream::StreamExt;
|
||||||
use tracing::{debug, error, info, instrument};
|
use tracing::{debug, error, event, info, instrument};
|
||||||
|
|
||||||
use collab_integrate::collab_builder::AppFlowyCollabBuilder;
|
use collab_integrate::collab_builder::AppFlowyCollabBuilder;
|
||||||
use collab_integrate::RocksCollabDB;
|
use collab_integrate::RocksCollabDB;
|
||||||
@ -347,16 +347,18 @@ impl UserManager {
|
|||||||
UserAwarenessDataSource::Remote
|
UserAwarenessDataSource::Remote
|
||||||
};
|
};
|
||||||
|
|
||||||
debug!("Sign up response: {:?}", response);
|
event!(tracing::Level::DEBUG, "Sign up response: {:?}", response);
|
||||||
if response.is_new_user {
|
if response.is_new_user {
|
||||||
if let Some(old_user) = migration_user {
|
if let Some(old_user) = migration_user {
|
||||||
let new_user = MigrationUser {
|
let new_user = MigrationUser {
|
||||||
user_profile: user_profile.clone(),
|
user_profile: user_profile.clone(),
|
||||||
session: new_session.clone(),
|
session: new_session.clone(),
|
||||||
};
|
};
|
||||||
info!(
|
event!(
|
||||||
|
tracing::Level::INFO,
|
||||||
"Migrate old user data from {:?} to {:?}",
|
"Migrate old user data from {:?} to {:?}",
|
||||||
old_user.user_profile.uid, new_user.user_profile.uid
|
old_user.user_profile.uid,
|
||||||
|
new_user.user_profile.uid
|
||||||
);
|
);
|
||||||
self
|
self
|
||||||
.migrate_local_user_to_cloud(&old_user, &new_user)
|
.migrate_local_user_to_cloud(&old_user, &new_user)
|
||||||
@ -488,6 +490,10 @@ impl UserManager {
|
|||||||
Ok(self.get_session()?.user_id)
|
Ok(self.get_session()?.user_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn workspace_id(&self) -> Result<String, FlowyError> {
|
||||||
|
Ok(self.get_session()?.user_workspace.id)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn token(&self) -> Result<Option<String>, FlowyError> {
|
pub fn token(&self) -> Result<Option<String>, FlowyError> {
|
||||||
Ok(None)
|
Ok(None)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user