{"id":13747401,"url":"https://github.com/net-ssh/net-ssh","last_synced_at":"2026-02-19T20:31:35.625Z","repository":{"id":596166,"uuid":"231339","full_name":"net-ssh/net-ssh","owner":"net-ssh","description":"Pure Ruby implementation of an SSH (protocol 2) client","archived":false,"fork":false,"pushed_at":"2025-12-08T13:42:30.000Z","size":7594,"stargazers_count":1004,"open_issues_count":112,"forks_count":466,"subscribers_count":39,"default_branch":"master","last_synced_at":"2026-02-12T22:42:27.938Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"http://net-ssh.github.io/net-ssh","language":"Ruby","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/net-ssh.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGES.txt","contributing":null,"funding":".github/FUNDING.yml","license":"LICENSE.txt","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":"support/ssh_tunnel_bug.rb","governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":["mfazekas"]}},"created_at":"2009-06-19T12:23:42.000Z","updated_at":"2026-02-11T04:26:59.000Z","dependencies_parsed_at":"2023-07-07T11:33:32.937Z","dependency_job_id":"dcbcc0f8-5b2b-42ac-ad65-92831da20fa4","html_url":"https://github.com/net-ssh/net-ssh","commit_stats":{"total_commits":1234,"total_committers":222,"mean_commits":5.558558558558558,"dds":0.7001620745542949,"last_synced_commit":"d9549e4226dc3aed12efcca24a8b6d349143f398"},"previous_names":[],"tags_count":145,"template":false,"template_full_name":null,"purl":"pkg:github/net-ssh/net-ssh","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/net-ssh%2Fnet-ssh","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/net-ssh%2Fnet-ssh/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/net-ssh%2Fnet-ssh/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/net-ssh%2Fnet-ssh/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/net-ssh","download_url":"https://codeload.github.com/net-ssh/net-ssh/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/net-ssh%2Fnet-ssh/sbom","scorecard":{"id":45746,"data":{"date":"2025-08-04","repo":{"name":"github.com/net-ssh/net-ssh","commit":"fac7a716d2d569a34266212f25b0a08649f39f32"},"scorecard":{"version":"v5.2.1-28-gc1d103a9","commit":"c1d103a9bb9f635ec7260bf9aa0699466fa4be0e"},"score":4.2,"checks":[{"name":"Security-Policy","score":10,"reason":"security policy file detected","details":["Info: security policy file detected: SECURITY.md:1","Info: Found linked content: SECURITY.md:1","Info: Found disclosure, vulnerability, and/or timelines in security policy: SECURITY.md:1","Info: Found text in security policy: SECURITY.md:1"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#security-policy"}},{"name":"Dangerous-Workflow","score":10,"reason":"no dangerous workflow patterns detected","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#dangerous-workflow"}},{"name":"Maintained","score":0,"reason":"1 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#maintained"}},{"name":"Code-Review","score":2,"reason":"Found 6/22 approved changesets -- score normalized to 2","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#packaging"}},{"name":"License","score":10,"reason":"license file detected","details":["Info: project has a license file: LICENSE.txt:0","Info: FSF or OSI recognized license: MIT License: LICENSE.txt:0"],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#license"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#cii-best-practices"}},{"name":"Token-Permissions","score":0,"reason":"detected GitHub workflow tokens with excessive permissions","details":["Warn: no topLevel permission defined: .github/workflows/ci-with-docker.yml:1","Warn: no topLevel permission defined: .github/workflows/ci.yml:1","Warn: no topLevel permission defined: .github/workflows/rubocop.yml:1","Info: no jobLevel write permissions found"],"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#token-permissions"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#fuzzing"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#binary-artifacts"}},{"name":"Vulnerabilities","score":10,"reason":"0 existing vulnerabilities detected","details":null,"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#vulnerabilities"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#branch-protection"}},{"name":"Pinned-Dependencies","score":0,"reason":"dependency not pinned by hash detected -- score normalized to 0","details":["Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-with-docker.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci-with-docker.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci-with-docker.yml:38: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci-with-docker.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:12: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/ci.yml:15: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:19: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:24: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/ci.yml:33: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/ci.yml/master?enable=pin","Warn: GitHub-owned GitHubAction not pinned by hash: .github/workflows/rubocop.yml:9: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/rubocop.yml/master?enable=pin","Warn: third-party GitHubAction not pinned by hash: .github/workflows/rubocop.yml:11: update your workflow using https://app.stepsecurity.io/secureworkflow/net-ssh/net-ssh/rubocop.yml/master?enable=pin","Warn: containerImage not pinned by hash: Dockerfile:2","Warn: containerImage not pinned by hash: Dockerfile.openssl3:1: pin your Docker image by updating ubuntu:22.04 to ubuntu:22.04@sha256:1ec65b2719518e27d4d25f104d93f9fac60dc437f81452302406825c46fcc9cb","Warn: pipCommand not pinned by hash: .github/workflows/ci.yml:62","Warn: pipCommand not pinned by hash: .github/workflows/ci.yml:63","Info:   0 out of   7 GitHub-owned GitHubAction dependencies pinned","Info:   0 out of   2 third-party GitHubAction dependencies pinned","Info:   0 out of   2 containerImage dependencies pinned","Info:   0 out of   2 pipCommand dependencies pinned"],"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#pinned-dependencies"}},{"name":"SAST","score":0,"reason":"SAST tool is not run on all commits -- score normalized to 0","details":["Warn: 0 commits out of 14 are checked with a SAST tool"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/c1d103a9bb9f635ec7260bf9aa0699466fa4be0e/docs/checks.md#sast"}}]},"last_synced_at":"2025-08-14T22:43:11.361Z","repository_id":596166,"created_at":"2025-08-14T22:43:11.361Z","updated_at":"2025-08-14T22:43:11.361Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29494330,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-16T00:00:57.352Z","status":"ssl_error","status_checked_at":"2026-02-15T23:56:34.338Z","response_time":118,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-08-03T06:01:27.631Z","updated_at":"2026-02-19T20:31:35.608Z","avatar_url":"https://github.com/net-ssh.png","language":"Ruby","readme":"[![Gem Version](https://badge.fury.io/rb/net-ssh.svg)](https://badge.fury.io/rb/net-ssh)\n[![Join the chat at https://gitter.im/net-ssh/net-ssh](https://badges.gitter.im/net-ssh/net-ssh.svg)](https://gitter.im/net-ssh/net-ssh?utm_source=badge\u0026utm_medium=badge\u0026utm_campaign=pr-badge\u0026utm_content=badge)\n[![Build status](https://github.com/net-ssh/net-ssh/actions/workflows/ci.yml/badge.svg)](https://github.com/net-ssh/net-ssh/actions/workflows/ci.yml)\n[![Coverage status](https://codecov.io/gh/net-ssh/net-ssh/branch/master/graph/badge.svg)](https://codecov.io/gh/net-ssh/net-ssh)\n[![Backers on Open Collective](https://opencollective.com/net-ssh/backers/badge.svg)](#backers])\n[![Sponsors on Open Collective](https://opencollective.com/net-ssh/sponsors/badge.svg)](#sponsors)\n\n# Net::SSH 7.x\n\n* Docs: http://net-ssh.github.io/net-ssh\n* Issues: https://github.com/net-ssh/net-ssh/issues\n* Codes: https://github.com/net-ssh/net-ssh\n* Email: net-ssh@solutious.com\n\n*As of v2.6.4, all gem releases are signed. See [INSTALL](#install).*\n\n## DESCRIPTION:\n\nNet::SSH is a pure-Ruby implementation of the SSH2 client protocol.\nIt allows you to write programs that invoke and interact with processes on remote servers, via SSH2.\n\n## FEATURES:\n\n* Execute processes on remote servers and capture their output\n* Run multiple processes in parallel over a single SSH connection\n* Support for SSH subsystems\n* Forward local and remote ports via an SSH connection\n\n## Supported Algorithms\n\nNet::SSH 6.0 disables by default the usage of weak algorithms.\nWe strongly recommend that you install a servers's version that supports the latest algorithms.\n\nIt is possible to return to the previous behavior by adding the option : `append_all_supported_algorithms: true`\n\nUnsecure algoritms will definitely be removed in Net::SSH 8.*.\n\n### Host Keys\n\n| Name                 | Support               | Details  |\n|----------------------|-----------------------|----------|\n| ssh-rsa              | OK                    |          |\n| ssh-ed25519          | OK                    | Require the gem `ed25519` |\n| ecdsa-sha2-nistp521  | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| ecdsa-sha2-nistp384  | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| ecdsa-sha2-nistp256  | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| ssh-dss              | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n\n### Key Exchange\n\n| Name                                 | Support               | Details  |\n|--------------------------------------|-----------------------|----------|\n| curve25519-sha256                    | OK                    | Require the gem `x25519` |\n| ecdh-sha2-nistp521                   | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| ecdh-sha2-nistp384                   | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| ecdh-sha2-nistp256                   | OK                    | [using weak elliptic curves](https://safecurves.cr.yp.to/) |\n| diffie-hellman-group1-sha1           | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| diffie-hellman-group14-sha1          | OK                    |          |\n| diffie-hellman-group-exchange-sha1   | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| diffie-hellman-group-exchange-sha256 | OK                    |          |\n\n### Encryption algorithms (ciphers)\n\n| Name                                 | Support               | Details  |\n|--------------------------------------|-----------------------|----------|\n| aes256-ctr / aes192-ctr / aes128-ctr | OK                    |          |\n| chacha20-poly1305@openssh.com        | OK.                   | Requires the gem `rbnacl` |\n| aes256-cbc / aes192-cbc / aes128-cbc | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| rijndael-cbc@lysator.liu.se          | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| blowfish-ctr blowfish-cbc            | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| cast128-ctr cast128-cbc              | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| 3des-ctr 3des-cbc                    | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| idea-cbc                             | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| none                                 | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n\n### Message Authentication Code algorithms\n\n| Name                 | Support               | Details  |\n|----------------------|-----------------------|----------|\n| hmac-sha2-512-etm    | OK                    |          |\n| hmac-sha2-256-etm    | OK                    |          |\n| hmac-sha2-512        | OK                    |          |\n| hmac-sha2-256        | OK                    |          |\n| hmac-sha2-512-96     | Deprecated in 6.0     | removed from the specification, will be removed in 8.0 |\n| hmac-sha2-256-96     | Deprecated in 6.0     | removed from the specification, will be removed in 8.0 |\n| hmac-sha1            | OK                    | for backward compatibility      |\n| hmac-sha1-96         | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| hmac-ripemd160       | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| hmac-md5             | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| hmac-md5-96          | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n| none                 | Deprecated in 6.0     | unsecure, will be removed in 8.0 |\n\n## SYNOPSIS:\n\nIn a nutshell:\n\n```ruby\nrequire 'net/ssh'\n\nNet::SSH.start('host', 'user', password: \"password\") do |ssh|\n\n# capture all stderr and stdout output from a remote process\noutput = ssh.exec!(\"hostname\")\nputs output\n\n# capture only stdout matching a particular pattern\nstdout = \"\"\nssh.exec!(\"ls -l /home/jamis\") do |channel, stream, data|\n  stdout \u003c\u003c data if stream == :stdout \u0026\u0026 /foo/.match(data)\nend\nputs stdout\n\n# run multiple processes in parallel to completion\nssh.exec \"sed ...\"\nssh.exec \"awk ...\"\nssh.exec \"rm -rf ...\"\nssh.loop\n\n# open a new channel and configure a minimal set of callbacks, then run\n# the event loop until the channel finishes (closes)\nchannel = ssh.open_channel do |ch|\n  ch.exec \"/usr/local/bin/ruby /path/to/file.rb\" do |ch, success|\n    raise \"could not execute command\" unless success\n\n    # \"on_data\" is called when the process writes something to stdout\n    ch.on_data do |c, data|\n      $stdout.print data\n    end\n\n    # \"on_extended_data\" is called when the process writes something to stderr\n    ch.on_extended_data do |c, type, data|\n      $stderr.print data\n    end\n\n    ch.on_close { puts \"done!\" }\n  end\nend\n\nchannel.wait\n\n# forward connections on local port 1234 to port 80 of www.capify.org\nssh.forward.local(1234, \"www.capify.org\", 80)\nssh.loop { true }\nend\n```\n\nSee Net::SSH for more documentation, and links to further information.\n\n## REQUIREMENTS:\n\nThe only requirement you might be missing is the OpenSSL bindings for Ruby with a version greather than `1.0.1`.\nThese are built by default on most platforms, but you can verify that they're built and installed on your system by running the following command line:\n\n```sh\nruby -ropenssl -e 'puts OpenSSL::OPENSSL_VERSION'\n```\n\nIf that spits out something like `OpenSSL 1.0.1 14 Mar 2012`, then you're set.\nIf you get an error, then you'll need to see about rebuilding ruby with OpenSSL support,\nor (if your platform supports it) installing the OpenSSL bindings separately.\n\n## INSTALL:\n\n```sh\ngem install net-ssh # might need sudo privileges\n```\n\nNOTE: If you are running on jruby on windows you need to install `jruby-pageant` manually\n(gemspec doesn't allow for platform specific dependencies at gem installation time).\n\nHowever, in order to be sure the code you're installing hasn't been tampered with,\nit's recommended that you verify the [signature](http://docs.rubygems.org/read/chapter/21).\n To do this, you need to add my public key as a trusted certificate (you only need to do this once):\n\n```sh\n# Add the public key as a trusted certificate\n# (You only need to do this once)\ncurl -O https://raw.githubusercontent.com/net-ssh/net-ssh/master/net-ssh-public_cert.pem\ngem cert --add net-ssh-public_cert.pem\n```\n\nThen, when install the gem, do so with high security:\n\n```sh\ngem install net-ssh -P HighSecurity\n```\n\nIf you don't add the public key, you'll see an error like \"Couldn't verify data signature\".\nIf you're still having trouble let me know and I'll give you a hand.\n\nFor ed25519 public key auth support your bundle file should contain `ed25519`, `bcrypt_pbkdf` dependencies.\n\n```sh\ngem install ed25519\ngem install bcrypt_pbkdf\n```\n\nFor curve25519-sha256 kex exchange support your bundle file should contain `x25519` dependency.\n\n## RUBY SUPPORT\n\n* See [net-ssh.gemspec](https://github.com/net-ssh/net-ssh/blob/master/net-ssh.gemspec) for current versions ruby requirements\n\n## RUNNING TESTS\n\nIf you want to run the tests or use any of the Rake tasks, you'll need Mocha and\nother dependencies listed in Gemfile\n\nRun the test suite from the net-ssh directory with the following command:\n\n```sh\nbundle exec rake test\n```\n\nNOTE : you can run test on all ruby versions with docker :\n\n```\ndocker-compose up --build\n```\n\nRun a single test file like this:\n\n```sh\nruby -Ilib -Itest test/transport/test_server_version.rb\n```\n\nTo run integration tests see [here](test/integration/README.md)\n\n### BUILDING GEM\n\n```sh\nrake build\n```\n\n### GEM SIGNING (for maintainers)\n\nIf you have the net-ssh private signing key, you will be able to create signed release builds. Make sure the private key path matches the `signing_key` path set in `net-ssh.gemspec` and tell rake to sign the gem by setting the `NET_SSH_BUILDGEM_SIGNED` flag:\n\n```sh\nNET_SSH_BUILDGEM_SIGNED=true rake build\n```\n\nFor time to time, the public certificate associated to the private key needs to be renewed. You can do this with the following command:\n\n```sh\ngem cert --build netssh@solutious.com --private-key path/2/net-ssh-private_key.pem\nmv gem-public_cert.pem net-ssh-public_cert.pem\ngem cert --add net-ssh-public_cert.pem\n```\n\nor `rake cert:update_public_when_expired`\n\n## Security contact information\n\nSee [SECURITY.md](SECURITY.md)\n\n## CREDITS\n\n### Contributors\n\nThis project exists thanks to all the people who contribute.\n\n[![contributors](https://opencollective.com/net-ssh/contributors.svg?width=890\u0026button=false)](graphs/contributors)\n\n### Backers\n\nThank you to all our backers! 🙏 [Become a backer](https://opencollective.com/net-ssh#backer)\n\n[![backers](https://opencollective.com/net-ssh/backers.svg?width=890)](https://opencollective.com/net-ssh#backers)\n\n### Sponsors\n\nSupport this project by becoming a sponsor. Your logo will show up here with a link to your website. [Become a sponsor](https://opencollective.com/net-ssh#sponsor)\n\n[![Sponsor](https://opencollective.com/net-ssh/sponsor/0/avatar.svg)](https://opencollective.com/net-ssh/sponsor/0/website)\n\n[\u003cimg src=\"https://github.com/net-ssh/net-ssh/assets/52435/9690bf3e-34ea-4c52-8aea-1cc4cb5bcb6d\" width=\"320\"\u003e](https://ubicloud.com)\n\n\n## LICENSE:\n\n(The MIT License)\n\nCopyright (c) 2008 Jamis Buck\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n'Software'), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.\nIN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY\nCLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,\nTORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE\nSOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n","funding_links":["https://github.com/sponsors/mfazekas","https://opencollective.com/net-ssh"],"categories":["Happy Exploring 🤘","Ruby","Libraries"],"sub_categories":["Alternatives to *SSH*"],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnet-ssh%2Fnet-ssh","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fnet-ssh%2Fnet-ssh","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnet-ssh%2Fnet-ssh/lists"}