1. 13 Jul, 2005 7 commits
  2. 12 Jul, 2005 6 commits
  3. 11 Jul, 2005 5 commits
  4. 10 Jul, 2005 22 commits
    • Tom Lane's avatar
      Missed adding extra argument to array_recv in a couple of places · 8826fe85
      Tom Lane authored
      (harmless, actually, but let's be tidy).
      8826fe85
    • Tom Lane's avatar
      Change typreceive function API so that receive functions get the same · d78397d3
      Tom Lane authored
      optional arguments as text input functions, ie, typioparam OID and
      atttypmod.  Make all the datatypes that use typmod enforce it the same
      way in typreceive as they do in typinput.  This fixes a problem with
      failure to enforce length restrictions during COPY FROM BINARY.
      d78397d3
    • Bruce Momjian's avatar
      > One more failure: · 2e330699
      Bruce Momjian authored
      >
      > I think this is because we don't have -lz in SHLIB_LINK.
      > Following patch fixes it.
      
      Marko Kreen
      2e330699
    • Bruce Momjian's avatar
      Add extra argument for new pg_regexec API. · 21634e51
      Bruce Momjian authored
      21634e51
    • Tom Lane's avatar
      Suppress compile warning. · aacfeba6
      Tom Lane authored
      aacfeba6
    • Bruce Momjian's avatar
      Rename xmalloc to pg_malloc for consistency with psql usage. · e8a3e6b8
      Bruce Momjian authored
      Add missing plperl include.
      e8a3e6b8
    • Bruce Momjian's avatar
      Reverse pg_malloc patch because psql/print.c is used in scripts files · f86c63ab
      Bruce Momjian authored
      that don't have pg_malloc.
      f86c63ab
    • Bruce Momjian's avatar
      8c9393c6
    • Bruce Momjian's avatar
      Remove #include <openssl/bn.h> as compile fix. · 6e1004f0
      Bruce Momjian authored
      Marko Kreen
      6e1004f0
    • Bruce Momjian's avatar
      Following up a previous thought I had, yesterday I realised how to · b135508c
      Bruce Momjian authored
      return arays nicely without having to make the plperl programmer aware
      of anything. The attached patch allows plperl to return an arrayref
      where the function returns an array type. It silently calls a perl
      function to stringify the array before passing it to the pg array
      parser. Non-array returns are handled as before (i.e. passed through
      this process) so it is backwards compatible. I will presently submit
      regression tests and docs.
      
      example:
      
      andrew=# create or replace function blah() returns text[][] language
      plperl as $$ return [['a"b','c,d'],['e\\f','g']]; $$;
      CREATE FUNCTION
      andrew=# select blah();
                  blah
      -----------------------------
       {{"a\"b","c,d"},{"e\\f",g}}
      
      
      This would complete half of the TODO item:
      
        . Pass arrays natively instead of as text between plperl and postgres
      
      (The other half is translating pg array arguments to perl arrays - that
      will have to wait for 8.1).
      
      Some of this patch is adapted from a previously submitted patch from
      Sergej Sergeev. Both he and Abhijit Menon-Sen have looked it over
      briefly and tentatively said it looks ok.
      
      Andrew Dunstan
      b135508c
    • Bruce Momjian's avatar
      The attached patch implements spi_query() and spi_fetchrow() functions · 6d92f210
      Bruce Momjian authored
      for PL/Perl, to avoid loading the entire result set into memory as the
      existing spi_exec_query() function does.
      
      Here's how one might use the new functions:
      
          $x = spi_query("select ...");
          while (defined ($y = spi_fetchrow($x))) {
              ...
              return_next(...);
          }
      
      The changes do not affect the spi_exec_query() interface in any way.
      
      Abhijit Menon-Sen
      6d92f210
    • Bruce Momjian's avatar
      Add --encoding to pg_dump. · d1cffe2f
      Bruce Momjian authored
      The Problem:  Occassionally a DBA needs to dump a database to a new
      encoding.   In instances where the current encoding, (or lack of an
      encoding, like SQL_ASCII) is poorly supported on the target  database
      server, it can be useful to dump into a particular  encoding.  But,
      currently the only way to set the encoding of  a pg_dump file is to
      change  client_encoding in postgresql.conf and restart postmaster.
      This is more  than a little awkward for production systems.
      
      Magnus Hagander
      d1cffe2f
    • Bruce Momjian's avatar
      This patch implements putting language handlers for the optional PLs · 07931080
      Bruce Momjian authored
      into pg_catalog rather than public, and supports dumping languages whose
      handlers are found there. This will make it easier to drop the public
      schema if desired.
      
      Unlike the previous patch, the comments have been updated and I have
      reformatted some code to meet Alvarro's request to stick to 80 cols. (I
      actually aghree with this - it makes printing the code much nicer).
      
      I think I did the right thing w.r.t versions earlier than 7.3, but I
      have no real way of checking, so that should be checked by someone with
      more/older knowledge than me ;-)
      
      Andrew Dunstan
      07931080
    • Bruce Momjian's avatar
      As Kris Jurka found out, pgcrypto does not work with · d51df918
      Bruce Momjian authored
      OpenSSL 0.9.6x.  The DES functions use the older 'des_'
      API, but the newer 3DES functions use the 0.9.7x-only
      'DES_' API.
      
      I think I just used /usr/include/openssl/des.h for reference
      when implementing them, and had upgraded OpenSSL in the
      meantime.
      
      Following patch converts DES also to newer API and provides
      compatibility functions for OpenSSL < 0.9.7.
      
      I chose this route because:
      
      - openssl.c uses few DES functions.
      - compatibility for old 'des_' API is going away at some point
        of time from OpenSSL.
      - as seen from macros, new API is saner
      - Thus pgcrypto supports any OpenSSL version from 0.9.5 to 1.0
      
      Tested with OpenSSL 0.9.6c and 0.9.7e.
      
      Marko Kreen
      d51df918
    • Bruce Momjian's avatar
      e94dd6ab
    • Bruce Momjian's avatar
      Update. · 42e7b0f0
      Bruce Momjian authored
      < 	  computations should adjust based on the time zone rules, e.g.
      < 	  adding 24 hours to a timestamp would yield a different result from
      < 	  adding one day.
      <
      > 	  computations should adjust based on the time zone rules.
      42e7b0f0
    • Bruce Momjian's avatar
      This patch addresses the problem mentioned in the "process crash · 37f11c30
      Bruce Momjian authored
      when a plpython function returns unicode" thread:
      
      http://archives.postgresql.org/pgsql-bugs/2005-06/msg00105.php
      
      In several places PL/Python was calling PyObject_Str() and then
      PyString_AsString() without checking if the former had returned
      NULL to indicate an error.  PyString_AsString() doesn't expect a
      NULL argument, so passing one causes a segmentation fault.  This
      patch adds checks for NULL and raises errors via PLy_elog(), which
      prints details of the underlying Python exception.  The patch also
      adds regression tests for these checks.  All tests pass on my
      Solaris 9 box running HEAD and Python 2.4.1.
      
      In one place the patch doesn't call PLy_elog() because that could
      cause infinite recursion; see the comment I added.  I'm not sure
      how to test that particular case or whether it's even possible to
      get an error there: the value that the code should check is the
      Python exception type, so I wonder if a NULL value "shouldn't
      happen."  This patch converts NULL to "Unknown Exception" but I
      wonder if an Assert() would be appropriate.
      
      The patch is against HEAD but the same changes should be applied
      to earlier versions because they have the same problem.  The patch
      might not apply cleanly against earlier versions -- will the committer
      take care of little differences or should I submit different versions
      of the patch?
      
      Michael Fuhr
      37f11c30
    • Bruce Momjian's avatar
      I made the patch that implements regexp_replace again. · 75a64eeb
      Bruce Momjian authored
      The specification of this function is as follows.
      
      regexp_replace(source text, pattern text, replacement text, [flags
      text])
      returns text
      
      Replace string that matches to regular expression in source text to
      replacement text.
      
       - pattern is regular expression pattern.
       - replacement is replace string that can use '\1'-'\9', and '\&'.
          '\1'-'\9': back reference to the n'th subexpression.
          '\&'     : entire matched string.
       - flags can use the following values:
          g: global (replace all)
          i: ignore case
          When the flags is not specified, case sensitive, replace the first
          instance only.
      
      Atsushi Ogawa
      75a64eeb
    • Bruce Momjian's avatar
      Major pgcrypto changes: · 73e24318
      Bruce Momjian authored
      of password-based encryption from RFC2440 (OpenPGP).
      
      The goal of this code is to be more featureful encryption solution
      than current encrypt(), which only functionality is running cipher
      over data.
      
      Compared to encrypt(), pgp_encrypt() does following:
      
      * It uses the equvialent of random Inital Vector to get cipher
        into random state before it processes user data
      * Stores SHA-1 of the data into result so any modification
        will be detected.
      * Remembers if data was text or binary - thus it can decrypt
        to/from text data.  This was a major nuisance for encrypt().
      * Stores info about used algorithms with result, so user needs
        not remember them - more user friendly!
      * Uses String2Key algorithms (similar to crypt()) with random salt
        to generate full-length binary key to be used for encrypting.
      * Uses standard format for data - you can feed it to GnuPG, if needed.
      
      Optional features (off by default):
      
      * Can use separate session key - user data will be encrypted
        with totally random key, which will be encrypted with S2K
        generated key and attached to result.
      * Data compression with zlib.
      * Can convert between CRLF<->LF line-endings - to get fully
        RFC2440-compliant behaviour.  This is off by default as
        pgcrypto does not know the line-endings of user data.
      
      Interface is simple:
      
      
          pgp_encrypt(data text, key text) returns bytea
          pgp_decrypt(data text, key text) returns text
          pgp_encrypt_bytea(data bytea, key text) returns bytea
          pgp_decrypt_bytea(data bytea, key text) returns bytea
      
      To change parameters (cipher, compression, mdc):
      
          pgp_encrypt(data text, key text, parms text) returns bytea
          pgp_decrypt(data text, key text, parms text) returns text
          pgp_encrypt_bytea(data bytea, key text, parms text) returns bytea
          pgp_decrypt_bytea(data bytea, key text, parms text) returns bytea
      
      Parameter names I lifted from gpg:
      
         pgp_encrypt('message', 'key', 'compress-algo=1,cipher-algo=aes256')
      
      For text data, pgp_encrypt simply encrypts the PostgreSQL internal data.
      
      This maps to RFC2440 data type 't' - 'extenally specified encoding'.
      But this may cause problems if data is dumped and reloaded into database
      which as different internal encoding.  My next goal is to implement data
      type 'u' - which means data is in UTF-8 encoding by converting internal
      encoding to UTF-8 and back.  And there wont be any compatibility
      problems with current code, I think its ok to submit this without UTF-8
      encoding by converting internal encoding to UTF-8 and back.  And there
      wont be any compatibility problems with current code, I think its ok to
      submit this without UTF-8 support.
      
      
      Here is v4 of PGP encrypt.  This depends on previously sent
      Fortuna-patch, as it uses the px_add_entropy function.
      
      - New function: pgp_key_id() for finding key id's.
      - Add SHA1 of user data and key into RNG pools.  We need to get
        randomness from somewhere, and it is in user best interests
        to contribute.
      - Regenerate pgp-armor test for SQL_ASCII database.
      - Cleanup the key handling so that the pubkey support is less
        hackish.
      
      Marko Kreen
      73e24318
    • Bruce Momjian's avatar
      - Add Fortuna PRNG to pgcrypto. · 4fcf8b11
      Bruce Momjian authored
      - Move openssl random provider to openssl.c and builtin provider
        to internal.c
      - Make px_random_bytes use Fortuna, instead of giving error.
      - Retarget random.c to aquiring system randomness, for initial seeding
        of Fortuna.  There is ATM 2 functions for Windows,
        reader from /dev/urandom and the regular time()/getpid() silliness.
      
      Marko Kreen
      4fcf8b11
    • Bruce Momjian's avatar
      This patch adds implementation of SHA2 to pgcrypto. · 248eeb82
      Bruce Momjian authored
      New hashes: SHA256, SHA384, SHA512.
      
      Marko Kreen
      248eeb82
    • Bruce Momjian's avatar
      Add psql \pset numericsep to allow output numbers like 100,000.0 or · 73a7c322
      Bruce Momjian authored
      100.000,0.
      
      Eugen Nedelcu
      73a7c322