#[non_exhaustive]pub enum Scheme {
Show 67 variants
AliyunDrive,
Atomicserver,
Azblob,
Azdls,
B2,
Compfs,
Seafile,
Upyun,
VercelBlob,
YandexDisk,
Pcloud,
Koofr,
Chainsafe,
Cacache,
CloudflareKv,
Cos,
D1,
Dashmap,
Etcd,
Foundationdb,
Dbfs,
Fs,
Ftp,
Gcs,
Ghac,
Hdfs,
Http,
Huggingface,
Alluxio,
Ipfs,
Ipmfs,
Icloud,
Memcached,
Memory,
MiniMoka,
Moka,
Monoiofs,
Obs,
Onedrive,
Gdrive,
Dropbox,
Oss,
Persy,
Redis,
Postgresql,
Libsql,
Mysql,
Sqlite,
Rocksdb,
S3,
Sftp,
Sled,
Supabase,
Swift,
VercelArtifacts,
Webdav,
Webhdfs,
Redb,
Tikv,
Azfile,
Mongodb,
Gridfs,
Github,
HdfsNative,
Surrealdb,
Lakefs,
Custom(&'static str),
}
Expand description
Services that OpenDAL supports
§Notes
- Scheme is
non_exhaustive
, new variant COULD be added at any time. - New variant SHOULD be added in alphabet orders,
- Users MUST NOT relay on its order.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
AliyunDrive
aliyun_drive: Aliyun Drive services.
Atomicserver
atomicserver: Atomicserver services.
Azblob
azblob: Azure Storage Blob services.
Azdls
Azdls: Azure Data Lake Storage Gen2.
B2
B2: Backblaze B2 Services.
Compfs
Compfs: Compio fs Services.
Seafile
Seafile: Seafile Services.
Upyun
Upyun: Upyun Services.
VercelBlob
VercelBlob: VercelBlob Services.
YandexDisk
YandexDisk: YandexDisk Services.
Pcloud
Pcloud: Pcloud Services.
Koofr
Koofr: Koofr Services.
Chainsafe
Chainsafe: Chainsafe Services.
Cacache
cacache: cacache backend support.
CloudflareKv
cloudflare-kv: Cloudflare KV services.
Cos
cos: Tencent Cloud Object Storage services.
D1
d1: D1 services
Dashmap
dashmap: dashmap backend support.
Etcd
etcd: Etcd Services
Foundationdb
foundationdb: Foundationdb services.
Dbfs
dbfs: DBFS backend support.
Fs
fs: POSIX-like file system.
Ftp
ftp: FTP backend.
Gcs
gcs: Google Cloud Storage backend.
Ghac
ghac: GitHub Action Cache services.
Hdfs
hdfs: Hadoop Distributed File System.
Http
http: HTTP backend.
Huggingface
huggingface: Huggingface services.
Alluxio
alluxio: Alluxio services.
Ipfs
ipmfs: IPFS HTTP Gateway
Ipmfs
ipmfs: IPFS mutable file system
Icloud
icloud: APPLE icloud services.
Memcached
memcached: Memcached service support.
Memory
memory: In memory backend support.
MiniMoka
mini-moka: Mini Moka backend support.
Moka
moka: moka backend support.
Monoiofs
monoiofs: monoio fs services.
Obs
obs: Huawei Cloud OBS services.
Onedrive
onedrive: Microsoft OneDrive services.
Gdrive
gdrive: GoogleDrive services.
Dropbox
dropbox: Dropbox services.
Oss
oss: Aliyun Object Storage Services
Persy
persy: persy backend support.
Redis
redis: Redis services
Postgresql
postgresql: Postgresql services
Libsql
libsql: Libsql services
Mysql
mysql: Mysql services
Sqlite
sqlite: Sqlite services
Rocksdb
rocksdb: RocksDB services
S3
s3: AWS S3 alike services.
Sftp
sftp: SFTP services
Sled
sled: Sled services
Supabase
Supabase: Supabase storage service
Swift
swift: Swift backend support.
VercelArtifacts
Vercel Artifacts: Vercel Artifacts service, as known as Vercel Remote Caching.
Webdav
webdav: WebDAV support.
Webhdfs
webhdfs: WebHDFS RESTful API Services
Redb
redb: Redb Services
Tikv
tikv: Tikv Services
Azfile
azfile: Azfile Services
Mongodb
mongodb: MongoDB Services
Gridfs
gridfs: MongoDB Gridfs Services
Github
Github Contents: Github contents support.
HdfsNative
Native HDFS: Hdfs Native service, using rust hdfs-native client for hdfs
Surrealdb
surrealdb: Surrealdb Services
Lakefs
lakefs: LakeFS Services
Custom(&'static str)
Custom that allow users to implement services outside of OpenDAL.
§NOTE
- Custom must not overwrite any existing services name.
- Custom must be in lower case.
Implementations§
source§impl Scheme
impl Scheme
sourcepub fn into_static(self) -> &'static str
pub fn into_static(self) -> &'static str
Convert self into static str.
sourcepub fn enabled() -> HashSet<Scheme>
pub fn enabled() -> HashSet<Scheme>
Get all enabled schemes.
OpenDAL could be compiled with different features, which will enable different schemes. This function returns all enabled schemes so users can make decisions based on it.
§Examples
use opendal::Scheme;
let enabled_schemes = Scheme::enabled();
if !enabled_schemes.contains(&Scheme::Memory) {
panic!("s3 support is not enabled")
}
Trait Implementations§
source§impl PartialEq for Scheme
impl PartialEq for Scheme
impl Copy for Scheme
impl Eq for Scheme
impl StructuralPartialEq for Scheme
Auto Trait Implementations§
impl Freeze for Scheme
impl RefUnwindSafe for Scheme
impl Send for Scheme
impl Sync for Scheme
impl Unpin for Scheme
impl UnwindSafe for Scheme
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.