Fix possible crash in tablesync worker.
authorAmit Kapila <akapila@postgresql.org>
Thu, 15 Jun 2023 03:07:48 +0000 (08:37 +0530)
committerAmit Kapila <akapila@postgresql.org>
Thu, 15 Jun 2023 03:07:48 +0000 (08:37 +0530)
Commit c3afe8cf5a added a new password_required option but forgot that you
need database access to check whether an arbitrary role ID is a superuser.

Commit e7e7da2f8d fixed a similar bug in apply worker, and this patch
fixes a similar bug in tablesync worker.

Author: Hou Zhijie
Reviewed-by: Amit Kapila
Discussion: https://postgr.es/m/OS0PR01MB571607F5A9D723755268D36294759@OS0PR01MB5716.jpnprd01.prod.outlook.com

src/backend/replication/logical/tablesync.c

index abae8d44dfc64d8d84228d774ede255ef78a698f..db10a446b3d5ad4622e37f4aacdfcc7faa76a459 100644 (file)
@@ -1262,6 +1262,12 @@ LogicalRepSyncTableStart(XLogRecPtr *origin_startpos)
        relstate = GetSubscriptionRelState(MyLogicalRepWorker->subid,
                                                                           MyLogicalRepWorker->relid,
                                                                           &relstate_lsn);
+
+       /* Is the use of a password mandatory? */
+       must_use_password = MySubscription->passwordrequired &&
+               !superuser_arg(MySubscription->owner);
+
+       /* Note that the superuser_arg call can access the DB */
        CommitTransactionCommand();
 
        SpinLockAcquire(&MyLogicalRepWorker->relmutex);
@@ -1288,10 +1294,6 @@ LogicalRepSyncTableStart(XLogRecPtr *origin_startpos)
                                                                        slotname,
                                                                        NAMEDATALEN);
 
-       /* Is the use of a password mandatory? */
-       must_use_password = MySubscription->passwordrequired &&
-               !superuser_arg(MySubscription->owner);
-
        /*
         * Here we use the slot name instead of the subscription name as the
         * application_name, so that it is different from the leader apply worker,