| commit | 7963d0883fe9310f0c276e0b2f96c84c834233e4 | [log] [tgz] |
|---|---|---|
| author | Xuanwo <github@xuanwo.io> | Tue Dec 20 13:44:43 2022 +0800 |
| committer | GitHub <noreply@github.com> | Tue Dec 20 13:44:43 2022 +0800 |
| tree | 062c371966a50c586eff7b43927de578a1f68d0d | |
| parent | 31e2aacb2bfd11835db2a43242a52a09173d77eb [diff] |
feat(services/s3,gcs): Allow accepting signer directly (#1087) * feat(services/s3,gcs): Allow accepting signer directly Signed-off-by: Xuanwo <github@xuanwo.io> * fix build Signed-off-by: Xuanwo <github@xuanwo.io> Signed-off-by: Xuanwo <github@xuanwo.io>
Open Data Access Layer: Access data freely, painlessly, and efficiently
You may be looking for:
Access data freely
Access data painlessly
LayersAccess data efficiently
metadata callsuse anyhow::Result; use futures::StreamExt; use futures::TryStreamExt; use opendal::ObjectStreamer; use opendal::Object; use opendal::ObjectMetadata; use opendal::ObjectMode; use opendal::Operator; use opendal::Scheme; #[tokio::main] async fn main() -> Result<()> { // Init Operator let op = Operator::from_env(Scheme::Fs)?; // Create object handler. let o = op.object("test_file"); // Write data info object; o.write("Hello, World!").await?; // Read data from object; let bs = o.read().await?; // Read range from object; let bs = o.range_read(1..=11).await?; // Get object's path let name = o.name(); let path = o.path(); // Fetch more meta about object. let meta = o.metadata().await?; let mode = meta.mode(); let length = meta.content_length(); let content_md5 = meta.content_md5(); let etag = meta.etag(); // Delete object. o.delete().await?; // List dir object. let o = op.object("test_dir/"); let mut os = o.list().await?; while let Some(entry) = os.try_next().await? { let path = entry.path(); let mode = entry.mode().await?; } Ok(()) }
More examples could be found at Documentation.
Check out the CONTRIBUTING.md guide for more details on getting started with contributing to this project.
Submit issues for bug report or asking questions in discussion.