This service can be used to:
- create_dir
- stat
- read
- write
- delete
- list
- copy
- rename
-
presign
endpoint: Set the endpoint for connection. The format is same asopenssh, using either[user@]hostnameorssh://[user@]hostname[:port]. A username or port that is specified in the endpoint overrides the one set in the builder (but does not change the builder).root: Set the work directory for backend. It uses the default directory set by the remotesftp-serveras defaultuser: Set the login userkey: Set the public key for loginknown_hosts_strategy: Set the strategy for known hosts, default toStrictacquire_timeout: Set how long to wait for an already-saturated SFTP connection pool, default to10sconnect_timeout: Set the SSH connect timeout, default to10senable_copy: Set whether the remote server has copy-file extension
For security reasons, it doesn't support password login, you can use public key or ssh-copy-id instead.
You can refer to [SftpBuilder]'s docs for more information
use anyhow::Result;
use opendal_service_sftp::Sftp;
use opendal_core::Operator;
#[tokio::main]
async fn main() -> Result<()> {
let mut builder = Sftp::default()
.endpoint("127.0.0.1")
.user("test")
.key("test_key");
let op: Operator = Operator::new(builder)?.finish();
Ok(())
}