Crates.io | ssh-rs |
lib.rs | ssh-rs |
version | 0.5.0 |
source | src |
created_at | 2022-01-05 08:15:07.804097 |
updated_at | 2023-12-26 08:57:54.7066 |
description | In addition to encryption library, pure RUST implementation of SSH-2.0 client protocol |
homepage | |
repository | https://github.com/1148118271/ssh-rs |
max_upload_size | |
id | 508267 |
size | 259,262 |
Rust implementation of ssh2.0 client.
If you encounter any problems in use, welcome issues or PR .
use ssh;
let mut session = ssh::create_session()
.username("ubuntu")
.password("password")
.connect("127.0.0.1:22")
.unwrap();
// pem format key path -> /xxx/xxx/id_rsa
// the content of the keyfile shall begin with
// -----BEGIN RSA PRIVATE KEY----- / -----BEGIN OPENSSH PRIVATE KEY-----
// and end with
// -----END RSA PRIVATE KEY----- / -----END OPENSSH PRIVATE KEY-----
// simply generated by `ssh-keygen -t rsa -m PEM -b 4096`
use ssh;
let mut session = ssh::create_session()
.username("ubuntu")
.private_key_path("./id_rsa")
.connect("127.0.0.1:22")
.unwrap();
// pem format key string:
// -----BEGIN RSA PRIVATE KEY----- / -----BEGIN OPENSSH PRIVATE KEY-----
// and end with
// -----END RSA PRIVATE KEY----- / -----END OPENSSH PRIVATE KEY-----
use ssh;
let mut session = ssh::create_session()
.username("ubuntu")
.private_key("rsa_string")
.connect("127.0.0.1:22")
.unwrap();
use ssh;
let mut session = ssh::create_session()
.username("username")
.password("password")
.private_key_path("/path/to/rsa")
.connect("127.0.0.1:22")
.unwrap();
log
compatible tracing
for logging functionalityuse tracing::Level;
use tracing_subscriber::FmtSubscriber;
// this will generate some basic event logs
// a builder for `FmtSubscriber`.
let subscriber = FmtSubscriber::builder()
// all spans/events with a level higher than INFO (e.g, info, warn, etc.)
// will be written to stdout.
.with_max_level(Level::INFO)
// completes the builder.
.finish();
tracing::subscriber::set_global_default(subscriber).expect("setting default subscriber failed");
use ssh;
let _listener = TcpListener::bind("127.0.0.1:7777").unwrap();
match ssh::create_session()
.username("ubuntu")
.password("password")
.private_key_path("./id_rsa")
.timeout(Some(std::time::Duration::from_secs(5)))
.connect("127.0.0.1:7777")
{
Err(e) => println!("Got error {}", e),
_ => unreachable!(),
}
curve25519-sha256
ecdh-sha2-nistp256
diffie-hellman-group14-sha256
diffie-hellman-group14-sha1
diffie-hellman-group1-sha1
(behind feature "deprecated-dh-group1-sha1")ssh-ed25519
rsa-sha2-256
rsa-sha2-512
rsa-sha
(behind feature "deprecated-rsa-sha1")
ssh-dss
(behind feature "deprecated-dss-sha1")
chacha20-poly1305@openssh.com
aes128-ctr
aes192-ctr
aes256-ctr
aes128-cbc
(behind feature "deprecated-aes-cbc")aes192-cbc
(behind feature "deprecated-aes-cbc")aes256-cbc
(behind feature "deprecated-aes-cbc")3des-cbc
(behind feature "deprecated-des-cbc")hmac-sha2-256
hmac-sha2-512
hmac-sha1
none
zlib@openssh.com
zlib
(behind feature "zlib")