--- title: Home layout: home --- # {{ site.title }} {: .fs-9} {{ site.description }} {: .fs-6 .fw-300 .text-grey-dk-200} [Get started]({% link tutorial/index.md %}){: .btn .btn-primary } [API docs][docs-rs]{: .btn .ml-4 } [Github][github]{: .btn .ml-4 } [Crate][crates-io]{: .btn .ml-4 } [docs-rs]: https://docs.rs/makiko/latest/makiko [github]: https://github.com/honzasp/makiko [crates-io]: https://crates.io/crates/makiko ## Features - SSH protocol 2 - Authentication methods: publickey, password, none - Shell/exec sessions - Remote and local tunnels - Raw SSH channels (low-level API) - Ciphers: chacha20-poly1305, aes128-gcm, aes256-gcm, aes128-ctr, aes192-ctr, aes256-ctr, aes128-cbc\*, aes192-cbc\*, aes256-cbc\*, 3des-cbc\* - MACs: hmac-sha2-256-etm, hmac-sha2-512-etm, hmac-sha2-256, hmac-sha2-512, hmac-sha1-etm\*, hmac-sha1\* - Public key algorithms: ssh-ed25519, rsa-sha2-256, rsa-sha2-512, ecdsa-sha2-nistp256\*, ecdsa-sha2-nistp384\*, ssh-rsa\* - Key exchange algorithms: curve25519-sha256, diffie-hellman-group14-sha1\*, diffie-hellman-group14-sha256\*, diffie-hellman-group16-sha512\*, diffie-hellmann-group18-sha512\*, diffie-hellman-group1-sha1\*\* - Crypto from [Rust Crypto][rust-crypto] - Use your own sockets, spawn your own tasks - Uses [Tokio][tokio] interfaces (but does not depend on the Tokio runtime) - Rust all the way down: no dependency on non-Rust libraries, direct or indirect [rust-crypto]: https://github.com/RustCrypto [tokio]: https://tokio.rs/ \* Algorithms marked with an asterisk are not enabled by default {: .text-grey-dk-200} \*\* Algorithms marked two asterisks are only available with feature insecure-crypto {: .text-grey-dk-200} ## Low-level Makiko gives you a lot of control over the SSH connection, it is meant to be a building block for libraries and advanced applications. {: .warning } Makiko and most of the cryptography crates from [Rust Crypto][rust-crypto] that Makiko uses have not yet been audited by a trusted third party. Use at your own risk!