From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | milos(dot)urbanek(at)email(dot)cz |
Cc: | pgsql-bugs(at)postgresql(dot)org |
Subject: | Re: BUG #14587: Foreign constraint with newline blows up pg_restore catalogue |
Date: | 2017-03-10 16:23:34 |
Message-ID: | 14281.1489163014@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
milos(dot)urbanek(at)email(dot)cz writes:
> As repoted in https://trac.osgeo.org/postgis/ticket/3727
> If there is some newline in e.g. foreign key contraint, the second command
> below fails:
> pg_restore -l test.backup > test.backup.lst
> pg_restore -L test.backup.lst > test2.out
Hm. As of a year or two back, we sanitize object names in the comments
printed in the restore script, eg after
d1=# create table p (f1 int primary key);
CREATE TABLE
d1=# create table f (f1 int);
CREATE TABLE
d1=# alter table f add constraint "weird
d1"# name" foreign key (f1) references p;
ALTER TABLE
the dump output will look like
--
-- Name: f weird name; Type: FK CONSTRAINT; Schema: public; Owner: postgres
--
ALTER TABLE ONLY f
ADD CONSTRAINT "weird
name" FOREIGN KEY (f1) REFERENCES p(f1);
However, pg_restore -l didn't get the memo:
;
; Selected TOC Entries:
;
2991; 1262 46745 DATABASE - d1 postgres
3; 2615 2200 SCHEMA - public postgres
2992; 0 0 COMMENT - SCHEMA public postgres
1; 3079 13112 EXTENSION - plpgsql
2993; 0 0 COMMENT - EXTENSION plpgsql
195; 1259 46751 TABLE public f postgres
194; 1259 46746 TABLE public p postgres
2986; 0 46751 TABLE DATA public f postgres
2985; 0 46746 TABLE DATA public p postgres
2862; 2606 46750 CONSTRAINT public p p_pkey postgres
2863; 2606 46754 FK CONSTRAINT public f weird
name postgres
and in turn that breaks -L for such cases. I think we need to transpose
the sanitization to also happen in these code paths.
Perhaps this should have been treated as a security issue, but the
cat's out of the bag now. I think automated workflows involving -l
are pretty rare anyway.
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Sandro Santilli | 2017-03-10 17:47:42 | Re: BUG #14587: Foreign constraint with newline blows up pg_restore catalogue |
Previous Message | milos.urbanek | 2017-03-10 15:53:18 | BUG #14587: Foreign constraint with newline blows up pg_restore catalogue |