1. 08 Aug, 2016 20 commits
    • Tom Lane's avatar
      Stamp 9.6beta4. · 67c08c0d
      Tom Lane authored
      67c08c0d
    • Bruce Momjian's avatar
      doc: update list of pg_trgm authors · cfdadf5f
      Bruce Momjian authored
      Author: Oleg Bartunov
      cfdadf5f
    • Tom Lane's avatar
      Update 9.6 release notes through today. · de4b3ea1
      Tom Lane authored
      de4b3ea1
    • Tom Lane's avatar
      Last-minute updates for release notes. · 9b8271c5
      Tom Lane authored
      Security: CVE-2016-5423, CVE-2016-5424
      9b8271c5
    • Peter Eisentraut's avatar
      Fix several one-byte buffer over-reads in to_number · 9a46324f
      Peter Eisentraut authored
      Several places in NUM_numpart_from_char(), which is called from the SQL
      function to_number(text, text), could accidentally read one byte past
      the end of the input buffer (which comes from the input text datum and
      is not null-terminated).
      
      1. One leading space character would be skipped, but there was no check
         that the input was at least one byte long.  This does not happen in
         practice, but for defensiveness, add a check anyway.
      
      2. Commit 4a3a1e2c apparently accidentally doubled that code that skips
         one space character (so that two spaces might be skipped), but there
         was no overflow check before skipping the second byte.  Fix by
         removing that duplicate code.
      
      3. A logic error would allow a one-byte over-read when looking for a
         trailing sign (S) placeholder.
      
      In each case, the extra byte cannot be read out directly, but looking at
      it might cause a crash.
      
      The third item was discovered by Piotr Stefaniak, the first two were
      found and analyzed by Tom Lane and Peter Eisentraut.
      9a46324f
    • Peter Eisentraut's avatar
      Translation updates · 34927b29
      Peter Eisentraut authored
      Source-Git-URL: git://git.postgresql.org/git/pgtranslation/messages.git
      Source-Git-Hash: cda21c1d7b160b303dc21dfe9d4169f2c8064c60
      34927b29
    • Tom Lane's avatar
      Fix two errors with nested CASE/WHEN constructs. · f0c7b789
      Tom Lane authored
      ExecEvalCase() tried to save a cycle or two by passing
      &econtext->caseValue_isNull as the isNull argument to its sub-evaluation of
      the CASE value expression.  If that subexpression itself contained a CASE,
      then *isNull was an alias for econtext->caseValue_isNull within the
      recursive call of ExecEvalCase(), leading to confusion about whether the
      inner call's caseValue was null or not.  In the worst case this could lead
      to a core dump due to dereferencing a null pointer.  Fix by not assigning
      to the global variable until control comes back from the subexpression.
      Also, avoid using the passed-in isNull pointer transiently for evaluation
      of WHEN expressions.  (Either one of these changes would have been
      sufficient to fix the known misbehavior, but it's clear now that each of
      these choices was in itself dangerous coding practice and best avoided.
      There do not seem to be any similar hazards elsewhere in execQual.c.)
      
      Also, it was possible for inlining of a SQL function that implements the
      equality operator used for a CASE comparison to result in one CASE
      expression's CaseTestExpr node being inserted inside another CASE
      expression.  This would certainly result in wrong answers since the
      improperly nested CaseTestExpr would be caused to return the inner CASE's
      comparison value not the outer's.  If the CASE values were of different
      data types, a crash might result; moreover such situations could be abused
      to allow disclosure of portions of server memory.  To fix, teach
      inline_function to check for "bare" CaseTestExpr nodes in the arguments of
      a function to be inlined, and avoid inlining if there are any.
      
      Heikki Linnakangas, Michael Paquier, Tom Lane
      
      Report: https://github.com/greenplum-db/gpdb/pull/327
      Report: <4DDCEEB8.50602@enterprisedb.com>
      Security: CVE-2016-5423
      f0c7b789
    • Noah Misch's avatar
      Obstruct shell, SQL, and conninfo injection via database and role names. · fcd15f13
      Noah Misch authored
      Due to simplistic quoting and confusion of database names with conninfo
      strings, roles with the CREATEDB or CREATEROLE option could escalate to
      superuser privileges when a superuser next ran certain maintenance
      commands.  The new coding rule for PQconnectdbParams() calls, documented
      at conninfo_array_parse(), is to pass expand_dbname=true and wrap
      literal database names in a trivial connection string.  Escape
      zero-length values in appendConnStrVal().  Back-patch to 9.1 (all
      supported versions).
      
      Nathan Bossart, Michael Paquier, and Noah Misch.  Reviewed by Peter
      Eisentraut.  Reported by Nathan Bossart.
      
      Security: CVE-2016-5424
      fcd15f13
    • Noah Misch's avatar
      Promote pg_dumpall shell/connstr quoting functions to src/fe_utils. · 41f18f02
      Noah Misch authored
      Rename these newly-extern functions with terms more typical of their new
      neighbors.  No functional changes; a subsequent commit will use them in
      more places.  Back-patch to 9.1 (all supported versions).  Back branches
      lack src/fe_utils, so instead rename the functions in place; the
      subsequent commit will copy them into the other programs using them.
      
      Security: CVE-2016-5424
      41f18f02
    • Noah Misch's avatar
      Fix Windows shell argument quoting. · bd653718
      Noah Misch authored
      The incorrect quoting may have permitted arbitrary command execution.
      At a minimum, it gave broader control over the command line to actors
      supposed to have control over a single argument.  Back-patch to 9.1 (all
      supported versions).
      
      Security: CVE-2016-5424
      bd653718
    • Noah Misch's avatar
      Reject, in pg_dumpall, names containing CR or LF. · 142c24c2
      Noah Misch authored
      These characters prematurely terminate Windows shell command processing,
      causing the shell to execute a prefix of the intended command.  The
      chief alternative to rejecting these characters was to bypass the
      Windows shell with CreateProcess(), but the ability to use such names
      has little value.  Back-patch to 9.1 (all supported versions).
      
      This change formally revokes support for these characters in database
      names and roles names.  Don't document this; the error message is
      self-explanatory, and too few users would benefit.  A future major
      release may forbid creation of databases and roles so named.  For now,
      check only at known weak points in pg_dumpall.  Future commits will,
      without notice, reject affected names from other frontend programs.
      
      Also extend the restriction to pg_dumpall --dbname=CONNSTR arguments and
      --file arguments.  Unlike the effects on role name arguments and
      database names, this does not reflect a broad policy change.  A
      migration to CreateProcess() could lift these two restrictions.
      
      Reviewed by Peter Eisentraut.
      
      Security: CVE-2016-5424
      142c24c2
    • Noah Misch's avatar
      Field conninfo strings throughout src/bin/scripts. · c4007171
      Noah Misch authored
      These programs nominally accepted conninfo strings, but they would
      proceed to use the original dbname parameter as though it were an
      unadorned database name.  This caused "reindexdb dbname=foo" to issue an
      SQL command that always failed, and other programs printed a conninfo
      string in error messages that purported to print a database name.  Fix
      both problems by using PQdb() to retrieve actual database names.
      Continue to print the full conninfo string when reporting a connection
      failure.  It is informative there, and if the database name is the sole
      problem, the server-side error message will include the name.  Beyond
      those user-visible fixes, this allows a subsequent commit to synthesize
      and use conninfo strings without that implementation detail leaking into
      messages.  As a side effect, the "vacuuming database" message now
      appears after, not before, the connection attempt.  Back-patch to 9.1
      (all supported versions).
      
      Reviewed by Michael Paquier and Peter Eisentraut.
      
      Security: CVE-2016-5424
      c4007171
    • Noah Misch's avatar
      Introduce a psql "\connect -reuse-previous=on|off" option. · 9d924e9a
      Noah Misch authored
      The decision to reuse values of parameters from a previous connection
      has been based on whether the new target is a conninfo string.  Add this
      means of overriding that default.  This feature arose as one component
      of a fix for security vulnerabilities in pg_dump, pg_dumpall, and
      pg_upgrade, so back-patch to 9.1 (all supported versions).  In 9.3 and
      later, comment paragraphs that required update had already-incorrect
      claims about behavior when no connection is open; fix those problems.
      
      Security: CVE-2016-5424
      9d924e9a
    • Noah Misch's avatar
      Sort out paired double quotes in \connect, \password and \crosstabview. · 984e5beb
      Noah Misch authored
      In arguments, these meta-commands wrongly treated each pair as closing
      the double quoted string.  Make the behavior match the documentation.
      This is a compatibility break, but I more expect to find software with
      untested reliance on the documented behavior than software reliant on
      today's behavior.  Back-patch to 9.1 (all supported versions).
      
      Reviewed by Tom Lane and Peter Eisentraut.
      
      Security: CVE-2016-5424
      984e5beb
    • Peter Eisentraut's avatar
      doc: Update benchmark results · a1f8b6bd
      Peter Eisentraut authored
      From: Alexander Law <exclusion@gmail.com>
      a1f8b6bd
    • Peter Eisentraut's avatar
      Make format() error messages consistent again · 8a56d4e3
      Peter Eisentraut authored
      07d25a96 changed only one occurrence.  Change the other one as well.
      8a56d4e3
    • Tom Lane's avatar
      Update 9.6 release notes through today. · be7f7ee5
      Tom Lane authored
      be7f7ee5
    • Peter Eisentraut's avatar
      Correct column name in information schema · d8710f18
      Peter Eisentraut authored
      Although the standard has routines.result_cast_character_set_name, given
      the naming of the surrounding columns, we concluded that this must have
      been a mistake and that result_cast_char_set_name was intended, so
      change the implementation.  The documentation was already using the new
      name.
      
      found by Clément Prévost <prevostclement@gmail.com>
      d8710f18
    • Tom Lane's avatar
      19322c0a
    • Peter Eisentraut's avatar
  2. 07 Aug, 2016 6 commits
    • Tom Lane's avatar
      Fix misestimation of n_distinct for a nearly-unique column with many nulls. · 95bee941
      Tom Lane authored
      If ANALYZE found no repeated non-null entries in its sample, it set the
      column's stadistinct value to -1.0, intending to indicate that the entries
      are all distinct.  But what this value actually means is that the number
      of distinct values is 100% of the table's rowcount, and thus it was
      overestimating the number of distinct values by however many nulls there
      are.  This could lead to very poor selectivity estimates, as for example
      in a recent report from Andreas Joseph Krogh.  We should discount the
      stadistinct value by whatever we've estimated the nulls fraction to be.
      (That is what will happen if we choose to use a negative stadistinct for
      a column that does have repeated entries, so this code path was just
      inconsistent.)
      
      In addition to fixing the stadistinct entries stored by several different
      ANALYZE code paths, adjust the logic where get_variable_numdistinct()
      forces an "all distinct" estimate on the basis of finding a relevant unique
      index.  Unique indexes don't reject nulls, so there's no reason to assume
      that the null fraction doesn't apply.
      
      Back-patch to all supported branches.  Back-patching is a bit of a judgment
      call, but this problem seems to affect only a few users (else we'd have
      identified it long ago), and it's bad enough when it does happen that
      destabilizing plan choices in a worse direction seems unlikely.
      
      Patch by me, with documentation wording suggested by Dean Rasheed
      
      Report: <VisenaEmail.26.df42f82acae38a58.156463942b8@tc7-visena>
      Discussion: <16143.1470350371@sss.pgh.pa.us>
      95bee941
    • Tom Lane's avatar
      Fix crash when pg_get_viewdef_name_ext() is passed a non-view relation. · 8a8c6b53
      Tom Lane authored
      Oversight in commit 976b24fb.
      
      Andreas Seltenreich
      
      Report: <87y448l3ag.fsf@credativ.de>
      8a8c6b53
    • Tom Lane's avatar
      Fix TOAST access failure in RETURNING queries. · 9ee1cf04
      Tom Lane authored
      Discussion of commit 3e2f3c2e exposed a problem that is of longer
      standing: since we don't detoast data while sticking it into a portal's
      holdStore for PORTAL_ONE_RETURNING and PORTAL_UTIL_SELECT queries, and we
      release the query's snapshot as soon as we're done loading the holdStore,
      later readout of the holdStore can do TOAST fetches against data that can
      no longer be seen by any of the session's live snapshots.  This means that
      a concurrent VACUUM could remove the TOAST data before we can fetch it.
      Commit 3e2f3c2e exposed the problem by showing that sometimes we had *no*
      live snapshots while fetching TOAST data, but we'd be at risk anyway.
      
      I believe this code was all right when written, because our management of a
      session's exposed xmin was such that the TOAST references were safe until
      end of transaction.  But that's no longer true now that we can advance or
      clear our PGXACT.xmin intra-transaction.
      
      To fix, copy the query's snapshot during FillPortalStore() and save it in
      the Portal; release it only when the portal is dropped.  This essentially
      implements a policy that we must hold a relevant snapshot whenever we
      access potentially-toasted data.  We had already come to that conclusion
      in other places, cf commits 08e261cb and ec543db7.
      
      I'd have liked to add a regression test case for this, but I didn't see
      a way to make one that's not unreasonably bloated; it seems to require
      returning a toasted value to the client, and those will be big.
      
      In passing, improve PortalRunUtility() so that it positively verifies
      that its ending PopActiveSnapshot() call will pop the expected snapshot,
      removing a rather shaky assumption about which utility commands might
      do their own PopActiveSnapshot().  There's no known bug here, but now
      that we're actively referencing the snapshot it's almost free to make
      this code a bit more bulletproof.
      
      We might want to consider back-patching something like this into older
      branches, but it would be prudent to let it prove itself more in HEAD
      beforehand.
      
      Discussion: <87vazemeda.fsf@credativ.de>
      9ee1cf04
    • Tom Lane's avatar
      Avoid crashing in GetOldestSnapshot() if there are no known snapshots. · 07a601ee
      Tom Lane authored
      The sole caller expects NULL to be returned in such a case, so make
      it so and document it.
      
      Per reports from Andreas Seltenreich and Regina Obe.  This doesn't
      really fix their problem, as now their RETURNING queries will say
      "ERROR: no known snapshots", but in any case this function should
      not dump core in a reasonably-foreseeable situation.
      
      Report: <87vazemeda.fsf@credativ.de>
      Report: <20160807051854.1427.32414@wrigleys.postgresql.org>
      07a601ee
    • Tom Lane's avatar
      Don't propagate a null subtransaction snapshot up to parent transaction. · bcbecbce
      Tom Lane authored
      This oversight could cause logical decoding to fail to decode an outer
      transaction containing changes, if a subtransaction had an XID but no
      actual changes.  Per bug #14279 from Marko Tiikkaja.  Patch by Marko
      based on analysis by Andrew Gierth.
      
      Discussion: <20160804191757.1430.39011@wrigleys.postgresql.org>
      bcbecbce
    • Tom Lane's avatar
      First-draft release notes for 9.5.4. · 3676631c
      Tom Lane authored
      As usual, the release notes for other branches will be made by cutting
      these down, but put them up for community review first.
      3676631c
  3. 06 Aug, 2016 1 commit
    • Tom Lane's avatar
      In B-tree page deletion, clean up properly after page deletion failure. · e89526d4
      Tom Lane authored
      In _bt_unlink_halfdead_page(), we might fail to find an immediate left
      sibling of the target page, perhaps because of corruption of the page
      sibling links.  The code intends to cope with this by just abandoning
      the deletion attempt; but what actually happens is that it fails outright
      due to releasing the same buffer lock twice.  (And error recovery masks
      a second problem, which is possible leakage of a pin on another page.)
      Seems to have been introduced by careless refactoring in commit efada2b8.
      Since there are multiple cases to consider, let's make releasing the buffer
      lock in the failure case the responsibility of _bt_unlink_halfdead_page()
      not its caller.
      
      Also, avoid fetching the leaf page's left-link again after we've dropped
      lock on the page.  This is probably harmless, but it's not exactly good
      coding practice.
      
      Per report from Kyotaro Horiguchi.  Back-patch to 9.4 where the faulty code
      was introduced.
      
      Discussion: <20160803.173116.111915228.horiguchi.kyotaro@lab.ntt.co.jp>
      e89526d4
  4. 05 Aug, 2016 9 commits
    • Tom Lane's avatar
      Teach libpq to decode server version correctly from future servers. · 69dc5ae4
      Tom Lane authored
      Beginning with the next development cycle, PG servers will report two-part
      not three-part version numbers.  Fix libpq so that it will compute the
      correct numeric representation of such server versions for reporting by
      PQserverVersion().  It's desirable to get this into the field and
      back-patched ASAP, so that older clients are more likely to understand the
      new server version numbering by the time any such servers are in the wild.
      
      (The results with an old client would probably not be catastrophic anyway
      for a released server; for example "10.1" would be interpreted as 100100
      which would be wrong in detail but would not likely cause an old client to
      misbehave badly.  But "10devel" or "10beta1" would result in sversion==0
      which at best would result in disabling all use of modern features.)
      
      Extracted from a patch by Peter Eisentraut; comments added by me
      
      Patch: <802ec140-635d-ad86-5fdf-d3af0e260c22@2ndquadrant.com>
      69dc5ae4
    • Tom Lane's avatar
      Fix copy-and-pasteo in 81c766b3. · fc509cd8
      Tom Lane authored
      Report: <57A4E6DF.8070209@dunslane.net>
      fc509cd8
    • Tom Lane's avatar
      Make array_to_tsvector() sort and de-duplicate the given strings. · f10eab73
      Tom Lane authored
      This is required for the result to be a legal tsvector value.
      Noted while fooling with Andreas Seltenreich's ts_delete() crash.
      
      Discussion: <87invhoj6e.fsf@credativ.de>
      f10eab73
    • Tom Lane's avatar
      Fix ts_delete(tsvector, text[]) to cope with duplicate array entries. · c50d192c
      Tom Lane authored
      Such cases either failed an Assert, or produced a corrupt tsvector in
      non-Assert builds, as reported by Andreas Seltenreich.  The reason is
      that tsvector_delete_by_indices() just assumed that its input array had
      no duplicates.  Fix by explicitly de-duping.
      
      In passing, improve some comments, and fix a number of tests for null
      values to use ERRCODE_NULL_VALUE_NOT_ALLOWED not
      ERRCODE_INVALID_PARAMETER_VALUE.
      
      Discussion: <87invhoj6e.fsf@credativ.de>
      c50d192c
    • Tom Lane's avatar
      Re-pgindent tsvector_op.c. · 33fe7360
      Tom Lane authored
      Messed up by recent commits --- this is annoying me while trying to fix
      some bugs here.
      33fe7360
    • Bruce Momjian's avatar
      docs: re-add spaces before units removed · 5ebad9a5
      Bruce Momjian authored
      This reverts the spaces before k/M/G/TB units removed for consistency in
      commit ca0c37b5.
      
      Discussion: 20160802165116.GC32575@momjian.us
      5ebad9a5
    • Tom Lane's avatar
      Update time zone data files to tzdata release 2016f. · a629330b
      Tom Lane authored
      DST law changes in Kemerovo and Novosibirsk.  Historical corrections for
      Azerbaijan, Belarus, and Morocco.  Asia/Novokuznetsk and Asia/Novosibirsk
      now use numeric time zone abbreviations instead of invented ones.  Zones
      for Antarctic bases and other locations that have been uninhabited for
      portions of the time span known to the tzdata database now report "-00"
      rather than "zzz" as the zone abbreviation for those time spans.
      
      Also, I decided to remove some of the timezone/data/ files that we don't
      use.  At one time that subdirectory was a complete copy of what IANA
      distributes in the tzdata tarballs, but that hasn't been true for a long
      time.  There seems no good reason to keep shipping those specific files
      but not others; they're just bloating our tarballs.
      a629330b
    • Robert Haas's avatar
      Change InitToastSnapshot to a macro. · 81c766b3
      Robert Haas authored
      tqual.h is included in some front-end compiles, and a static inline
      breaks on buildfarm member castoroides.  Since the macro is never
      referenced, it should dodge that problem, although this doesn't
      seem like the cleanest way of hiding things from front-end compiles.
      
      Report and review by Tom Lane; patch by me.
      81c766b3
    • Andres Freund's avatar
      Fix hard to hit race condition in heapam's tuple locking code. · e7caacf7
      Andres Freund authored
      As mentioned in its commit message, eca0f1db left open a race condition,
      where a page could be marked all-visible, after the code checked
      PageIsAllVisible() to pin the VM, but before the page is locked.  Plug
      that hole.
      
      Reviewed-By: Robert Haas, Andres Freund
      Author: Amit Kapila
      Discussion: CAEepm=3fWAbWryVW9swHyLTY4sXVf0xbLvXqOwUoDiNCx9mBjQ@mail.gmail.com
      Backpatch: -
      e7caacf7
  5. 04 Aug, 2016 2 commits
    • Bruce Momjian's avatar
      docs: mention rsync of temp and unlogged tables · 4eb4b3f2
      Bruce Momjian authored
      This happens when using rsync to pg_upgrade slaves.
      
      Reported-by: Jerry Sievers
      
      Discussion: 20160726161946.GA3511@momjian.us
      4eb4b3f2
    • Tom Lane's avatar
      Fix bogus coding in WaitForBackgroundWorkerShutdown(). · 8d498a5c
      Tom Lane authored
      Some conditions resulted in "return" directly out of a PG_TRY block,
      which left the exception stack dangling, and to add insult to injury
      failed to restore the state of set_latch_on_sigusr1.
      
      This is a bug only in 9.5; in HEAD it was accidentally fixed by commit
      db0f6cad, which removed the surrounding PG_TRY block.  However, I (tgl)
      chose to apply the patch to HEAD as well, because the old coding was
      gratuitously different from WaitForBackgroundWorkerStartup(), and there
      would indeed have been no bug if it were done like that to start with.
      
      Dmitry Ivanov
      
      Discussion: <1637882.WfYN5gPf1A@abook>
      8d498a5c
  6. 03 Aug, 2016 2 commits
    • Peter Eisentraut's avatar
    • Robert Haas's avatar
      Prevent "snapshot too old" from trying to return pruned TOAST tuples. · 3e2f3c2e
      Robert Haas authored
      Previously, we tested for MVCC snapshots to see whether they were too
      old, but not TOAST snapshots, which can lead to complaints about missing
      TOAST chunks if those chunks are subject to early pruning.  Ideally,
      the threshold lsn and timestamp for a TOAST snapshot would be that of
      the corresponding MVCC snapshot, but since we have no way of deciding
      which MVCC snapshot was used to fetch the TOAST pointer, use the oldest
      active or registered snapshot instead.
      
      Reported by Andres Freund, who also sketched out what the fix should
      look like.  Patch by me, reviewed by Amit Kapila.
      3e2f3c2e