postgresql/contrib
Tom Lane e3208fec32 Prevent potential overruns of fixed-size buffers.
Coverity identified a number of places in which it couldn't prove that a
string being copied into a fixed-size buffer would fit.  We believe that
most, perhaps all of these are in fact safe, or are copying data that is
coming from a trusted source so that any overrun is not really a security
issue.  Nonetheless it seems prudent to forestall any risk by using
strlcpy() and similar functions.

Fixes by Peter Eisentraut and Jozef Mlich based on Coverity reports.

In addition, fix a potential null-pointer-dereference crash in
contrib/chkpass.  The crypt(3) function is defined to return NULL on
failure, but chkpass.c didn't check for that before using the result.
The main practical case in which this could be an issue is if libc is
configured to refuse to execute unapproved hashing algorithms (e.g.,
"FIPS mode").  This ideally should've been a separate commit, but
since it touches code adjacent to one of the buffer overrun changes,
I included it in this commit to avoid last-minute merge issues.
This issue was reported by Honza Horak.

Security: CVE-2014-0065 for buffer overruns, CVE-2014-0066 for crypt()
2014-02-17 11:20:24 -05:00
..
adminpack Update copyrights for 2013 2013-01-01 17:15:01 -05:00
auth_delay Limit values of archive_timeout, post_auth_delay, auth_delay.milliseconds. 2012-11-18 17:15:06 -05:00
auto_explain Update copyrights for 2013 2013-01-01 17:15:01 -05:00
btree_gin
btree_gist pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
chkpass Prevent potential overruns of fixed-size buffers. 2014-02-17 11:20:24 -05:00
citext
cube Fix contrib/cube and contrib/seg to build with bison 3.0. 2013-07-29 10:42:41 -04:00
dblink Fix performance regression in dblink connection speed. 2013-12-07 17:00:10 -08:00
dict_int Update copyrights for 2013 2013-01-01 17:15:01 -05:00
dict_xsyn Update copyrights for 2013 2013-01-01 17:15:01 -05:00
dummy_seclabel Update copyrights for 2013 2013-01-01 17:15:01 -05:00
earthdistance
file_fdw pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
fuzzystrmatch Update copyrights for 2013 2013-01-01 17:15:01 -05:00
hstore Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
intagg
intarray Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
isn Fix calculation of ISMN check digit. 2014-01-13 15:43:59 +02:00
lo Defend against bad trigger definitions in contrib/lo's lo_manage() trigger. 2013-11-23 22:46:03 -05:00
ltree Predict integer overflow to avoid buffer overruns. 2014-02-17 09:33:32 -05:00
oid2name pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pageinspect Remove pageinspect--1.0.sql 2013-05-24 08:11:44 -04:00
passwordcheck Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pg_archivecleanup pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pg_buffercache
pg_freespacemap
pg_standby Prevent potential overruns of fixed-size buffers. 2014-02-17 11:20:24 -05:00
pg_stat_statements Editorialize a bit on new ProcessUtility() API. 2013-04-28 00:18:45 -04:00
pg_test_fsync pg_test_fsync: update output to show usecs/op clearer 2013-05-02 10:27:12 -04:00
pg_test_timing pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pg_trgm Fix possible buffer overrun in contrib/pg_trgm. 2014-01-13 13:07:13 -05:00
pg_upgrade Fix potential coredump on bad locale value in pg_upgrade. 2014-01-30 18:10:04 -05:00
pg_upgrade_support Update copyrights for 2013 2013-01-01 17:15:01 -05:00
pg_xlogdump Remove broken PGXS code for pg_xlogdump 2013-10-01 17:39:46 -03:00
pgbench Fix progress logging when scale factor is large. 2013-12-12 19:07:53 +09:00
pgcrypto pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pgrowlocks pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
pgstattuple pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
postgres_fdw Improve connection-failure error handling in contrib/postgres_fdw. 2014-02-03 21:30:28 -05:00
seg Fix contrib/cube and contrib/seg to build with bison 3.0. 2013-07-29 10:42:41 -04:00
sepgsql pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
spi
sslinfo
start-scripts Remove dead URL mention in OSX startup script 2013-09-04 17:04:57 -04:00
tablefunc Update copyrights for 2013 2013-01-01 17:15:01 -05:00
tcn Update copyrights for 2013 2013-01-01 17:15:01 -05:00
test_parser Update copyrights for 2013 2013-01-01 17:15:01 -05:00
tsearch2 Update copyrights for 2013 2013-01-01 17:15:01 -05:00
unaccent pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
uuid-ossp Fix quoting in help messages in uuid-ossp extension scripts. 2013-11-22 12:08:10 -05:00
vacuumlo pgindent run for release 9.3 2013-05-29 16:58:43 -04:00
worker_spi Fix some more bugs in signal handlers and process shutdown logic. 2014-02-01 16:21:30 -05:00
xml2
contrib-global.mk
Makefile contrib/Makefile also needs updated 2013-02-22 18:56:42 -03:00
README

The PostgreSQL contrib tree
---------------------------

This subtree contains porting tools, analysis utilities, and plug-in
features that are not part of the core PostgreSQL system, mainly
because they address a limited audience or are too experimental to be
part of the main source tree.  This does not preclude their
usefulness.

User documentation for each module appears in the main SGML
documentation.

When building from the source distribution, these modules are not
built automatically, unless you build the "world" target.  You can
also build and install them all by running "gmake all" and "gmake
install" in this directory; or to build and install just one selected
module, do the same in that module's subdirectory.

Some directories supply new user-defined functions, operators, or
types.  To make use of one of these modules, after you have installed
the code you need to register the new SQL objects in the database
system by executing a CREATE EXTENSION command.  In a fresh database,
you can simply do

    CREATE EXTENSION module_name;

See the PostgreSQL documentation for more information about this
procedure.