1. 09 Jan, 2008 3 commits
  2. 08 Jan, 2008 4 commits
  3. 07 Jan, 2008 2 commits
  4. 06 Jan, 2008 1 commit
  5. 05 Jan, 2008 1 commit
  6. 04 Jan, 2008 1 commit
  7. 03 Jan, 2008 6 commits
    • Tom Lane's avatar
      Stamp release 8.3RC1. · 2bf121e4
      Tom Lane authored
      Security: CVE-2007-4769, CVE-2007-4772, CVE-2007-6067, CVE-2007-6600, CVE-2007-6601
      2bf121e4
    • Tom Lane's avatar
      Update release notes for security releases. · 019fac77
      Tom Lane authored
      Security: CVE-2007-4769, CVE-2007-4772, CVE-2007-6067, CVE-2007-6600, CVE-2007-6601
      019fac77
    • Tom Lane's avatar
      The original patch to disallow non-passworded connections to non-superusers · 919c9f6c
      Tom Lane authored
      failed to cover all the ways in which a connection can be initiated in dblink.
      Plug the remaining holes.  Also, disallow transient connections in functions
      for which that feature makes no sense (because they are only sensible as
      part of a sequence of operations on the same connection).  Joe Conway
      
      Security: CVE-2007-6601
      919c9f6c
    • Tom Lane's avatar
      Make standard maintenance operations (including VACUUM, ANALYZE, REINDEX, · eedb068c
      Tom Lane authored
      and CLUSTER) execute as the table owner rather than the calling user, using
      the same privilege-switching mechanism already used for SECURITY DEFINER
      functions.  The purpose of this change is to ensure that user-defined
      functions used in index definitions cannot acquire the privileges of a
      superuser account that is performing routine maintenance.  While a function
      used in an index is supposed to be IMMUTABLE and thus not able to do anything
      very interesting, there are several easy ways around that restriction; and
      even if we could plug them all, there would remain a risk of reading sensitive
      information and broadcasting it through a covert channel such as CPU usage.
      
      To prevent bypassing this security measure, execution of SET SESSION
      AUTHORIZATION and SET ROLE is now forbidden within a SECURITY DEFINER context.
      
      Thanks to Itagaki Takahiro for reporting this vulnerability.
      
      Security: CVE-2007-6600
      eedb068c
    • Tom Lane's avatar
      Fix assorted security-grade bugs in the regex engine. All of these problems · 98f27aae
      Tom Lane authored
      are shared with Tcl, since it's their code to begin with, and the patches
      have been copied from Tcl 8.5.0.  Problems:
      
      CVE-2007-4769: Inadequate check on the range of backref numbers allows
      crash due to out-of-bounds read.
      CVE-2007-4772: Infinite loop in regex optimizer for pattern '($|^)*'.
      CVE-2007-6067: Very slow optimizer cleanup for regex with a large NFA
      representation, as well as crash if we encounter an out-of-memory condition
      during NFA construction.
      
      Part of the response to CVE-2007-6067 is to put a limit on the number of
      states in the NFA representation of a regex.  This seems needed even though
      the within-the-code problems have been corrected, since otherwise the code
      could try to use very large amounts of memory for a suitably-crafted regex,
      leading to potential DOS by driving the system into swap, activating a kernel
      OOM killer, etc.
      
      Although there are certainly plenty of ways to drive the system into effective
      DOS with poorly-written SQL queries, these problems seem worth treating as
      security issues because many applications might accept regex search patterns
      from untrustworthy sources.
      
      Thanks to Will Drewry of Google for reporting these problems.  Patches by Will
      Drewry and Tom Lane.
      
      Security: CVE-2007-4769, CVE-2007-4772, CVE-2007-6067
      98f27aae
    • Bruce Momjian's avatar
      Add: · 8af31d56
      Bruce Momjian authored
      > * Allow multiple identical NOTIFY events to always be communicated to the
      >   client, rather than sent as a single notification to the listener
      8af31d56
  8. 02 Jan, 2008 6 commits
  9. 01 Jan, 2008 6 commits
  10. 31 Dec, 2007 4 commits
  11. 30 Dec, 2007 4 commits
    • Andrew Dunstan's avatar
    • Bruce Momjian's avatar
      Update TODO list based on 8.3 completed items: · a225bf05
      Bruce Momjian authored
      < * Allow major upgrades without dump/reload, perhaps using pg_upgrade
      <   [pg_upgrade]
      < * Check for unreferenced table files created by transactions that were
      <   in-progress when the server terminated abruptly
      <
      <   http://archives.postgresql.org/pgsql-patches/2006-06/msg00096.php
      <
      > * Check for unreferenced table files created by transactions that were
      >   in-progress when the server terminated abruptly
      >
      >   http://archives.postgresql.org/pgsql-patches/2006-06/msg00096.php
      >
      < * Support table partitioning that allows a single table to be stored
      <   in subtables that are partitioned based on the primary key or a WHERE
      <   clause
      <   creation of rules for INSERT/UPDATE/DELETE, and constraints for
      <   rapid partition selection.  Options could include range and hash
      >   creation of triggers or rules for INSERT/UPDATE/DELETE, and constraints
      >   for rapid partition selection.  Options could include range and hash
      <
      < * Improve replication solutions
      <
      < 	o Load balancing
      <
      < 	  You can use any of the master/slave replication servers to use a
      < 	  standby server for data warehousing. To allow read/write queries to
      < 	  multiple servers, you need multi-master replication like pgcluster.
      <
      < 	o Allow replication over unreliable or non-persistent links
      <
      <
      < 	o Mark change-on-restart-only values in postgresql.conf
      < 	  All objects in the default database tablespace must have default
      < 	  tablespace specifications. This is because new databases are
      < 	  created by copying directories. If you mix default tablespace
      < 	  tables and tablespace-specified tables in the same directory,
      < 	  creating a new database from such a mixed directory would create a
      < 	  new database with tables that had incorrect explicit tablespaces.
      < 	  To fix this would require modifying pg_class in the newly copied
      < 	  database, which we don't currently do.
      > 	  Currently all objects in the default database tablespace must
      > 	  have default tablespace specifications. This is because new
      > 	  databases are created by copying directories. If you mix default
      > 	  tablespace tables and tablespace-specified tables in the same
      > 	  directory, creating a new database from such a mixed directory
      > 	  would create a new database with tables that had incorrect
      > 	  explicit tablespaces.  To fix this would require modifying
      > 	  pg_class in the newly copied database, which we don't currently
      > 	  do.
      <
      < 	  o Allow recovery.conf to allow the same syntax as
      > 	  o Allow recovery.conf to support the same syntax as
      < * Allow user-defined types to specify a type modifier at table creation
      <   time
      < * Allow all data types to cast to and from TEXT
      <
      <   http://archives.postgresql.org/pgsql-hackers/2007-04/msg00017.php
      <
      <
      < 		o Add support for year-month syntax, INTERVAL '50-6' YEAR TO MONTH
      < 		o Interpret INTERVAL '1 year' MONTH as CAST (INTERVAL '1 year' AS
      < 		  INTERVAL MONTH), and this should return '12 months'
      > 		o Add support for year-month syntax, INTERVAL '50-6' YEAR
      > 		  TO MONTH
      > 		o Interpret INTERVAL '1 year' MONTH as CAST (INTERVAL '1
      > 		  year' AS INTERVAL MONTH), and this should return '12 months'
      < 	* Allow MONEY to be cast to/from other numeric data types
      > 	* Allow MONEY to be easily cast to/from other numeric data types
      >
      < * Allow functions to have a schema search path specified at creation time
      < * Fix cases where invalid byte encodings are accepted by the database,
      <   but throw an error on SELECT
      <
      <   http://archives.postgresql.org/pgsql-hackers/2007-03/msg00767.php
      < * Improve logging of prepared statements recovered during startup
      > * Improve logging of prepared transactions recovered during startup
      < * Make standard_conforming_strings the default in 8.4?
      > * Make standard_conforming_strings the default in 8.5?
      < * Allow the count returned by SELECT, etc to be to represent as an int64
      > * Allow the count returned by SELECT, etc to be represented as an int64
      < 	o Use more reliable method for CREATE DATABASE to get a consistent
      < 	  copy of db?
      < 	o Fix transaction restriction checks for CREATE DATABASE and
      < 	  other commands
      <
      < 	  http://archives.postgresql.org/pgsql-hackers/2007-01/msg00133.php
      < 	  currently allowed.
      > 	  currently allowed.  This currently is done if the table is
      > 	  created inside the same transaction block as the COPY because
      > 	  no other backends can see the table.
      < 	o Add SET PATH for schemas?
      <
      < 	  This is basically the same as SET search_path.
      < 	o Enforce referential integrity for system tables
      < 		o Add Oracle-style packages  (Pavel)
      <
      < 		  A package would be a schema with session-local variables,
      < 		  public/private functions, and initialization functions.  It
      < 		  is also possible to implement these capabilities
      < 		  in all schemas and not use a separate "packages"
      < 		  syntax at all.
      <
      < 		  http://archives.postgresql.org/pgsql-hackers/2006-08/msg00384.php
      <
      < 		o Add single-step debugging of functions
      < 		o Allow RETURN to return row or record functions
      <
      < 		  http://archives.postgresql.org/pgsql-patches/2005-11/msg00045.php
      < 		  http://archives.postgresql.org/pgsql-patches/2006-08/msg00397.php
      < 		  http://archives.postgresql.org/pgsql-hackers/2006-09/msg00388.php
      <
      < 		o Fix problems with RETURN NEXT on tables with
      < 		  dropped/added columns after function creation
      <
      < 		  http://archives.postgresql.org/pgsql-patches/2006-02/msg00165.php
      <
      < * Make consistent use of long/short command options --- pg_ctl needs
      <   long ones, pg_config doesn't have short ones, postgres doesn't have
      <   enough long ones, etc.
      <
      <
      <
      < 	o Consider parsing the -c string into individual queries so each
      < 	  is run in its own transaction
      <
      < 	  http://archives.postgresql.org/pgsql-hackers/2007-01/msg00291.php
      <
      <
      < 	o Remove unnecessary function pointer abstractions in pg_dump source
      < 	  code
      > 	o Remove unnecessary function pointer abstractions in pg_dump source
      > 	  code
      <
      <
      < 	o Fix SSL retry to avoid useless repeated connection attempts and
      < 	  ensuing misleading error messages
      >
      <
      <   This is difficult because it requires datatype-specific knowledge.
      <
      < * Improve commit_delay handling to reduce fsync()
      < * %Add an option to sync() before fsync()'ing checkpoint files
      >
      < * Reduce lock time during VACUUM FULL by moving tuples with read lock,
      <   then write lock and truncate table
      <
      <   Moved tuples are invisible to other backends so they don't require a
      <   write lock. However, the read lock promotion to write lock could lead
      <   to deadlock situations.
      <
      < * Prevent long-lived temporary tables from causing frozen-xid advancement
      <    starvation
      <
      <    The problem is that autovacuum cannot vacuum them to set frozen xids;
      <    only the session that created them can do that.
      <
      <
      <
      < 	o Use free-space map information to guide refilling
      < 	o Consider logging activity either to the logs or a system view
      > 	  The problem is that autovacuum cannot vacuum them to set frozen xids;
      > 	  only the session that created them can do that.
      < * Add connection pooling
      <
      <   It is unclear if this should be done inside the backend code or done
      <   by something external like pgpool. The passing of file descriptors to
      <   existing backends is one of the difficulties with a backend approach.
      <
      < * Consider reducing memory used for shared buffer reference count
      <
      <   http://archives.postgresql.org/pgsql-hackers/2007-01/msg00752.php
      <
      < * %Remove memory/file descriptor freeing before ereport(ERROR)
      < * %Promote debug_query_string into a server-side function current_query()
      < * Allow ecpg to work with MSVC and BCC
      < * Add xpath_array() to /contrib/xml2 to return results as an array
      < * Allow building in directories containing spaces
      <
      <   This is probably not possible because 'gmake' and other compiler tools
      <   do not fully support quoting of paths with spaces.
      <
      < * Fix sgmltools so PDFs can be generated with bookmarks
      < * Split out libpq pgpass and environment documentation sections to make
      <   it easier for non-developers to find
      < * Use strlcpy() rather than our StrNCpy() macro
      <
      <   http://archives.postgresql.org/pgsql-hackers/2006-09/msg02108.php
      <
      < 	o Re-enable timezone output on log_line_prefix '%t' when a
      < 	  shorter timezone string is available
      < * Allow statements across databases or servers with transaction
      <   semantics
      <
      <   This can be done using dblink and two-phase commit.
      > * Add Oracle-style packages  (Pavel)
      < * Add the features of packages
      > 	  A package would be a schema with session-local variables,
      > 	  public/private functions, and initialization functions.  It
      > 	  is also possible to implement these capabilities
      > 	  in any schema and not use a separate "packages"
      > 	  syntax at all.
      < 	o  Make private objects accessible only to objects in the same schema
      < 	o  Allow current_schema.objname to access current schema objects
      < 	o  Add session variables
      < 	o  Allow nested schemas
      > 	  http://archives.postgresql.org/pgsql-hackers/2006-08/msg00384.php
      a225bf05
    • Bruce Momjian's avatar
      Remove TODO.detil for pg_upgrade. · 835a51c6
      Bruce Momjian authored
      835a51c6
    • Bruce Momjian's avatar
      Add: · ebb28cb3
      Bruce Momjian authored
      >
      > * Allow SSL authentication/encryption over unix domain sockets
      >
      >   http://archives.postgresql.org/pgsql-hackers/2007-12/msg00924.php
      ebb28cb3
  12. 29 Dec, 2007 2 commits