1. 05 Oct, 2020 7 commits
    • Bruce Momjian's avatar
      Overhaul pg_hba.conf clientcert's API · 253f1025
      Bruce Momjian authored
      Since PG 12, clientcert no longer supported only on/off, so remove 1/0
      as possible values, and instead support only the text strings
      'verify-ca' and 'verify-full'.
      
      Remove support for 'no-verify' since that is possible by just not
      specifying clientcert.
      
      Also, throw an error if 'verify-ca' is used and 'cert' authentication is
      used, since cert authentication requires verify-full.
      
      Also improve the docs.
      
      THIS IS A BACKWARD INCOMPATIBLE API CHANGE.
      
      Reported-by: Kyotaro Horiguchi
      
      Discussion: https://postgr.es/m/20200716.093012.1627751694396009053.horikyota.ntt@gmail.com
      
      Author: Kyotaro Horiguchi
      
      Backpatch-through: master
      253f1025
    • Tom Lane's avatar
      Include the process PID in assertion-failure messages. · 18c170a0
      Tom Lane authored
      This should help to identify what happened when studying the postmaster
      log after-the-fact.
      
      While here, clean up some old comments in the same function.
      
      Discussion: https://postgr.es/m/1568983.1601845687@sss.pgh.pa.us
      18c170a0
    • Tom Lane's avatar
      Fix two latent(?) bugs in equivclass.c. · 53c6daff
      Tom Lane authored
      get_eclass_for_sort_expr() computes expr_relids and nullable_relids
      early on, even though they won't be needed unless we make a new
      EquivalenceClass, which we often don't.  Aside from the probably-minor
      inefficiency, there's a memory management problem: these bitmapsets will
      be built in the caller's context, leading to dangling pointers if that
      is shorter-lived than root->planner_cxt.  This would be a live bug if
      get_eclass_for_sort_expr() could be called with create_it = true during
      GEQO join planning.  So far as I can find, the core code never does
      that, but it's hard to be sure that no extensions do, especially since
      the comments make it clear that that's supposed to be a supported case.
      Fix by not computing these values until we've switched into planner_cxt
      to build the new EquivalenceClass.
      
      generate_join_implied_equalities() uses inner_rel->relids to look up
      relevant eclasses, but it ought to be using nominal_inner_relids.
      This is presently harmless because a child RelOptInfo will always have
      exactly the same eclass_indexes as its topmost parent; but that might
      not be true forever, and anyway it makes the code confusing.
      
      The first of these is old (introduced by me in f3b3b8d5), so back-patch
      to all supported branches.  The second only dates to v13, but we might
      as well back-patch it to keep the code looking similar across branches.
      
      Discussion: https://postgr.es/m/1508010.1601832581@sss.pgh.pa.us
      53c6daff
    • Tom Lane's avatar
      Doc: fix parameter names in the docs of a couple of functions. · 9cc3d614
      Tom Lane authored
      The descriptions of make_interval() and pg_options_to_table()
      were randomly different from the reality embedded in pg_proc.
      
      (These are not all the discrepancies I found in a quick search,
      but the others perhaps require more discussion, since there's
      at least a case to be made for changing pg_proc not the docs.)
      
      make_interval issue noted by Thomas Kellerer.
      
      Discussion: https://postgr.es/m/7b154ef0-9f22-90b9-7734-4bf23686695b@gmx.net
      9cc3d614
    • Peter Eisentraut's avatar
      Support for OUT parameters in procedures · 2453ea14
      Peter Eisentraut authored
      Unlike for functions, OUT parameters for procedures are part of the
      signature.  Therefore, they have to be listed in pg_proc.proargtypes
      as well as mentioned in ALTER PROCEDURE and DROP PROCEDURE.
      Reviewed-by: default avatarAndrew Dunstan <andrew.dunstan@2ndquadrant.com>
      Reviewed-by: default avatarPavel Stehule <pavel.stehule@gmail.com>
      Discussion: https://www.postgresql.org/message-id/flat/2b8490fe-51af-e671-c504-47359dc453c5@2ndquadrant.com
      2453ea14
    • Tom Lane's avatar
      Improve stability of identity.sql regression test. · e8997420
      Tom Lane authored
      I noticed while trying to run the regression tests under a low
      geqo_threshold that one query on information_schema.columns had
      unstable (as in, variable from one run to the next) output order.
      This is pretty unsurprising given the complexity of the underlying
      plan.  Interestingly, of this test's three nigh-identical queries on
      information_schema.columns, the other two already had ORDER BY clauses
      guaranteeing stable output.  Let's make this one look the same.
      
      Back-patch to v10 where this test was added.  We've not heard field
      reports of the test failing, but this experience shows that it can
      happen when testing under even slightly unusual conditions.
      e8997420
    • Michael Paquier's avatar
      Fix handling of redundant options with COPY for "freeze" and "header" · 10c5291c
      Michael Paquier authored
      The handling of those options was inconsistent, as the processing used
      directly the value assigned to the option to check if it was redundant,
      leading to patterns like this one to succeed (note that false is
      specified first):
      COPY hoge to '/path/to/file/' (header off, header on);
      
      And the opposite would fail correctly (note that true is first here):
      COPY hoge to '/path/to/file/' (header on, header off);
      
      While on it, add some tests to check for all redundant patterns with the
      options of COPY.  I have gone through the code and did not notice
      similar mistakes for other commands.
      
      "header" got it wrong since b63990c6, and "freeze" was wrong from the
      start as of 8de72b66.  No backpatch is done per the lack of complaints.
      
      Reported-by: Rémi Lapeyre
      Discussion: https://postgr.es/m/20200929072433.GA15570@paquier.xyz
      Discussion: https://postgr.es/m/0B55BD07-83E4-439F-AACC-FA2D7CF50532@lenstra.fr
      10c5291c
  2. 04 Oct, 2020 1 commit
    • Tom Lane's avatar
      Make postgres.bki use the same literal-string syntax as postgresql.conf. · 97b61448
      Tom Lane authored
      The BKI file's string quoting conventions were previously quite weird,
      perhaps as a result of repurposing a function built to scan
      single-quoted strings to scan double-quoted ones.  Change to use the
      same rules as we use in GUC files, allowing some simplifications in
      genbki.pl and initdb.c.
      
      While at it, completely remove the backend's scanstr() function, which
      was essentially a duplicate of the string dequoting code in guc-file.l.
      Instead export that one (under a less generic name than it had) and let
      bootscanner.l use it.  Now we can clarify that scansup.c exists only to
      support the main lexer. We could alternatively have removed GUC_scanstr,
      but this way seems better since the previous arrangement could mislead
      a reader into thinking that scanstr() had something to do with the main
      lexer's handling of string literals.  Maybe it did once, but if so it
      was a long time ago.
      
      This patch does not bump catversion, since the initially-installed
      catalog contents don't change.  Note however that successful initdb
      after applying this patch will require up-to-date postgres.bki as well
      as postgres and initdb executables.
      
      In passing, remove a bunch of very-long-obsolete #include's in
      bootparse.y and bootscanner.l.
      
      John Naylor
      
      Discussion: https://postgr.es/m/CACPNZCtDpd18T0KATTmCggO2GdVC4ow86ypiq5ENff1VnauL8g@mail.gmail.com
      97b61448
  3. 03 Oct, 2020 3 commits
  4. 02 Oct, 2020 4 commits
  5. 01 Oct, 2020 5 commits
  6. 30 Sep, 2020 6 commits
    • Alvaro Herrera's avatar
      Reword partitioning error message · 9fc21227
      Alvaro Herrera authored
      The error message about columns in the primary key not including all of
      the partition key was unclear; reword it.
      
      Backpatch all the way to pg11, where it appeared.
      Reported-by: default avatarNagaraj Raj <nagaraj.sf@yahoo.com>
      Discussion: https://postgr.es/m/64062533.78364.1601415362244@mail.yahoo.com
      9fc21227
    • Tom Lane's avatar
      Fix handling of BC years in to_date/to_timestamp. · 489c9c34
      Tom Lane authored
      Previously, a conversion such as
      	to_date('-44-02-01','YYYY-MM-DD')
      would result in '0045-02-01 BC', as the code attempted to interpret
      the negative year as BC, but failed to apply the correction needed
      for our internal handling of BC years.  Fix the off-by-one problem.
      
      Also, arrange for the combination of a negative year and an
      explicit "BC" marker to cancel out and produce AD.  This is how
      the negative-century case works, so it seems sane to do likewise.
      
      Continue to read "year 0000" as 1 BC.  Oracle would throw an error,
      but we've accepted that case for a long time so I'm hesitant to
      change it in a back-patch.
      
      Per bug #16419 from Saeed Hubaishan.  Back-patch to all supported
      branches.
      
      Dar Alathar-Yemen and Tom Lane
      
      Discussion: https://postgr.es/m/16419-d8d9db0a7553f01b@postgresql.org
      489c9c34
    • Heikki Linnakangas's avatar
    • Peter Eisentraut's avatar
      Fix XML id to match GUC name · 300b6984
      Peter Eisentraut authored
      For some reason, the id of the description of
      max_parallel_maintenance_workers has been
      guc-max-parallel-workers-maintenance since the beginning.  Flip that
      around to make it consistent.
      300b6984
    • Tom Lane's avatar
      Remove obsolete replication settings within TAP tests. · 151c0c5f
      Tom Lane authored
      PostgresNode.pm set "max_wal_senders = 5" for replication testing,
      but this seems to be slightly too low for our current test suite.
      Slower buildfarm members frequently report "number of requested standby
      connections exceeds max_wal_senders" failures, due to old walsenders
      not exiting instantaneously.  Usually, the test does not fail overall
      because of automatic walreceiver restart, but sometimes the failure
      becomes visible; and in any case such retries slow down the test.
      
      That value came in with commit 89ac7004, but was soon obsoleted by
      f6d6d292, which raised the built-in default from zero to 10; so that
      PostgresNode.pm is actually setting it to less than the conservative
      built-in default.  That seems pretty pointless, so let's remove the
      special setting and let the default prevail, in hopes of making
      the TAP tests more robust.
      
      Likewise, the setting "max_replication_slots = 5" is obsolete and
      can be removed.
      
      While here, reverse-engineer a comment about why we're choosing
      less-than-default values for some other settings.
      
      (Note: before v12, max_wal_senders counted against max_connections
      so that the latter setting also needs some fiddling with.)
      
      Back-patch to v10 where the subscription tests were added.
      It's likely that the older branches aren't pushing the boundaries
      of max_wal_senders, but I'm disinclined to spend time trying to
      figure out exactly when it started to be a problem.
      
      Discussion: https://postgr.es/m/723911.1601417626@sss.pgh.pa.us
      151c0c5f
    • David Rowley's avatar
      Doc: Improve clarity on partitioned table limitations · 2b888647
      David Rowley authored
      Explicitly mention that primary key constraints are also included in the
      limitation that the constraint columns must be a superset of the partition key
      columns.
      
      Wording suggestion from Tom Lane.
      
      Discussion: https://postgr.es/m/64062533.78364.1601415362244@mail.yahoo.com
      Backpatch-through: 11, where unique constraints on partitioned tables were added
      2b888647
  7. 29 Sep, 2020 8 commits
    • Tom Lane's avatar
      Fix make_timestamp[tz] to accept negative years as meaning BC. · a094c8ff
      Tom Lane authored
      Previously we threw an error.  But make_date already allowed the case,
      so it is inconsistent as well as unhelpful for make_timestamp not to.
      
      Both functions continue to reject year zero.
      
      Code and test fixes by Peter Eisentraut, doc changes by me
      
      Discussion: https://postgr.es/m/13c0992c-f15a-a0ca-d839-91d3efd965d9@2ndquadrant.com
      a094c8ff
    • Tom Lane's avatar
      Fix memory leak in plpgsql's CALL processing. · a6b1f536
      Tom Lane authored
      When executing a CALL or DO in a non-atomic context (i.e., not inside
      a function or query), plpgsql creates a new plan each time through,
      as a rather hacky solution to some resource management issues.  But
      it failed to free this plan until exit of the current procedure or DO
      block, resulting in serious memory bloat in procedures that called
      other procedures many times.  Fix by remembering to free the plan,
      and by being more honest about restoring the previous state (otherwise,
      recursive procedure calls have a problem).
      
      There was also a smaller leak associated with recalculation of the
      "target" list of output variables.  Fix that by using the statement-
      lifespan context to hold non-permanent values.
      
      Back-patch to v11 where procedures were introduced.
      
      Pavel Stehule and Tom Lane
      
      Discussion: https://postgr.es/m/CAFj8pRDiiU1dqym+_P4_GuTWm76knJu7z9opWayBJTC0nQGUUA@mail.gmail.com
      a6b1f536
    • Alexander Korotkov's avatar
      Support for ISO 8601 in the jsonpath .datetime() method · 927d9abb
      Alexander Korotkov authored
      The SQL standard doesn't require jsonpath .datetime() method to support the
      ISO 8601 format.  But our to_json[b]() functions convert timestamps to text in
      the ISO 8601 format in the sake of compatibility with javascript.  So, we add
      support of the  ISO 8601 to the jsonpath .datetime() in the sake compatibility
      with to_json[b]().
      
      The standard mode of datetime parsing currently supports just template patterns
      and separators in the format string.  In order to implement ISO 8601, we have to
      add support of the format string double quotes to the standard parsing mode.
      
      Discussion: https://postgr.es/m/94321be0-cc96-1a81-b6df-796f437f7c66%40postgrespro.ru
      Author: Nikita Glukhov, revised by me
      Backpatch-through: 13
      927d9abb
    • Alexander Korotkov's avatar
      Remove excess space from jsonpath .datetime() default format string · c2aa562e
      Alexander Korotkov authored
      bffe1bd6 has introduced jsonpath .datetime() method, but default formats
      for time and timestamp contain excess space between time and timezone.  This
      commit removes this excess space making behavior of .datetime() method
      standard-compliant.
      
      Discussion: https://postgr.es/m/94321be0-cc96-1a81-b6df-796f437f7c66%40postgrespro.ru
      Author: Nikita Glukhov
      Backpatch-through: 13
      c2aa562e
    • Fujii Masao's avatar
      Archive timeline history files in standby if archive_mode is set to "always". · fd26f782
      Fujii Masao authored
      Previously the standby server didn't archive timeline history files
      streamed from the primary even when archive_mode is set to "always",
      while it archives the streamed WAL files. This could cause the PITR to
      fail because there was no required timeline history file in the archive.
      The cause of this issue was that walreceiver didn't mark those files as
      ready for archiving.
      
      This commit makes walreceiver mark those streamed timeline history
      files as ready for archiving if archive_mode=always. Then the archiver
      process archives the marked timeline history files.
      
      Back-patch to all supported versions.
      
      Reported-by: Grigory Smolkin
      Author: Grigory Smolkin, Fujii Masao
      Reviewed-by: David Zhang, Anastasia Lubennikova
      Discussion: https://postgr.es/m/54b059d4-2b48-13a4-6f43-95a087c92367@postgrespro.ru
      fd26f782
    • Michael Paquier's avatar
      Fix progress reporting of REINDEX CONCURRENTLY · e66bcfb4
      Michael Paquier authored
      This addresses a couple of issues with the so-said subject:
      - Report the correct parent relation with the index actually being
      rebuilt or validated.  Previously, the command status remained set to
      the last index created for the progress of the index build and
      validation, which would be incorrect when working on a table that has
      more than one index.
      - Use the correct phase when waiting before the drop of the old
      indexes.  Previously, this was reported with the same status as when
      waiting before the old indexes are marked as dead.
      
      Author: Matthias van de Meent, Michael Paquier
      Discussion: https://postgr.es/m/CAEze2WhqFgcwe1_tv=sFYhLWV2AdpfukumotJ6JNcAOQs3jufg@mail.gmail.com
      Backpatch-through: 12
      e66bcfb4
    • Tom Lane's avatar
      Add for_each_from, to simplify loops starting from non-first list cells. · 56fe0089
      Tom Lane authored
      We have a dozen or so places that need to iterate over all but the
      first cell of a List.  Prior to v13 this was typically written as
      	for_each_cell(lc, lnext(list_head(list)))
      Commit 1cff1b95 changed these to
      	for_each_cell(lc, list, list_second_cell(list))
      This patch introduces a new macro for_each_from() which expresses
      the start point as a list index, allowing these to be written as
      	for_each_from(lc, list, 1)
      This is marginally more efficient, since ForEachState.i can be
      initialized directly instead of backing into it from a ListCell
      address.  It also seems clearer and less typo-prone.
      
      Some of the remaining uses of for_each_cell() look like they could
      profitably be changed to for_each_from(), but here I confined myself
      to changing uses of list_second_cell().
      
      Also, fix for_each_cell_setup() and for_both_cell_setup() to
      const-ify their arguments; that's a simple oversight in 1cff1b95.
      
      Back-patch into v13, on the grounds that (1) the const-ification
      is a minor bug fix, and (2) it's better for back-patching purposes
      if we only have two ways to write these loops rather than three.
      
      In HEAD, also remove list_third_cell() and list_fourth_cell(),
      which were also introduced in 1cff1b95, and are unused as of
      cc99baa4.  It seems unlikely that any third-party code would
      have started to use them already; anyone who has can be directed
      to list_nth_cell instead.
      
      Discussion: https://postgr.es/m/CAApHDvpo1zj9KhEpU2cCRZfSM3Q6XGdhzuAS2v79PH7WJBkYVA@mail.gmail.com
      56fe0089
    • Michael Paquier's avatar
      Revert "Change SHA2 implementation based on OpenSSL to use EVP digest routines" · fe0a1dc5
      Michael Paquier authored
      This reverts commit e21cbb4b, as the switch to EVP routines requires a
      more careful design where we would need to have at least our wrapper
      routines return a status instead of issuing an error by themselves to
      let the caller do the error handling.  The memory handling was also
      incorrect and could cause leaks in the backend if a failure happened,
      requiring most likely a callback to do the necessary cleanup as the only
      clean way to be able to allocate an EVP context requires the use of an
      allocation within OpenSSL.  The potential rework of the wrappers also
      impacts the fallback implementation when not building with OpenSSL.
      
      Originally, prairiedog has reported a compilation failure, but after
      discussion with Tom Lane this needs a better design.
      
      Discussion: https://postgr.es/m/20200928073330.GC2316@paquier.xyz
      fe0a1dc5
  8. 28 Sep, 2020 6 commits