FreeBSD src
Go to file
Conrad Meyer f27d255c59 dumpon(8): Provide seatbelt against weak RSA keys
The premise of dumpon -k foo.pem is that dump contents will be confidential
except to anyone holding the corresponding RSA private key.

This guarantee breaks down when weak RSA keys are used.  Small RSA keys
(e.g. 512 bits) can be broken on a single personal computer in tractible
time.  Marginal RSA keys (768 bits) can be broken by EC2 and a few dollars.
Even 1024 bit keys can probably be broken by sophisticated and wealthy
attackers.

NIST SP800-57 (2016) recommends a minimum of 2048 bit RSA keys, and
estimates this provides 112 bits of security.

It would also be good to protect users from weak values of 'e' (i.e., 3) and
perhaps sanity check that their public key .pem does not accidentally
contain their private key as well.  These considerations are left as future
work.

Reviewed by:	markj, darius AT dons.net.au (previous version)
Discussed with:	bjk
Differential Revision:	https://reviews.freebsd.org/D17678
2018-10-26 19:53:59 +00:00
bin Don't print pathconf() errors if the target file doesn't exist. 2018-10-26 19:01:52 +00:00
cddl Add support for send, receive and state-change DTrace providers for 2018-08-22 21:23:32 +00:00
contrib MFV r339750: 2018-10-25 23:13:19 +00:00
crypto Update SHLIB_VERSION_NUMBER following the OpenSSL shared library 2018-10-25 18:46:45 +00:00
etc Move hosts.allow to lib/libwrap/ 2018-09-22 13:17:30 +00:00
gnu Implement a BSD licensed crtbegin/crtend 2018-10-25 17:39:41 +00:00
include Reduce NL_ARGMAX to 4096 to match Linux. 2018-10-04 21:55:58 +00:00
kerberos5 Update the existing heimdal implementation for OpenSSL 1.1. 2018-10-05 16:35:24 +00:00
lib Add __dso_handle to the BSD crtbegin. This is used to identify shared 2018-10-26 11:53:20 +00:00
libexec Remove code that is dead since r287197. Today wlan(4) interfaces aren't 2018-10-24 20:49:51 +00:00
release Reduce the GCE image size to 27G to be lower than the free 2018-10-24 15:51:55 +00:00
rescue Avoid referencing private lib names directly. 2017-11-10 07:53:02 +00:00
sbin dumpon(8): Provide seatbelt against weak RSA keys 2018-10-26 19:53:59 +00:00
secure Bump base OpenSSL libraries versions to avoid conflict with port's libraries. 2018-10-25 13:37:57 +00:00
share Redo r339563: Remove joy(4) driver. 2018-10-26 16:03:30 +00:00
stand lualoader: Improve module loading diagnostics 2018-10-25 02:14:35 +00:00
sys Move 32-bit compat support for FIODGNAME to the right place. 2018-10-26 17:59:25 +00:00
targets Add -b/-l options to localedef(1) to specify output endianness and use 2018-10-20 20:51:05 +00:00
tests Update and re-enable ACL tests following r332396 and r339781. 2018-10-26 19:03:30 +00:00
tools Redo r339563: Remove joy(4) driver. 2018-10-26 16:03:30 +00:00
usr.bin Add an IMPLEMENTATION NOTES section to ldd.1. 2018-10-23 13:49:53 +00:00
usr.sbin Add blank line after each item in "ngctl ls -l" 2018-10-26 19:16:17 +00:00
.arcconfig callsign isn't required anymore 2016-09-29 06:19:45 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.gitattributes Remove spuriously added svn properties 2018-08-02 18:37:02 +00:00
.gitignore Ignore _.universe-toolchain file. 2018-07-01 13:50:37 +00:00
COPYRIGHT Remove 'All Rights Reserved' from the collection copyright and templates. 2018-05-09 02:02:49 +00:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS Add pointer to freebsd-numerics for libm. 2018-07-16 15:29:32 +00:00
Makefile Don't include the broken riscv64sf TARGET_ARCH in universe. 2018-10-09 22:22:15 +00:00
Makefile.inc1 Update elftoolchain bootstrapping test after r339083 2018-10-26 01:13:20 +00:00
Makefile.libcompat Fix non-FreeBSD host lib32 build for TARGET=amd64 2018-08-23 18:19:10 +00:00
Makefile.sys.inc AUTO_OBJ: For all top-level targets enforce using an OBJDIR. 2017-12-05 21:29:47 +00:00
ObsoleteFiles.inc Redo r339563: Remove joy(4) driver. 2018-10-26 16:03:30 +00:00
README README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
README.md README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
UPDATING Add updating entry for DRM 2018-10-20 19:14:46 +00:00

FreeBSD Source:

This is the top level of the FreeBSD source directory. This file was last revised on: FreeBSD

FreeBSD is an operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.

For copyright information, please see the file COPYRIGHT in this directory. Additional copyright information also exists for some sources in this tree - please see the specific source directories for more information.

The Makefile in this directory supports a number of targets for building components (or all) of the FreeBSD source tree. See build(7), config(8), https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html, and https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information, including setting make(1) variables.

Source Roadmap:

bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

stand		Boot loader sources.

sys		Kernel sources.

sys/<arch>/conf Kernel configuration files. GENERIC is the configuration
		used in release builds. NOTES contains documentation of
		all possible entries.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.

For information on synchronizing your source tree with one or more of the FreeBSD Project's development branches, please see:

https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/current-stable.html