1. 15 12月, 2009 4 次提交
  2. 14 12月, 2009 2 次提交
    • T
      Fix a bug introduced when set-returning SQL functions were made inline-able: · a620d500
      Tom Lane 提交于
      we have to cope with the possibility that the declared result rowtype contains
      dropped columns.  This fails in 8.4, as per bug #5240.
      
      While at it, be more paranoid about inserting binary coercions when inlining.
      The pre-8.4 code did not really need to worry about that because it could not
      inline at all in any case where an added coercion could change the behavior
      of the function's statement.  However, when inlining a SRF we allow sorting,
      grouping, and set-ops such as UNION.  In these cases, modifying one of the
      targetlist entries that the sort/group/setop depends on could conceivably
      change the behavior of the function's statement --- so don't inline when
      such a case applies.
      a620d500
    • I
      Additional fixes for large object access control. · 84f910a7
      Itagaki Takahiro 提交于
      Use pg_largeobject_metadata.oid instead of pg_largeobject.loid
      to enumerate existing large objects in pg_dump, pg_restore, and
      contrib modules.
      84f910a7
  3. 13 12月, 2009 2 次提交
    • M
      Allow LDAP authentication to operate in search+bind mode, meaning it · 0182d6f6
      Magnus Hagander 提交于
      does a search for the user in the directory first, and then binds with
      the DN found for this user.
      
      This allows for LDAP logins in scenarios where the DN of the user cannot
      be determined simply by prefix and suffix, such as the case where different
      users are located in different containers.
      
      The old way of authentication can be significantly faster, so it's kept
      as an option.
      
      Robert Fleming and Magnus Hagander
      0182d6f6
    • T
      Fix integer-to-bit-string conversions to handle the first fractional byte · a4e035b2
      Tom Lane 提交于
      correctly when the output bit width is wider than the given integer by
      something other than a multiple of 8 bits.
      
      This has been wrong since I first wrote that code for 8.0 :-(.  Kudos to
      Roman Kononov for being the first to notice, though I didn't use his
      patch.  Per bug #5237.
      a4e035b2
  4. 12 12月, 2009 3 次提交
    • R
      Export ExplainBeginOutput() and ExplainEndOutput() for auto_explain. · 02490d46
      Robert Haas 提交于
      Without these functions, anyone outside of explain.c can't actually use
      ExplainPrintPlan, because the ExplainState won't be initialized properly.
      The user-visible result of this was a crash when using auto_explain with
      the JSON output format.
      
      Report by Euler Taveira de Oliveira.  Analysis by Tom Lane.  Patch by me.
      02490d46
    • T
      Arrange to generate different random sequences in the different child · 6b45e3b7
      Tom Lane 提交于
      processes of a pgbench run, when we are using -j > 1 and are emulating
      threads via fork().  Otherwise the children all inherit the same random
      sequence state and produce the same random-number sequence.
      
      In the threaded case the different threads will share one RNG state, so
      they will produce different subsets of one sequence, which is maybe more
      correlated than a purist would like but will not be "the same".  So we
      leave that case alone.
      
      First noticed by Takahiro Itagaki, and is also part of the explanation
      for the pgbench misbehavior recently reported by Jaime Casanova.
      6b45e3b7
    • T
      Ensure that the result tuple of an EvalPlanQual cycle gets materialized · d8e511fa
      Tom Lane 提交于
      before we zap the input tuple.  Otherwise, pass-by-reference columns of
      the result slot are likely to contain just references to the input
      tuple, leading to big trouble if the pfree'd space is reused.  Per
      trouble report from Jaime Casanova.  This is a new bug in the recent
      rewrite of EvalPlanQual, so nothing to back-patch.
      d8e511fa
  5. 11 12月, 2009 4 次提交
  6. 10 12月, 2009 6 次提交
    • P
      Add init[db] option to pg_ctl · a37b001b
      Peter Eisentraut 提交于
      pg_ctl gets a new mode that runs initdb.  Adjust the documentation a bit to
      not assume that initdb is the only way to run database cluster initialization.
      But don't replace initdb as the canonical way.
      
      Author: Zdenek Kotala <Zdenek.Kotala@Sun.COM>
      a37b001b
    • R
      Fix levenshtein with costs. The previous code multiplied by the cost in only · da076414
      Robert Haas 提交于
      3 of the 7 relevant locations.
      
      Marcin Mank, slightly adjusted by me.
      da076414
    • T
      03d7b064
    • T
      Prevent indirect security attacks via changing session-local state within · 62aba765
      Tom Lane 提交于
      an allegedly immutable index function.  It was previously recognized that
      we had to prevent such a function from executing SET/RESET ROLE/SESSION
      AUTHORIZATION, or it could trivially obtain the privileges of the session
      user.  However, since there is in general no privilege checking for changes
      of session-local state, it is also possible for such a function to change
      settings in a way that might subvert later operations in the same session.
      Examples include changing search_path to cause an unexpected function to
      be called, or replacing an existing prepared statement with another one
      that will execute a function of the attacker's choosing.
      
      The present patch secures VACUUM, ANALYZE, and CREATE INDEX/REINDEX against
      these threats, which are the same places previously deemed to need protection
      against the SET ROLE issue.  GUC changes are still allowed, since there are
      many useful cases for that, but we prevent security problems by forcing a
      rollback of any GUC change after completing the operation.  Other cases are
      handled by throwing an error if any change is attempted; these include temp
      table creation, closing a cursor, and creating or deleting a prepared
      statement.  (In 7.4, the infrastructure to roll back GUC changes doesn't
      exist, so we settle for rejecting changes of "search_path" in these contexts.)
      
      Original report and patch by Gurjeet Singh, additional analysis by
      Tom Lane.
      
      Security: CVE-2009-4136
      62aba765
    • M
      Add notes about updating disk and shared memory size information in the · 7aeaa97d
      Magnus Hagander 提交于
      documentation when doing new major release.
      7aeaa97d
    • M
      Update size references in installation instructions to be a bit · 2367d689
      Magnus Hagander 提交于
      more up-to-date with current versions.
      2367d689
  7. 09 12月, 2009 4 次提交
  8. 08 12月, 2009 1 次提交
  9. 07 12月, 2009 1 次提交
  10. 06 12月, 2009 3 次提交
  11. 03 12月, 2009 2 次提交
    • H
      Fix bug in temporary file management with subtransactions. A cursor opened · ab3148b7
      Heikki Linnakangas 提交于
      in a subtransaction stays open even if the subtransaction is aborted, so
      any temporary files related to it must stay alive as well. With the patch,
      we use ResourceOwners to track open temporary files and don't automatically
      close them at subtransaction end (though in the normal case temporary files
      are registered with the subtransaction resource owner and will therefore be
      closed).
      
      At end of top transaction, we still check that there's no temporary files
      marked as close-at-end-of-transaction open, but that's now just a debugging
      cross-check as the resource owner cleanup should've closed them already.
      ab3148b7
    • T
      Clarify what's supposed to happen when a cursor FETCH is rolled back · dc588058
      Tom Lane 提交于
      by aborting a subtransaction.  Per discussion with Heikki.
      dc588058
  12. 02 12月, 2009 7 次提交
    • B
      thread-safety · 8c1c2e38
      Bruce Momjian 提交于
      Apply full patch to enable thread-safety by default, e.g. doc changes.
      8c1c2e38
    • T
      Preventing intersection of ranges during page split. Changes are only · aebc4e67
      Teodor Sigaev 提交于
      optimization, so don't backpatch.
      aebc4e67
    • T
      Mark application_name as GUC_REPORT so that the value will be reported back · 59ed94ad
      Tom Lane 提交于
      to the client by the server.  This might seem pretty pointless but apparently
      it will help pgbouncer, and perhaps other connection poolers.  Anyway it's
      practically free to do so for the normal use-case where appname is only set
      in the startup packet --- we're just adding a few more bytes to the initial
      ParameterStatus response packet.  Per comments from Marko Kreen.
      59ed94ad
    • T
      Instead of sending application_name as a SET command after the connection · 3dfcf8cc
      Tom Lane 提交于
      is made, include it in the startup-packet options.  This makes it work more
      like every other libpq connection option, in particular it now has the same
      response to RESET ALL as the rest.  This also saves one network round trip
      for new applications using application_name.  The cost is that if the server
      is pre-8.5, it'll reject the startup packet altogether, forcing us to retry
      the entire connection cycle.  But on balance we shouldn't be optimizing that
      case in preference to the behavior with a new server, especially when doing
      so creates visible behavioral oddities.  Per discussion.
      3dfcf8cc
    • B
      Enable thread safety · 925b32bb
      Bruce Momjian 提交于
      Enable thread safety on all platforms.  This will either be followed up
      by a more extensive patch, or reverted, depending on the build farm
      results.
      925b32bb
    • B
      psql -f - · b291c0fb
      Bruce Momjian 提交于
      Adjust psql -f - to behave like a normal file and honor the -1 flag.
      
      Report from Robert Haas
      b291c0fb
    • T
      Teach the regular expression functions to do case-insensitive matching and · 0d323425
      Tom Lane 提交于
      locale-dependent character classification properly when the database encoding
      is UTF8.
      
      The previous coding worked okay in single-byte encodings, or in any case for
      ASCII characters, but failed entirely on multibyte characters.  The fix
      assumes that the <wctype.h> functions use Unicode code points as the wchar
      representation for Unicode, ie, wchar matches pg_wchar.
      
      This is only a partial solution, since we're still stupid about non-ASCII
      characters in multibyte encodings other than UTF8.  The practical effect
      of that is limited, however, since those cases are generally Far Eastern
      glyphs for which concepts like case-folding don't apply anyway.  Certainly
      all or nearly all of the field reports of problems have been about UTF8.
      A more general solution would require switching to the platform's wchar
      representation for all regex operations; which is possible but would have
      substantial disadvantages.  Let's try this and see if it's sufficient in
      practice.
      0d323425
  13. 01 12月, 2009 1 次提交