Commit 93f039b4 authored by Tom Lane's avatar Tom Lane

Fix pg_dump's handling of event triggers.

pg_dump with the --clean option failed to emit DROP EVENT TRIGGER
commands for event triggers.  In a closely related oversight,
it also did not emit ALTER OWNER commands for event triggers.
Since only superusers can create event triggers, the latter oversight
is of little practical consequence ... but if we're going to record
an owner for event triggers, then surely pg_dump should preserve it.

Per complaint from Greg Atkins.  Back-patch to 9.3 where event triggers
were introduced.

Discussion: https://postgr.es/m/20170722191142.yi4e7tzcg3iacclg@gmail.com
parent ab2324fd
...@@ -3313,6 +3313,7 @@ _getObjectDescription(PQExpBuffer buf, TocEntry *te, ArchiveHandle *AH) ...@@ -3313,6 +3313,7 @@ _getObjectDescription(PQExpBuffer buf, TocEntry *te, ArchiveHandle *AH)
strcmp(type, "DATABASE") == 0 || strcmp(type, "DATABASE") == 0 ||
strcmp(type, "PROCEDURAL LANGUAGE") == 0 || strcmp(type, "PROCEDURAL LANGUAGE") == 0 ||
strcmp(type, "SCHEMA") == 0 || strcmp(type, "SCHEMA") == 0 ||
strcmp(type, "EVENT TRIGGER") == 0 ||
strcmp(type, "FOREIGN DATA WRAPPER") == 0 || strcmp(type, "FOREIGN DATA WRAPPER") == 0 ||
strcmp(type, "SERVER") == 0 || strcmp(type, "SERVER") == 0 ||
strcmp(type, "PUBLICATION") == 0 || strcmp(type, "PUBLICATION") == 0 ||
...@@ -3359,7 +3360,7 @@ _getObjectDescription(PQExpBuffer buf, TocEntry *te, ArchiveHandle *AH) ...@@ -3359,7 +3360,7 @@ _getObjectDescription(PQExpBuffer buf, TocEntry *te, ArchiveHandle *AH)
return; return;
} }
write_msg(modulename, "WARNING: don't know how to set owner for object type %s\n", write_msg(modulename, "WARNING: don't know how to set owner for object type \"%s\"\n",
type); type);
} }
...@@ -3518,6 +3519,7 @@ _printTocEntry(ArchiveHandle *AH, TocEntry *te, bool isData, bool acl_pass) ...@@ -3518,6 +3519,7 @@ _printTocEntry(ArchiveHandle *AH, TocEntry *te, bool isData, bool acl_pass)
strcmp(te->desc, "OPERATOR FAMILY") == 0 || strcmp(te->desc, "OPERATOR FAMILY") == 0 ||
strcmp(te->desc, "PROCEDURAL LANGUAGE") == 0 || strcmp(te->desc, "PROCEDURAL LANGUAGE") == 0 ||
strcmp(te->desc, "SCHEMA") == 0 || strcmp(te->desc, "SCHEMA") == 0 ||
strcmp(te->desc, "EVENT TRIGGER") == 0 ||
strcmp(te->desc, "TABLE") == 0 || strcmp(te->desc, "TABLE") == 0 ||
strcmp(te->desc, "TYPE") == 0 || strcmp(te->desc, "TYPE") == 0 ||
strcmp(te->desc, "VIEW") == 0 || strcmp(te->desc, "VIEW") == 0 ||
...@@ -3556,7 +3558,7 @@ _printTocEntry(ArchiveHandle *AH, TocEntry *te, bool isData, bool acl_pass) ...@@ -3556,7 +3558,7 @@ _printTocEntry(ArchiveHandle *AH, TocEntry *te, bool isData, bool acl_pass)
} }
else else
{ {
write_msg(modulename, "WARNING: don't know how to set owner for object type %s\n", write_msg(modulename, "WARNING: don't know how to set owner for object type \"%s\"\n",
te->desc); te->desc);
} }
} }
......
...@@ -16844,6 +16844,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo) ...@@ -16844,6 +16844,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo)
{ {
DumpOptions *dopt = fout->dopt; DumpOptions *dopt = fout->dopt;
PQExpBuffer query; PQExpBuffer query;
PQExpBuffer delqry;
PQExpBuffer labelq; PQExpBuffer labelq;
/* Skip if not to be dumped */ /* Skip if not to be dumped */
...@@ -16851,6 +16852,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo) ...@@ -16851,6 +16852,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo)
return; return;
query = createPQExpBuffer(); query = createPQExpBuffer();
delqry = createPQExpBuffer();
labelq = createPQExpBuffer(); labelq = createPQExpBuffer();
appendPQExpBufferStr(query, "CREATE EVENT TRIGGER "); appendPQExpBufferStr(query, "CREATE EVENT TRIGGER ");
...@@ -16890,14 +16892,21 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo) ...@@ -16890,14 +16892,21 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo)
} }
appendPQExpBufferStr(query, ";\n"); appendPQExpBufferStr(query, ";\n");
} }
appendPQExpBuffer(delqry, "DROP EVENT TRIGGER %s;\n",
fmtId(evtinfo->dobj.name));
appendPQExpBuffer(labelq, "EVENT TRIGGER %s", appendPQExpBuffer(labelq, "EVENT TRIGGER %s",
fmtId(evtinfo->dobj.name)); fmtId(evtinfo->dobj.name));
if (evtinfo->dobj.dump & DUMP_COMPONENT_DEFINITION) if (evtinfo->dobj.dump & DUMP_COMPONENT_DEFINITION)
ArchiveEntry(fout, evtinfo->dobj.catId, evtinfo->dobj.dumpId, ArchiveEntry(fout, evtinfo->dobj.catId, evtinfo->dobj.dumpId,
evtinfo->dobj.name, NULL, NULL, evtinfo->evtowner, false, evtinfo->dobj.name, NULL, NULL,
evtinfo->evtowner, false,
"EVENT TRIGGER", SECTION_POST_DATA, "EVENT TRIGGER", SECTION_POST_DATA,
query->data, "", NULL, NULL, 0, NULL, NULL); query->data, delqry->data, NULL,
NULL, 0,
NULL, NULL);
if (evtinfo->dobj.dump & DUMP_COMPONENT_COMMENT) if (evtinfo->dobj.dump & DUMP_COMPONENT_COMMENT)
dumpComment(fout, labelq->data, dumpComment(fout, labelq->data,
...@@ -16905,6 +16914,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo) ...@@ -16905,6 +16914,7 @@ dumpEventTrigger(Archive *fout, EventTriggerInfo *evtinfo)
evtinfo->dobj.catId, 0, evtinfo->dobj.dumpId); evtinfo->dobj.catId, 0, evtinfo->dobj.dumpId);
destroyPQExpBuffer(query); destroyPQExpBuffer(query);
destroyPQExpBuffer(delqry);
destroyPQExpBuffer(labelq); destroyPQExpBuffer(labelq);
} }
......
...@@ -466,7 +466,7 @@ my %tests = ( ...@@ -466,7 +466,7 @@ my %tests = (
'ALTER COLLATION test0 OWNER TO' => { 'ALTER COLLATION test0 OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER COLLATION test0 OWNER TO .*;/m, regexp => qr/^ALTER COLLATION test0 OWNER TO .*;/m,
collation => 1, collation => 1,
like => { like => {
...@@ -493,7 +493,7 @@ my %tests = ( ...@@ -493,7 +493,7 @@ my %tests = (
'ALTER FOREIGN DATA WRAPPER dummy OWNER TO' => { 'ALTER FOREIGN DATA WRAPPER dummy OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER FOREIGN DATA WRAPPER dummy OWNER TO .*;/m, regexp => qr/^ALTER FOREIGN DATA WRAPPER dummy OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -520,7 +520,7 @@ my %tests = ( ...@@ -520,7 +520,7 @@ my %tests = (
'ALTER SERVER s1 OWNER TO' => { 'ALTER SERVER s1 OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER SERVER s1 OWNER TO .*;/m, regexp => qr/^ALTER SERVER s1 OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -547,7 +547,7 @@ my %tests = ( ...@@ -547,7 +547,7 @@ my %tests = (
'ALTER FUNCTION dump_test.pltestlang_call_handler() OWNER TO' => { 'ALTER FUNCTION dump_test.pltestlang_call_handler() OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ regexp => qr/^
\QALTER FUNCTION dump_test.pltestlang_call_handler() \E \QALTER FUNCTION dump_test.pltestlang_call_handler() \E
\QOWNER TO \E \QOWNER TO \E
...@@ -576,7 +576,7 @@ my %tests = ( ...@@ -576,7 +576,7 @@ my %tests = (
'ALTER OPERATOR FAMILY dump_test.op_family OWNER TO' => { 'ALTER OPERATOR FAMILY dump_test.op_family OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ regexp => qr/^
\QALTER OPERATOR FAMILY dump_test.op_family USING btree \E \QALTER OPERATOR FAMILY dump_test.op_family USING btree \E
\QOWNER TO \E \QOWNER TO \E
...@@ -655,7 +655,7 @@ my %tests = ( ...@@ -655,7 +655,7 @@ my %tests = (
'ALTER OPERATOR CLASS dump_test.op_class OWNER TO' => { 'ALTER OPERATOR CLASS dump_test.op_class OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ regexp => qr/^
\QALTER OPERATOR CLASS dump_test.op_class USING btree \E \QALTER OPERATOR CLASS dump_test.op_class USING btree \E
\QOWNER TO \E \QOWNER TO \E
...@@ -746,7 +746,7 @@ my %tests = ( ...@@ -746,7 +746,7 @@ my %tests = (
'ALTER PROCEDURAL LANGUAGE pltestlang OWNER TO' => { 'ALTER PROCEDURAL LANGUAGE pltestlang OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER PROCEDURAL LANGUAGE pltestlang OWNER TO .*;/m, regexp => qr/^ALTER PROCEDURAL LANGUAGE pltestlang OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -772,7 +772,7 @@ my %tests = ( ...@@ -772,7 +772,7 @@ my %tests = (
'ALTER SCHEMA dump_test OWNER TO' => { 'ALTER SCHEMA dump_test OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER SCHEMA dump_test OWNER TO .*;/m, regexp => qr/^ALTER SCHEMA dump_test OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -798,7 +798,7 @@ my %tests = ( ...@@ -798,7 +798,7 @@ my %tests = (
'ALTER SCHEMA dump_test_second_schema OWNER TO' => { 'ALTER SCHEMA dump_test_second_schema OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER SCHEMA dump_test_second_schema OWNER TO .*;/m, regexp => qr/^ALTER SCHEMA dump_test_second_schema OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1193,7 +1193,7 @@ my %tests = ( ...@@ -1193,7 +1193,7 @@ my %tests = (
'ALTER TABLE test_table OWNER TO' => { 'ALTER TABLE test_table OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER TABLE test_table OWNER TO .*;/m, regexp => qr/^ALTER TABLE test_table OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1251,7 +1251,7 @@ my %tests = ( ...@@ -1251,7 +1251,7 @@ my %tests = (
'ALTER TABLE test_second_table OWNER TO' => { 'ALTER TABLE test_second_table OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER TABLE test_second_table OWNER TO .*;/m, regexp => qr/^ALTER TABLE test_second_table OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1278,7 +1278,7 @@ my %tests = ( ...@@ -1278,7 +1278,7 @@ my %tests = (
'ALTER TABLE test_third_table OWNER TO' => { 'ALTER TABLE test_third_table OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER TABLE test_third_table OWNER TO .*;/m, regexp => qr/^ALTER TABLE test_third_table OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1305,7 +1305,7 @@ my %tests = ( ...@@ -1305,7 +1305,7 @@ my %tests = (
'ALTER TABLE measurement OWNER TO' => { 'ALTER TABLE measurement OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER TABLE measurement OWNER TO .*;/m, regexp => qr/^ALTER TABLE measurement OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1332,7 +1332,7 @@ my %tests = ( ...@@ -1332,7 +1332,7 @@ my %tests = (
'ALTER TABLE measurement_y2006m2 OWNER TO' => { 'ALTER TABLE measurement_y2006m2 OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER TABLE measurement_y2006m2 OWNER TO .*;/m, regexp => qr/^ALTER TABLE measurement_y2006m2 OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1359,7 +1359,7 @@ my %tests = ( ...@@ -1359,7 +1359,7 @@ my %tests = (
'ALTER FOREIGN TABLE foreign_table OWNER TO' => { 'ALTER FOREIGN TABLE foreign_table OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => qr/^ALTER FOREIGN TABLE foreign_table OWNER TO .*;/m, regexp => qr/^ALTER FOREIGN TABLE foreign_table OWNER TO .*;/m,
like => { like => {
binary_upgrade => 1, binary_upgrade => 1,
...@@ -1386,7 +1386,7 @@ my %tests = ( ...@@ -1386,7 +1386,7 @@ my %tests = (
'ALTER TEXT SEARCH CONFIGURATION alt_ts_conf1 OWNER TO' => { 'ALTER TEXT SEARCH CONFIGURATION alt_ts_conf1 OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => regexp =>
qr/^ALTER TEXT SEARCH CONFIGURATION alt_ts_conf1 OWNER TO .*;/m, qr/^ALTER TEXT SEARCH CONFIGURATION alt_ts_conf1 OWNER TO .*;/m,
like => { like => {
...@@ -1414,7 +1414,7 @@ my %tests = ( ...@@ -1414,7 +1414,7 @@ my %tests = (
'ALTER TEXT SEARCH DICTIONARY alt_ts_dict1 OWNER TO' => { 'ALTER TEXT SEARCH DICTIONARY alt_ts_dict1 OWNER TO' => {
all_runs => 1, all_runs => 1,
catch_all => catch_all =>
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)', 'ALTER ... OWNER commands (except post-data objects)',
regexp => regexp =>
qr/^ALTER TEXT SEARCH DICTIONARY alt_ts_dict1 OWNER TO .*;/m, qr/^ALTER TEXT SEARCH DICTIONARY alt_ts_dict1 OWNER TO .*;/m,
like => { like => {
...@@ -1439,11 +1439,11 @@ my %tests = ( ...@@ -1439,11 +1439,11 @@ my %tests = (
only_dump_test_table => 1, only_dump_test_table => 1,
role => 1, }, }, role => 1, }, },
# catch-all for ALTER ... OWNER (except LARGE OBJECTs and PUBLICATIONs) # catch-all for ALTER ... OWNER (except post-data objects)
'ALTER ... OWNER commands (except LARGE OBJECTs and PUBLICATIONs)' => { 'ALTER ... OWNER commands (except post-data objects)' => {
all_runs => 0, # catch-all all_runs => 0, # catch-all
regexp => regexp =>
qr/^ALTER (?!LARGE OBJECT|PUBLICATION|SUBSCRIPTION)(.*) OWNER TO .*;/m, qr/^ALTER (?!EVENT TRIGGER|LARGE OBJECT|PUBLICATION|SUBSCRIPTION)(.*) OWNER TO .*;/m,
like => {}, # use more-specific options above like => {}, # use more-specific options above
unlike => { unlike => {
column_inserts => 1, column_inserts => 1,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment