]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - crypto/openssh/README.md
MFV: Restore the ability to process files from stdin immediately.
[FreeBSD/FreeBSD.git] / crypto / openssh / README.md
1 # Portable OpenSSH
2
3 [![C/C++ CI](https://github.com/openssh/openssh-portable/actions/workflows/c-cpp.yml/badge.svg)](https://github.com/openssh/openssh-portable/actions/workflows/c-cpp.yml)
4 [![Fuzzing Status](https://oss-fuzz-build-logs.storage.googleapis.com/badges/openssh.svg)](https://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened&can=1&q=proj:openssh)
5
6 OpenSSH is a complete implementation of the SSH protocol (version 2) for secure remote login, command execution and file transfer. It includes a client ``ssh`` and server ``sshd``, file transfer utilities ``scp`` and ``sftp`` as well as tools for key generation (``ssh-keygen``), run-time key storage (``ssh-agent``) and a number of supporting programs.
7
8 This is a port of OpenBSD's [OpenSSH](https://openssh.com) to most Unix-like operating systems, including Linux, OS X and Cygwin. Portable OpenSSH polyfills OpenBSD APIs that are not available elsewhere, adds sshd sandboxing for more operating systems and includes support for OS-native authentication and auditing (e.g. using PAM).
9
10 ## Documentation
11
12 The official documentation for OpenSSH are the man pages for each tool:
13
14 * [ssh(1)](https://man.openbsd.org/ssh.1)
15 * [sshd(8)](https://man.openbsd.org/sshd.8)
16 * [ssh-keygen(1)](https://man.openbsd.org/ssh-keygen.1)
17 * [ssh-agent(1)](https://man.openbsd.org/ssh-agent.1)
18 * [scp(1)](https://man.openbsd.org/scp.1)
19 * [sftp(1)](https://man.openbsd.org/sftp.1)
20 * [ssh-keyscan(8)](https://man.openbsd.org/ssh-keyscan.8)
21 * [sftp-server(8)](https://man.openbsd.org/sftp-server.8)
22
23 ## Stable Releases
24
25 Stable release tarballs are available from a number of [download mirrors](https://www.openssh.com/portable.html#downloads). We recommend the use of a stable release for most users. Please read the [release notes](https://www.openssh.com/releasenotes.html) for details of recent changes and potential incompatibilities.
26
27 ## Building Portable OpenSSH
28
29 ### Dependencies
30
31 Portable OpenSSH is built using autoconf and make. It requires a working C compiler, standard library and headers.
32
33 ``libcrypto`` from either [LibreSSL](https://www.libressl.org/) or [OpenSSL](https://www.openssl.org) may also be used.  OpenSSH may be built without either of these, but the resulting binaries will have only a subset of the cryptographic algorithms normally available.
34
35 [zlib](https://www.zlib.net/) is optional; without it transport compression is not supported.
36
37 FIDO security token support needs [libfido2](https://github.com/Yubico/libfido2) and its dependencies.
38
39 In addition, certain platforms and build-time options may require additional dependencies; see README.platform for details about your platform.
40
41 ### Building a release
42
43 Releases include a pre-built copy of the ``configure`` script and may be built using:
44
45 ```
46 tar zxvf openssh-X.YpZ.tar.gz
47 cd openssh
48 ./configure # [options]
49 make && make tests
50 ```
51
52 See the [Build-time Customisation](#build-time-customisation) section below for configure options. If you plan on installing OpenSSH to your system, then you will usually want to specify destination paths.
53
54 ### Building from git
55
56 If building from git, you'll need [autoconf](https://www.gnu.org/software/autoconf/) installed to build the ``configure`` script. The following commands will check out and build portable OpenSSH from git:
57
58 ```
59 git clone https://github.com/openssh/openssh-portable # or https://anongit.mindrot.org/openssh.git
60 cd openssh-portable
61 autoreconf
62 ./configure
63 make && make tests
64 ```
65
66 ### Build-time Customisation
67
68 There are many build-time customisation options available. All Autoconf destination path flags (e.g. ``--prefix``) are supported (and are usually required if you want to install OpenSSH).
69
70 For a full list of available flags, run ``./configure --help`` but a few of the more frequently-used ones are described below. Some of these flags will require additional libraries and/or headers be installed.
71
72 Flag | Meaning
73 --- | ---
74 ``--with-pam`` | Enable [PAM](https://en.wikipedia.org/wiki/Pluggable_authentication_module) support. [OpenPAM](https://www.openpam.org/), [Linux PAM](http://www.linux-pam.org/) and Solaris PAM are supported.
75 ``--with-libedit`` | Enable [libedit](https://www.thrysoee.dk/editline/) support for sftp.
76 ``--with-kerberos5`` | Enable Kerberos/GSSAPI support. Both [Heimdal](https://www.h5l.org/) and [MIT](https://web.mit.edu/kerberos/) Kerberos implementations are supported.
77 ``--with-selinux`` | Enable [SELinux](https://en.wikipedia.org/wiki/Security-Enhanced_Linux) support.
78 ``--with-security-key-builtin`` | Include built-in support for U2F/FIDO2 security keys. This requires [libfido2](https://github.com/Yubico/libfido2) be installed.
79
80 ## Development
81
82 Portable OpenSSH development is discussed on the [openssh-unix-dev mailing list](https://lists.mindrot.org/mailman/listinfo/openssh-unix-dev) ([archive mirror](https://marc.info/?l=openssh-unix-dev)). Bugs and feature requests are tracked on our [Bugzilla](https://bugzilla.mindrot.org/).
83
84 ## Reporting bugs
85
86 _Non-security_ bugs may be reported to the developers via [Bugzilla](https://bugzilla.mindrot.org/) or via the mailing list above. Security bugs should be reported to [openssh@openssh.com](mailto:openssh.openssh.com).