postgresql/src/port
Tom Lane 67a472d71c Remove arbitrary restrictions on password length.
This patch started out with the goal of harmonizing various arbitrary
limits on password length, but after awhile a better idea emerged:
let's just get rid of those fixed limits.

recv_password_packet() has an arbitrary limit on the packet size,
which we don't really need, so just drop it.  (Note that this doesn't
really affect anything for MD5 or SCRAM password verification, since
those will hash the user's password to something shorter anyway.
It does matter for auth methods that require a cleartext password.)

Likewise remove the arbitrary error condition in pg_saslprep().

The remaining limits are mostly in client-side code that prompts
for passwords.  To improve those, refactor simple_prompt() so that
it allocates its own result buffer that can be made as big as
necessary.  Actually, it proves best to make a separate routine
pg_get_line() that has essentially the semantics of fgets(), except
that it allocates a suitable result buffer and hence will never
return a truncated line.  (pg_get_line has a lot of potential
applications to replace randomly-sized fgets buffers elsewhere,
but I'll leave that for another patch.)

I built pg_get_line() atop stringinfo.c, which requires moving
that code to src/common/; but that seems fine since it was a poor
fit for src/port/ anyway.

This patch is mostly mine, but it owes a good deal to Nathan Bossart
who pressed for a solution to the password length problem and
created a predecessor patch.  Also thanks to Peter Eisentraut and
Stephen Frost for ideas and discussion.

Discussion: https://postgr.es/m/09512C4F-8CB9-4021-B455-EF4C4F0D55A0@amazon.com
2020-09-03 20:09:18 -04:00
..
.gitignore Build src/port files as a library with -fPIC, and use that in libpq. 2018-09-27 11:23:43 -04:00
Makefile Remove arbitrary restrictions on password length. 2020-09-03 20:09:18 -04:00
README Always use our own versions of *printf(). 2018-09-26 13:13:57 -04:00
chklocale.c Be more careful about extracting encoding from locale strings on Windows. 2020-03-30 11:14:58 -04:00
dirent.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
dirmod.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
dlopen.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
erand48.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
explicit_bzero.c Initial pgindent and pgperltidy run for v13. 2020-05-14 13:06:50 -04:00
fls.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
getaddrinfo.c Cleanup more code related to ws2_32.dll loading in src/port/getaddrinfo.c 2020-02-20 11:57:41 +09:00
getopt.c Use our own getopt() on OpenBSD. 2019-01-18 15:06:26 -05:00
getopt_long.c Fix our getopt_long's behavior for a command line argument of just "-". 2020-03-23 11:58:00 -04:00
getpeereid.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
getrusage.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
gettimeofday.c Clean up newlines following left parentheses 2020-01-30 13:42:14 -03:00
inet_aton.c Correct include file name in inet_aton fallback. 2017-10-01 17:41:00 -07:00
inet_net_ntop.c Avoid conflicts with library versions of inet_net_ntop() and friends. 2019-08-18 19:27:23 -04:00
kill.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
link.c Move pg_upgrade's Windows link() implementation to AC_REPLACE_FUNCS 2020-03-04 08:22:54 +01:00
mkdtemp.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
noblock.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
open.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
path.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_bitutils.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_crc32c_armv8.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_crc32c_armv8_choose.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_crc32c_sb8.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_crc32c_sse42.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_crc32c_sse42_choose.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pg_strong_random.c Remove optimization for RAND_poll() failing. 2020-07-25 14:50:59 -07:00
pgcheckdir.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pgmkdirp.c Fix various typos and grammar errors in comments. 2015-04-26 18:42:31 +02:00
pgsleep.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pgstrcasecmp.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pgstrsignal.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pqsignal.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pread.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
pthread-win32.h Remove cvs keywords from all files. 2010-09-20 22:08:53 +02:00
pwrite.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
qsort.c Get rid of trailing semicolons in C macro definitions. 2020-05-01 17:28:00 -04:00
qsort_arg.c Get rid of trailing semicolons in C macro definitions. 2020-05-01 17:28:00 -04:00
quotes.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
random.c Clear some style deviations. 2020-05-21 08:31:16 -07:00
snprintf.c Dial back -Wimplicit-fallthrough to level 3 2020-05-13 15:31:14 -04:00
srandom.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
strerror.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
strlcat.c pgindent run for 9.4 2014-05-06 12:12:18 -04:00
strlcpy.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
strnlen.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
strtof.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
system.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
tar.c Make the order of the header file includes consistent in non-backend modules. 2019-10-25 07:41:52 +05:30
thread.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
unsetenv.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
win32.ico Revert binary change in copyright year adjustment. 2012-01-01 19:40:13 -05:00
win32env.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
win32error.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
win32security.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
win32setlocale.c Update copyrights for 2020 2020-01-01 12:21:45 -05:00
win32ver.rc Remove win32ver.rc from version_stamp.pl 2020-03-10 11:21:41 +01:00

README

src/port/README

libpgport
=========

libpgport must have special behavior.  It supplies functions to both
libraries and applications.  However, there are two complexities:

1)  Libraries need to use object files that are compiled with exactly
the same flags as the library.  libpgport might not use the same flags,
so it is necessary to recompile the object files for individual
libraries.  This is done by removing -lpgport from the link line:

        # Need to recompile any libpgport object files
        LIBS := $(filter-out -lpgport, $(LIBS))

and adding infrastructure to recompile the object files:

        OBJS= execute.o typename.o descriptor.o data.o error.o prepare.o memory.o \
                connect.o misc.o path.o exec.o \
                $(filter strlcat.o, $(LIBOBJS))

The problem is that there is no testing of which object files need to be
added, but missing functions usually show up when linking user
applications.

2) For applications, we use -lpgport before -lpq, so the static files
from libpgport are linked first.  This avoids having applications
dependent on symbols that are _used_ by libpq, but not intended to be
exported by libpq.  libpq's libpgport usage changes over time, so such a
dependency is a problem.  Windows, Linux, and macOS use an export list to
control the symbols exported by libpq.