Portable OpenSSH, all Win32-OpenSSH releases and wiki are managed at https://github.com/powershell/Win32-OpenSSH
Go to file
djm@openbsd.org 1e84d0cf40
upstream: make host/banner comments go to stderr instead of stdout,
so they are useful as comments without extra shell redirection and so they
don't clutter actual errors on stderr.

Add a -q flag to shut them up.

ok dtucker@

OpenBSD-Commit-ID: bec813de56a71adb5c1a76adcf49621130d24264
2024-06-14 10:27:34 +10:00
.github Remove 9.6 branch from status page. 2024-04-25 13:19:03 +10:00
contrib attempt at updating RPM specs for sshd-session 2024-05-17 14:50:43 +10:00
m4 Improve detection of -fzero-call-used-regs=used. 2024-03-25 10:12:58 +11:00
openbsd-compat sync getrrsetbyname.c with recent upstream changes 2024-05-08 09:43:59 +10:00
regress upstream: specify an algorithm for ssh-keyscan, otherwise it will make 2024-06-14 10:25:51 +10:00
.depend upstream: Add a facility to sshd(8) to penalise particular 2024-06-07 03:35:40 +10:00
.git_allowed_signers add new token-based signing key for dtucker@ 2024-03-30 16:05:59 +11:00
.git_allowed_signers.asc add new token-based signing key for dtucker@ 2024-03-30 16:05:59 +11:00
.gitignore prepare for checking in autogenerated files 2024-06-13 15:02:26 +10:00
.skipped-commit-ids upstream: enable -fret-clean on amd64, for libc libcrypto ld.so 2024-06-07 03:18:44 +10:00
CREDITS convert to UTF-8; from Mike Frysinger 2019-07-29 09:49:23 +10:00
INSTALL remove support for old libcrypto 2023-03-24 13:56:25 +11:00
LICENCE Add a timegm implementation from Heimdal via Samba. 2022-08-11 22:51:10 +10:00
Makefile.in Makefile support for sshd-session 2024-05-17 14:41:37 +10:00
OVERVIEW upstream: refer to OpenSSL not SSLeay; 2018-10-23 16:57:54 +11:00
PROTOCOL upstream: fix missing field in users-groups-by-id@openssh.com reply 2024-01-08 16:06:29 +11:00
PROTOCOL.agent upstream: add missing reserved fields to key constraint protocol 2024-04-30 15:46:39 +10:00
PROTOCOL.certkeys upstream: PROTOCOL.certkeys: update reference from IETF draft to 2021-06-06 13:24:37 +10:00
PROTOCOL.chacha20poly1305 upstream: Fix some typos and an incorrect word in docs. Patch from 2020-02-21 12:27:23 +11:00
PROTOCOL.key upstream: in OpenSSH private key format, correct type for subsequent 2024-03-30 16:57:32 +11:00
PROTOCOL.krl upstream: remove vestigal support for KRL signatures 2023-07-17 14:52:35 +10:00
PROTOCOL.mux upstream: Remove outdated note from PROTOCOL.mux 2024-01-08 16:12:17 +11:00
PROTOCOL.sshsig upstream: Add RCS IDs to the few files that are missing them; from 2020-08-31 14:34:41 +10:00
PROTOCOL.u2f upstream: when writing an attestation blob for a FIDO key, record all 2020-09-09 13:11:34 +10:00
README version number in README 2024-03-11 16:20:49 +11:00
README.dns Minor documentation update: 2020-02-11 12:51:24 +11:00
README.md Add Coverity badges. 2023-03-03 14:50:03 +11:00
README.platform nite that recent OSX tun/tap is unsupported 2024-01-08 16:26:37 +11:00
README.privsep Privsep is now required. 2019-09-19 15:41:23 +10:00
README.tun - deraadt@cvs.openbsd.org 2006/03/28 00:12:31 2006-03-31 23:10:51 +11:00
SECURITY.md basic SECURITY.md (refers people to the website) 2021-11-03 12:08:21 +11:00
TODO Remove support for S/Key 2018-07-31 12:59:30 +10:00
addr.c upstream: Use strtonum() instead of severely non-idomatic 2024-04-30 12:16:50 +10:00
addr.h upstream: allow ssh-keyscan(1) to accept CIDR address ranges, e.g. 2022-10-28 13:39:35 +11:00
addrmatch.c upstream: highly polished whitespace, mostly fixing spaces-for-tab 2021-04-03 17:23:02 +11:00
atomicio.c remove sys/param.h in -portable, after upstream 2021-12-22 09:02:50 +11:00
atomicio.h upstream: move client/server SSH-* banners to buffers under 2018-12-27 14:38:22 +11:00
audit-bsm.c polish whitespace for portable files 2021-04-03 17:47:37 +11:00
audit-linux.c last bits of old packet API / active_state global 2019-01-20 14:55:27 +11:00
audit.c last bits of old packet API / active_state global 2019-01-20 14:55:27 +11:00
audit.h last bits of old packet API / active_state global 2019-01-20 14:55:27 +11:00
auth-bsdauth.c remove duplicate #includes 2019-10-02 10:54:28 +10:00
auth-krb5.c polish whitespace for portable files 2021-04-03 17:47:37 +11:00
auth-options.c conditionalise stdint.h inclusion on HAVE_STDINT_H 2023-07-18 15:41:12 +10:00
auth-options.h upstream: make authorized_keys environment="..." directives 2021-07-23 14:07:19 +10:00
auth-pam.c sshd: don't use argv[0] as PAM service name 2024-06-13 16:41:29 +10:00
auth-pam.h upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth-passwd.c upstream: use the new variant log macros instead of prepending 2020-10-18 23:46:29 +11:00
auth-rhosts.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth-shadow.c Cast time_t's in debug output to long long. 2023-02-27 21:04:22 +11:00
auth-sia.c Remove key.h from portable files too. 2018-07-12 14:57:46 +10:00
auth-sia.h - (dtucker) [auth-passwd.c auth-sia.h] Remove duplicate definitions of 2005-04-05 21:00:47 +10:00
auth.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
auth2-chall.c upstream: use the new variant log macros instead of prepending 2020-10-18 23:46:29 +11:00
auth2-gss.c upstream: g/c unused variable 2024-05-17 14:42:49 +10:00
auth2-hostbased.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth2-kbdint.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth2-methods.c upstream: typos 2024-05-31 19:04:11 +10:00
auth2-none.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth2-passwd.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth2-pubkey.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
auth2-pubkeyfile.c upstream: Remove unused compat.h includes. 2023-03-05 19:27:31 +11:00
auth2.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
authfd.c upstream: Make it possible to load certs from PKCS#11 tokens 2023-12-19 01:52:55 +11:00
authfd.h upstream: Make it possible to load certs from PKCS#11 tokens 2023-12-19 01:52:55 +11:00
authfile.c upstream: Check pointer for NULL before deref. 2023-03-14 18:35:31 +11:00
authfile.h upstream: factor out reading/writing sshbufs to dedicated 2020-01-26 10:18:42 +11:00
bitmap.c upstream commit 2017-10-20 12:58:35 +11:00
bitmap.h upstream commit 2017-10-20 12:58:35 +11:00
buildpkg.sh.in whitespace at EOL 2020-12-22 19:43:55 +11:00
canohost.c upstream: Return immediately from get_sock_port 2023-03-31 16:17:22 +11:00
canohost.h upstream commit 2016-03-08 06:20:35 +11:00
chacha.c upstream: move other RCSIDs to before their respective license blocks 2023-07-17 15:33:51 +10:00
chacha.h upstream: whitespace (tab after space) 2021-04-03 17:20:00 +11:00
channels.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
channels.h upstream: remove unused struct fwd_perm_list, no decl with complete 2024-05-27 11:55:02 +10:00
cipher-aes.c remove support for old libcrypto 2023-03-24 13:56:25 +11:00
cipher-aesctr.c Add includes.h for compatibility stuff. 2015-02-25 13:17:40 +11:00
cipher-aesctr.h - markus@cvs.openbsd.org 2014/04/29 18:01:49 2014-05-15 14:24:09 +10:00
cipher-chachapoly-libcrypto.c upstream: move other RCSIDs to before their respective license blocks 2023-07-17 15:33:51 +10:00
cipher-chachapoly.c upstream: move other RCSIDs to before their respective license blocks 2023-07-17 15:33:51 +10:00
cipher-chachapoly.h upstream: make Chacha20-POLY1305 context struct opaque; ok tb@ as 2020-04-03 15:36:57 +11:00
cipher.c upstream: spelling; ok djm@ 2024-05-17 14:42:49 +10:00
cipher.h upstream: Garbage collect cipher_get_keyiv_len() 2023-10-11 15:57:08 +11:00
cleanup.c - (djm) [auth-pam.c auth-shadow.c auth2-none.c cleanup.c sshd.c] 2006-08-05 14:07:20 +10:00
clientloop.c upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
clientloop.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
compat.c upstream: Refactor creation of KEX proposal. 2023-03-06 23:31:52 +11:00
compat.h upstream: Refactor creation of KEX proposal. 2023-03-06 23:31:52 +11:00
config.guess Update autotools 2022-12-06 12:23:08 +11:00
config.sub Update autotools 2022-12-06 12:23:08 +11:00
configure.ac Merge flags for OpenSSL 3.x versions. 2024-04-25 13:20:19 +10:00
crypto_api.h upstream: update OpenSSH's Ed25519 code to the last version of SUPERCOP 2023-01-16 10:57:41 +11:00
defines.h Correct value for IPTOS_DSCP_LE. 2021-12-15 10:50:33 +11:00
dh.c upstream: highly polished whitespace, mostly fixing spaces-for-tab 2021-04-03 17:23:02 +11:00
dh.h upstream: Add ModuliFile keyword to sshd_config to specify the 2021-03-13 13:14:13 +11:00
digest-libc.c Use SHA.*_HMAC_BLOCK_SIZE if needed. 2021-12-23 11:36:08 +11:00
digest-openssl.c upstream: whitespace; no code change 2020-10-29 13:54:13 +11:00
digest.h upstream commit 2017-05-10 11:41:21 +10:00
dispatch.c upstream: Remove unused compat.h includes. 2023-03-05 19:27:31 +11:00
dispatch.h upstream: remove last traces of old packet API! 2019-01-20 09:45:18 +11:00
dns.c upstream: Plug mem leak on error path. Coverity CID 405026, ok djm@. 2023-03-10 15:42:37 +11:00
dns.h upstream: let ssh-keygen and ssh-keyscan accept 2023-02-10 16:12:42 +11:00
ed25519.c upstream: update OpenSSH's Ed25519 code to the last version of SUPERCOP 2023-01-16 10:57:41 +11:00
ed25519.sh upstream: spelling; ok djm@ 2024-05-17 14:42:49 +10:00
entropy.c Remove seed passing over reexec. 2022-11-10 12:44:51 +11:00
entropy.h Adapt portable to legacy buffer API removal 2018-07-10 19:39:52 +10:00
fatal.c upstream: fix SEGV on fatal() errors spotted by dtucker@ 2020-10-19 19:09:08 +11:00
fixalgorithms - (dtucker) [Makefile.in configure.ac fixalgorithms] Remove unsupported 2013-06-11 11:26:10 +10:00
fixpaths - (djm) PERL-free fixpaths from stuge-openssh-unix-dev@cdy.org 2002-12-05 20:59:33 +11:00
groupaccess.c upstream: Move checks for lists of users or groups into their own 2019-03-08 15:10:07 +11:00
groupaccess.h - djm@cvs.openbsd.org 2008/07/04 03:44:59 2008-07-04 13:51:12 +10:00
gss-genr.c upstream: whitespace 2024-02-01 13:42:45 +11:00
gss-serv-krb5.c upstream: sshd: switch GSSAPI to sshbuf API; ok djm@ 2018-07-10 15:28:30 +10:00
gss-serv.c gss-serv.c: `MAXHOSTNAMELEN` -> `HOST_NAME_MAX` 2023-07-05 17:54:15 +10:00
hash.c Remove old OpenBSD version marker. 2021-07-03 20:36:06 +10:00
hmac.c upstream: change explicit_bzero();free() to freezero() 2020-02-28 12:26:28 +11:00
hmac.h - djm@cvs.openbsd.org 2014/06/24 01:13:21 2014-07-02 15:28:02 +10:00
hostfile.c upstream: fseek to end of known_hosts before writing to it. 2023-02-21 18:28:26 +11:00
hostfile.h upstream: make struct hostkeys public; I have no idea why I made it 2021-01-26 12:21:48 +11:00
includes.h remove sys/param.h in -portable, after upstream 2021-12-22 09:02:50 +11:00
install-sh Update autotools 2022-12-06 12:23:08 +11:00
kex-names.c upstream: missing files from previous 2024-05-17 14:41:35 +10:00
kex.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
kex.h upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
kexc25519.c upstream: rename kex->kem_client_pub -> kex->client_pub now that 2019-01-21 23:13:03 +11:00
kexdh.c Move signal.h up include order to match upstream. 2021-07-03 20:38:09 +10:00
kexecdh.c Put ssherr.h back as it's actually needed. 2019-10-02 14:30:55 +10:00
kexgen.c upstream: Record session ID, host key and sig at intital KEX 2021-12-20 09:24:42 +11:00
kexgex.c upstream: pass most arguments to the KEX hash functions as sshbuf 2019-01-23 13:02:02 +11:00
kexgexc.c upstream: Record session ID, host key and sig at intital KEX 2021-12-20 09:24:42 +11:00
kexgexs.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
kexsntrup761x25519.c upstream: fix unintended sizeof pointer in debug path ok markus@ 2021-12-07 12:30:50 +11:00
krl.c upstream: Move RCSID to before license block and away from #includes, 2023-07-17 15:24:14 +10:00
krl.h upstream: remove vestigal support for KRL signatures 2023-07-17 14:52:35 +10:00
log.c upstream: short circuit debug log processing early if we're not going 2023-12-07 08:09:11 +11:00
log.h upstream: do not pass file/func to monitor; noted by Ilja van Sprundel; 2021-04-16 13:24:33 +10:00
loginrec.c remove sys/param.h in -portable, after upstream 2021-12-22 09:02:50 +11:00
loginrec.h polish whitespace for portable files 2021-04-03 17:47:37 +11:00
logintest.c polish whitespace for portable files 2021-04-03 17:47:37 +11:00
mac.c remove duplicate #includes 2019-10-02 10:54:28 +10:00
mac.h upstream commit 2016-07-08 13:50:03 +10:00
match.c upstream: match_user() shouldn't be called with user==NULL unless 2023-04-06 13:27:16 +10:00
match.h upstream: some language improvements; ok markus 2020-07-15 15:07:42 +10:00
mdoc2man.awk Remove remaining now-obsolete cvs $Ids. 2018-02-15 20:06:19 +11:00
misc.c upstream: Add a facility to sshd(8) to penalise particular 2024-06-07 03:35:40 +10:00
misc.h upstream: Add a facility to sshd(8) to penalise particular 2024-06-07 03:35:40 +10:00
mkinstalldirs Remove remaining now-obsolete cvs $Ids. 2018-02-15 20:06:19 +11:00
moduli upstream: Import regenerated moduli. 2024-03-26 13:03:00 +11:00
moduli.5 Resync moduli.5 with upstream. 2022-04-16 14:33:20 +10:00
moduli.c upstream: Always call fclose on checkpoints. 2023-03-02 18:24:51 +11:00
monitor.c upstream: Add a facility to sshd(8) to penalise particular 2024-06-07 03:35:40 +10:00
monitor.h upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
monitor_fdpass.c upstream: use the new variant log macros instead of prepending 2020-10-18 23:46:29 +11:00
monitor_fdpass.h - djm@cvs.openbsd.org 2007/09/04 03:21:03 2007-09-17 12:04:08 +10:00
monitor_wrap.c upstream: reap preauth net child if it hangs up during privsep message 2024-06-11 12:55:20 +10:00
monitor_wrap.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
msg.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
msg.h upstream commit 2015-01-15 21:39:14 +11:00
mux.c upstream: Include existing mux path in debug message. 2023-11-24 12:01:31 +11:00
myproposal.h upstream: select post-quantum KEX 2022-03-31 08:16:38 +11:00
nchan.c upstream: whitespace 2024-02-01 13:42:45 +11:00
nchan.ms - djm@cvs.openbsd.org 2003/11/21 11:57:03 2003-11-21 23:48:55 +11:00
nchan2.ms - djm@cvs.openbsd.org 2008/05/15 23:52:24 2008-05-19 16:08:20 +10:00
openssh.xml.in - (tim) [buildpkg.sh.in openssh.xml.in] Allow more flexibility where smf(5) 2007-07-24 21:16:07 -07:00
opensshd.init.in Replace shell function with ssh-keygen -A. 2021-08-20 18:14:13 +10:00
packet.c upstream: typos 2024-05-31 19:04:11 +10:00
packet.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
pathnames.h upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
pkcs11.h - deraadt@cvs.openbsd.org 2013/11/26 19:15:09 2013-12-05 10:22:03 +11:00
platform-listen.c Makefile support for sshd-session 2024-05-17 14:41:37 +10:00
platform-misc.c Split platform_sys_dir_uid into its own file 2017-08-25 13:25:01 +10:00
platform-pledge.c Support Illumos/Solaris fine-grained privileges 2016-01-08 14:29:12 +11:00
platform-tracing.c Fix comment text. From emaste at freebsd.org. 2022-11-09 08:27:47 +11:00
platform.c Makefile support for sshd-session 2024-05-17 14:41:37 +10:00
platform.h notify systemd on listen and reload 2024-04-03 14:40:32 +11:00
poly1305.c upstream: move other RCSIDs to before their respective license blocks 2023-07-17 15:33:51 +10:00
poly1305.h - djm@cvs.openbsd.org 2014/05/02 03:27:54 2014-05-15 14:37:03 +10:00
progressmeter.c upstream: remove duplicate signal.h include 2023-04-17 09:21:14 +10:00
progressmeter.h upstream: Have progressmeter force an update at the beginning and 2019-01-25 06:32:14 +11:00
readconf.c upstream: spelling; ok djm@ 2024-05-17 14:42:49 +10:00
readconf.h upstream: Separate parsing of string array options from applying them 2024-03-04 14:46:46 +11:00
readpass.c upstream: allow WAYLAND_DISPLAY to enable SSH_ASKPASS 2024-03-30 15:35:03 +11:00
rijndael.c upstream commit 2015-03-23 17:08:12 +11:00
rijndael.h upstream: Make prototype for rijndaelEncrypt match function 2021-09-29 11:09:27 +10:00
sandbox-capsicum.c Cache timezone data in capsicum sandbox. 2022-04-23 21:14:01 +10:00
sandbox-darwin.c sandbox-darwin.c: fix missing prototypes. 2020-01-21 10:37:25 +11:00
sandbox-null.c - (djm) [Makefile.in configure.ac sandbox-capsicum.c sandbox-darwin.c] 2014-01-17 16:47:04 +11:00
sandbox-pledge.c upstream: use the new variant log macros instead of prepending 2020-10-18 23:46:29 +11:00
sandbox-rlimit.c upstream: use the new variant log macros instead of prepending 2020-10-18 23:46:29 +11:00
sandbox-seccomp-filter.c Improve seccomp compat on older systems. 2023-02-11 12:32:19 +11:00
sandbox-solaris.c drop two more privileges in the Solaris sandbox 2017-06-09 14:44:43 +10:00
sandbox-systrace.c upstream: Replace all calls to signal(2) with a wrapper around 2020-01-23 18:51:25 +11:00
scp.1 upstream: Mention that scp uses the SFTP protocol and remove 2023-01-03 17:53:05 +11:00
scp.c upstream: in olde rcp/scp protocol mode, when rejecting a path from the 2023-10-11 16:44:40 +11:00
servconf.c upstream: split PerSourcePenalties address tracking. Previously it 2024-06-13 08:36:41 +10:00
servconf.h upstream: split PerSourcePenalties address tracking. Previously it 2024-06-13 08:36:41 +10:00
serverloop.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
serverloop.h upstream commit 2017-09-12 17:37:02 +10:00
session.c typo in comment 2024-06-13 14:41:33 +10:00
session.h upstream: Add channel_force_close() 2023-01-06 16:21:39 +11:00
sftp-client.c upstream: spelling; ok djm@ 2024-05-17 14:42:49 +10:00
sftp-client.h upstream: the sftp code was one of my first contributions to 2023-09-08 15:59:08 +10:00
sftp-common.c upstream: don't attempt to decode a ridiculous number of 2023-03-31 15:06:20 +11:00
sftp-common.h upstream: extend sftp-common.c:extend ls_file() to support supplied 2022-09-19 20:49:13 +10:00
sftp-glob.c upstream: rename remote_glob() -> sftp_glob() to match other API 2023-09-11 09:14:02 +10:00
sftp-realpath.c upstream: sys/param.h is not needed for any visible reason 2021-09-03 14:20:22 +10:00
sftp-server-main.c Remove seed_rng calls from scp, sftp, sftp-server. 2022-07-27 16:22:30 +10:00
sftp-server.8 upstream: standardise the grammar in the options list; issue 2021-08-03 09:39:57 +10:00
sftp-server.c upstream: fix home-directory extension implementation, it always 2024-04-30 16:24:22 +10:00
sftp-usergroup.c upstream: the sftp code was one of my first contributions to 2023-09-08 15:59:08 +10:00
sftp-usergroup.h upstream: use users-groups-by-id@openssh.com sftp-server extension 2022-09-19 20:51:14 +10:00
sftp.1 upstream: add a -X option to both scp(1) and sftp(1) to allow 2023-01-03 17:53:05 +11:00
sftp.c upstream: flush stdout after writing "sftp>" prompt when not using 2024-04-30 16:17:20 +10:00
sftp.h - dtucker@cvs.openbsd.org 2008/06/13 00:12:02 2008-06-13 10:22:54 +10:00
sk-api.h upstream: when enrolling a resident key on a security token, check 2022-07-20 13:38:47 +10:00
sk-usbhid.c conditionalise stdint.h inclusion on HAVE_STDINT_H 2023-07-18 15:41:12 +10:00
smult_curve25519_ref.c - markus@cvs.openbsd.org 2013/11/02 21:59:15 2013-11-04 08:26:52 +11:00
sntrup761.c upstream: remove whitespace at EOL from code extracted from SUPERCOP 2023-01-11 13:17:03 +11:00
sntrup761.sh upstream: remove whitespace at EOL from code extracted from SUPERCOP 2023-01-11 13:17:03 +11:00
srclimit.c upstream: split PerSourcePenalties address tracking. Previously it 2024-06-13 08:36:41 +10:00
srclimit.h upstream: Add a facility to sshd(8) to penalise particular 2024-06-07 03:35:40 +10:00
ssh-add.1 upstream: sort -C, and add to usage(); ok djm 2024-01-08 13:25:20 +11:00
ssh-add.c upstream: make DSA key support compile-time optional, defaulting to 2024-01-11 15:46:22 +11:00
ssh-agent.1 use portable provider allowlist path in manpage 2023-10-04 10:54:04 +11:00
ssh-agent.c upstream: avoid logging in signal handler by converting mainloop to 2024-03-09 16:13:57 +11:00
ssh-dss.c upstream: make DSA key support compile-time optional, defaulting to 2024-01-11 15:46:22 +11:00
ssh-ecdsa-sk.c upstream: Delete obsolete /* ARGSUSED */ lint comments. 2023-03-08 17:26:53 +11:00
ssh-ecdsa.c upstream: Delete obsolete /* ARGSUSED */ lint comments. 2023-03-08 17:26:53 +11:00
ssh-ed25519-sk.c upstream: refactor sshkey_private_deserialize 2022-10-28 12:47:01 +11:00
ssh-ed25519.c upstream: refactor sshkey_private_deserialize 2022-10-28 12:47:01 +11:00
ssh-gss.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
ssh-keygen.1 upstream: Generate Ed25519 keys when invoked without arguments 2023-09-07 09:53:59 +10:00
ssh-keygen.c upstream: make DSA key support compile-time optional, defaulting to 2024-01-11 15:46:22 +11:00
ssh-keyscan.1 upstream: space between macro and punctuation; sort usage(); 2023-02-16 21:11:38 +11:00
ssh-keyscan.c upstream: make host/banner comments go to stderr instead of stdout, 2024-06-14 10:27:34 +10:00
ssh-keysign.8 upstream: man pages: add missing commas between subordinate and 2022-04-06 09:16:05 +10:00
ssh-keysign.c upstream: stricter validation of messaging socket fd number; disallow 2024-04-30 15:53:26 +10:00
ssh-pkcs11-client.c Fix compilation error in ssh-pcks11-client.c 2024-01-08 16:23:19 +11:00
ssh-pkcs11-helper.8 upstream: mention that the helpers are used by ssh(1), ssh-agent(1) 2022-04-29 13:26:24 +10:00
ssh-pkcs11-helper.c upstream: check for POLLHUP wherever we check for POLLIN 2021-11-18 14:32:54 +11:00
ssh-pkcs11.c upstream: Oops, incorrect hex conversion spotted by claudio. 2024-04-30 12:16:54 +10:00
ssh-pkcs11.h upstream: Make it possible to load certs from PKCS#11 tokens 2023-12-19 01:52:55 +11:00
ssh-rsa.c upstream: Remove unused compat.h includes. 2023-03-05 19:27:31 +11:00
ssh-sandbox.h - (djm) [Makefile.in configure.ac sandbox-capsicum.c sandbox-darwin.c] 2014-01-17 16:47:04 +11:00
ssh-sk-client.c upstream: sshsk_load_resident: don't preallocate resp 2022-01-14 14:40:40 +11:00
ssh-sk-helper.8 upstream: mention that the helpers are used by ssh(1), ssh-agent(1) 2022-04-29 13:26:24 +10:00
ssh-sk-helper.c upstream: Remove duplicate includes. 2022-12-04 22:40:04 +11:00
ssh-sk.c upstream: Ensure FIDO/PKCS11 libraries contain expected symbols 2023-07-20 00:21:31 +10:00
ssh-sk.h upstream: When downloading resident keys from a FIDO token, pass 2021-10-28 13:56:59 +11:00
ssh-xmss.c conditionalise stdint.h inclusion on HAVE_STDINT_H 2023-07-18 15:41:12 +10:00
ssh.1 upstream: remove references to SSH1 and DSA server keys 2024-05-27 11:55:03 +10:00
ssh.c upstream: make DSA key support compile-time optional, defaulting to 2024-01-11 15:46:22 +11:00
ssh.h upstream: allow some additional control over the use of ssh-askpass 2020-07-15 15:08:10 +10:00
ssh2.h upstream: Reserve a range of "local extension" message numbers that 2023-10-10 14:58:55 +11:00
ssh_api.c upstream: Start the process of splitting sshd into separate 2024-05-17 14:41:35 +10:00
ssh_api.h upstream: lots of typos in comments/docs. Patch from Karsten Weiss 2018-04-10 10:17:15 +10:00
ssh_config upstream: CheckHostIP has defaulted to 'no' for a while; make the 2023-08-03 09:09:02 +10:00
ssh_config.5 upstream: fix typo in match directive predicate (s/tagged/tag) GHPR#462 2024-02-21 17:01:37 +11:00
sshbuf-getput-basic.c upstream: revert previous; it was broken (spotted by Theo) 2022-05-25 16:06:03 +10:00
sshbuf-getput-crypto.c upstream: whitespace 2024-02-01 13:42:45 +11:00
sshbuf-io.c upstream: tidy headers; some junk snuck into sshbuf-misc.c and 2020-01-26 10:34:50 +11:00
sshbuf-misc.c upstream: Add a sshbuf_read() that attempts to read(2) directly in 2022-01-25 10:45:47 +11:00
sshbuf.c upstream: make struct sshbuf private 2022-12-04 22:39:42 +11:00
sshbuf.h upstream: make struct sshbuf private 2022-12-04 22:39:42 +11:00
sshconnect.c upstream: add explict check for server hostkey type against 2024-04-30 12:22:35 +10:00
sshconnect.h upstream: add explict check for server hostkey type against 2024-04-30 12:22:35 +10:00
sshconnect2.c upstream: remove externs for removed vars; ok djm@ 2024-05-22 14:20:46 +10:00
sshd-session.c fix PTY allocation on Cygwin, broken by sshd split 2024-06-13 14:35:25 +10:00
sshd.8 upstream: typo; from Jim Spath 2023-10-01 10:57:54 +11:00
sshd.c upstream: disable stderr redirection before closing fds 2024-06-07 05:52:50 +10:00
sshd_config Use "prohibit-password" in -portable comments. 2022-11-07 10:54:29 +11:00
sshd_config.5 upstream: separate keywords with comma 2024-06-14 10:27:33 +10:00
ssherr.c upstream: improve the error message for u2f enrollment errors by 2020-01-26 10:18:42 +11:00
ssherr.h upstream: improve the error message for u2f enrollment errors by 2020-01-26 10:18:42 +11:00
sshkey-xmss.c upstream: factor out key generation 2022-10-28 12:46:58 +11:00
sshkey-xmss.h upstream: factor out key generation 2022-10-28 12:46:58 +11:00
sshkey.c upstream: make DSA key support compile-time optional, defaulting to 2024-01-11 15:46:22 +11:00
sshkey.h upstream: remove prototypes with no matching function; ok djm@ 2024-05-22 14:21:13 +10:00
sshlogin.c Include stdlib.h for free() prototype. 2022-04-23 21:14:01 +10:00
sshlogin.h - (djm) [sshlogin.h] Fix prototype merge botch from 2006; bz#2134 2013-08-01 14:34:16 +10:00
sshpty.c Include stdio.h for FILE in misc.h. 2020-12-22 18:56:54 +11:00
sshpty.h upstream commit 2016-11-29 16:51:27 +11:00
sshsig.c upstream: skip more whitespace, fixes find-principals on 2024-03-09 09:17:22 +11:00
sshsig.h upstream: Add ssh-keygen -Y match-principals operation to perform 2021-11-27 18:22:41 +11:00
sshtty.c - djm@cvs.openbsd.org 2010/01/09 05:04:24 2010-01-09 22:26:23 +11:00
survey.sh.in - (dtucker) [config.sh.in] Collect oslevel -r too. 2005-02-15 21:26:32 +11:00
ttymodes.c upstream: remove global variable used to stash compat flags and use the 2021-01-27 20:28:25 +11:00
ttymodes.h upstream commit 2017-05-01 10:05:04 +10:00
uidswap.c polish whitespace for portable files 2021-04-03 17:47:37 +11:00
uidswap.h upstream: Remove support for running ssh(1) setuid and fatal if 2018-07-19 21:41:42 +10:00
umac.c upstream: correct size for array argument when changing 2023-03-07 16:38:39 +11:00
umac.h upstream: spelling ok dtucker@ 2022-01-01 15:19:48 +11:00
umac128.c upstream commit 2018-02-09 20:00:18 +11:00
utf8.c upstream: expose vasnmprintf(); ok (as part of other commit) markus 2020-05-01 16:40:11 +10:00
utf8.h upstream: highly polished whitespace, mostly fixing spaces-for-tab 2021-04-03 17:23:02 +11:00
version.h upstream: openssh-9.7 2024-03-11 16:19:44 +11:00
xmalloc.c upstream: ssh: xstrdup(): use memcpy(3) 2022-03-18 13:33:36 +11:00
xmalloc.h upstream: highly polished whitespace, mostly fixing spaces-for-tab 2021-04-03 17:23:02 +11:00
xmss_commons.c wrap stdint.h include in HAVE_STDINT_H 2019-10-09 09:06:35 +11:00
xmss_commons.h Remove extra XMSS #endif 2018-03-05 10:22:32 +11:00
xmss_fast.c wrap stdint.h include in HAVE_STDINT_H 2019-10-09 09:06:35 +11:00
xmss_fast.h upstream: Add $OpenBSD$ markers to xmss files to help keep synced 2018-03-02 14:29:25 +11:00
xmss_hash.c upstream: spelling; ok markus@ 2024-01-08 13:25:21 +11:00
xmss_hash.h upstream: Add $OpenBSD$ markers to xmss files to help keep synced 2018-03-02 14:29:25 +11:00
xmss_hash_address.c wrap stdint.h include in HAVE_STDINT_H 2019-10-09 09:06:35 +11:00
xmss_hash_address.h upstream: Add $OpenBSD$ markers to xmss files to help keep synced 2018-03-02 14:29:25 +11:00
xmss_wots.c wrap stdint.h include in HAVE_STDINT_H 2019-10-09 09:06:35 +11:00
xmss_wots.h upstream: Remove unneeded (local) include. ok markus@ 2018-03-02 14:30:02 +11:00

README.md

Portable OpenSSH

C/C++ CI Fuzzing Status Coverity Status

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.

This is a port of OpenBSD's OpenSSH 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).

Documentation

The official documentation for OpenSSH are the man pages for each tool:

Stable Releases

Stable release tarballs are available from a number of download mirrors. We recommend the use of a stable release for most users. Please read the release notes for details of recent changes and potential incompatibilities.

Building Portable OpenSSH

Dependencies

Portable OpenSSH is built using autoconf and make. It requires a working C compiler, standard library and headers.

libcrypto from either LibreSSL or OpenSSL 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.

zlib is optional; without it transport compression is not supported.

FIDO security token support needs libfido2 and its dependencies and will be enabled automatically if they are found.

In addition, certain platforms and build-time options may require additional dependencies; see README.platform for details about your platform.

Building a release

Releases include a pre-built copy of the configure script and may be built using:

tar zxvf openssh-X.YpZ.tar.gz
cd openssh
./configure # [options]
make && make tests

See the 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.

Building from git

If building from git, you'll need autoconf installed to build the configure script. The following commands will check out and build portable OpenSSH from git:

git clone https://github.com/openssh/openssh-portable # or https://anongit.mindrot.org/openssh.git
cd openssh-portable
autoreconf
./configure
make && make tests

Build-time Customisation

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).

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.

Flag Meaning
--with-pam Enable PAM support. OpenPAM, Linux PAM and Solaris PAM are supported.
--with-libedit Enable libedit support for sftp.
--with-kerberos5 Enable Kerberos/GSSAPI support. Both Heimdal and MIT Kerberos implementations are supported.
--with-selinux Enable SELinux support.

Development

Portable OpenSSH development is discussed on the openssh-unix-dev mailing list (archive mirror). Bugs and feature requests are tracked on our Bugzilla.

Reporting bugs

Non-security bugs may be reported to the developers via Bugzilla or via the mailing list above. Security bugs should be reported to openssh@openssh.com.