]> granicus.if.org Git - postgresql/commitdiff
Verify input in pg_read_file().
authorItagaki Takahiro <itagaki.takahiro@gmail.com>
Tue, 5 Jan 2010 01:29:36 +0000 (01:29 +0000)
committerItagaki Takahiro <itagaki.takahiro@gmail.com>
Tue, 5 Jan 2010 01:29:36 +0000 (01:29 +0000)
src/backend/utils/adt/genfile.c

index ff77c19da117afe64ddf7a20be37e84acfc59be2..863727dc01a9551aeb0dbdbb7d5c02a828151df9 100644 (file)
@@ -9,7 +9,7 @@
  * Author: Andreas Pflug <pgadmin@pse-consulting.de>
  *
  * IDENTIFICATION
- *       $PostgreSQL: pgsql/src/backend/utils/adt/genfile.c,v 1.22 2010/01/02 16:57:54 momjian Exp $
+ *       $PostgreSQL: pgsql/src/backend/utils/adt/genfile.c,v 1.23 2010/01/05 01:29:36 itagaki Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -22,6 +22,7 @@
 
 #include "catalog/pg_type.h"
 #include "funcapi.h"
+#include "mb/pg_wchar.h"
 #include "miscadmin.h"
 #include "postmaster/syslogger.h"
 #include "storage/fd.h"
@@ -131,6 +132,9 @@ pg_read_file(PG_FUNCTION_ARGS)
                                (errcode_for_file_access(),
                                 errmsg("could not read file \"%s\": %m", filename)));
 
+       /* Make sure the input is valid */
+       pg_verifymbstr(VARDATA(buf), nbytes, false);
+
        SET_VARSIZE(buf, nbytes + VARHDRSZ);
 
        FreeFile(file);