PostgreSQL Source Code git master
Loading...
Searching...
No Matches
pg_subscription.h File Reference
#include "access/xlogdefs.h"
#include "catalog/genbki.h"
#include "catalog/pg_subscription_d.h"
#include "lib/stringinfo.h"
#include "nodes/pg_list.h"
Include dependency graph for pg_subscription.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  Subscription
 

Typedefs

typedef struct Subscription Subscription
 

Functions

BEGIN_CATALOG_STRUCT CATALOG (pg_subscription, 6100, SubscriptionRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_OID(6101
 
Oid subdbid BKI_LOOKUP (pg_database)
 
Oid subowner BKI_LOOKUP (pg_authid)
 
Oid subserver BKI_LOOKUP_OPT (pg_foreign_server)
 
 DECLARE_TOAST_WITH_MACRO (pg_subscription, 4183, 4184, PgSubscriptionToastTable, PgSubscriptionToastIndex)
 
 DECLARE_UNIQUE_INDEX_PKEY (pg_subscription_oid_index, 6114, SubscriptionObjectIndexId, pg_subscription, btree(oid oid_ops))
 
 DECLARE_UNIQUE_INDEX (pg_subscription_subname_index, 6115, SubscriptionNameIndexId, pg_subscription, btree(subdbid oid_ops, subname name_ops))
 
 MAKE_SYSCACHE (SUBSCRIPTIONOID, pg_subscription_oid_index, 4)
 
 MAKE_SYSCACHE (SUBSCRIPTIONNAME, pg_subscription_subname_index, 4)
 
SubscriptionGetSubscription (Oid subid, bool missing_ok, bool aclcheck)
 
void DisableSubscription (Oid subid)
 
int CountDBSubscriptions (Oid dbid)
 
void GetPublicationsStr (List *publications, StringInfo dest, bool quote_literal)
 

Variables

END_CATALOG_STRUCT typedef FormData_pg_subscriptionForm_pg_subscription
 
BEGIN_CATALOG_STRUCT SubscriptionRelation_Rowtype_Id BKI_SCHEMA_MACRO
 
XLogRecPtr subskiplsn
 
NameData subname
 
bool subenabled
 
bool subbinary
 
char substream
 
char subtwophasestate
 
bool subdisableonerr
 
bool subpasswordrequired
 
bool subrunasowner
 
bool subfailover
 
bool subretaindeadtuples
 
int32 submaxretention
 
bool subretentionactive
 
 FormData_pg_subscription
 

Typedef Documentation

◆ Subscription

Function Documentation

◆ BKI_LOOKUP() [1/2]

Oid subowner BKI_LOOKUP ( pg_authid  )

◆ BKI_LOOKUP() [2/2]

Oid subdbid BKI_LOOKUP ( pg_database  )

◆ BKI_LOOKUP_OPT()

Oid subserver BKI_LOOKUP_OPT ( pg_foreign_server  )

◆ CATALOG()

◆ CountDBSubscriptions()

int CountDBSubscriptions ( Oid  dbid)
extern

Definition at line 211 of file pg_subscription.c.

212{
213 int nsubs = 0;
214 Relation rel;
216 SysScanDesc scan;
218
220
224 ObjectIdGetDatum(dbid));
225
226 scan = systable_beginscan(rel, InvalidOid, false,
227 NULL, 1, &scankey);
228
229 while (HeapTupleIsValid(tup = systable_getnext(scan)))
230 nsubs++;
231
232 systable_endscan(scan);
233
234 table_close(rel, NoLock);
235
236 return nsubs;
237}
void systable_endscan(SysScanDesc sysscan)
Definition genam.c:604
HeapTuple systable_getnext(SysScanDesc sysscan)
Definition genam.c:515
SysScanDesc systable_beginscan(Relation heapRelation, Oid indexId, bool indexOK, Snapshot snapshot, int nkeys, ScanKey key)
Definition genam.c:388
#define HeapTupleIsValid(tuple)
Definition htup.h:78
#define NoLock
Definition lockdefs.h:34
#define RowExclusiveLock
Definition lockdefs.h:38
static Datum ObjectIdGetDatum(Oid X)
Definition postgres.h:252
#define InvalidOid
static int fb(int x)
void ScanKeyInit(ScanKey entry, AttrNumber attributeNumber, StrategyNumber strategy, RegProcedure procedure, Datum argument)
Definition scankey.c:76
#define BTEqualStrategyNumber
Definition stratnum.h:31
void table_close(Relation relation, LOCKMODE lockmode)
Definition table.c:126
Relation table_open(Oid relationId, LOCKMODE lockmode)
Definition table.c:40

References BTEqualStrategyNumber, fb(), HeapTupleIsValid, InvalidOid, NoLock, ObjectIdGetDatum(), RowExclusiveLock, ScanKeyInit(), systable_beginscan(), systable_endscan(), systable_getnext(), table_close(), and table_open().

Referenced by dropdb().

◆ DECLARE_TOAST_WITH_MACRO()

DECLARE_TOAST_WITH_MACRO ( pg_subscription  ,
4183  ,
4184  ,
PgSubscriptionToastTable  ,
PgSubscriptionToastIndex   
)

◆ DECLARE_UNIQUE_INDEX()

DECLARE_UNIQUE_INDEX ( pg_subscription_subname_index  ,
6115  ,
SubscriptionNameIndexId  ,
pg_subscription  ,
btree(subdbid oid_ops, subname name_ops  
)

◆ DECLARE_UNIQUE_INDEX_PKEY()

DECLARE_UNIQUE_INDEX_PKEY ( pg_subscription_oid_index  ,
6114  ,
SubscriptionObjectIndexId  ,
pg_subscription  ,
btree(oid oid_ops  
)

◆ DisableSubscription()

void DisableSubscription ( Oid  subid)
extern

Definition at line 243 of file pg_subscription.c.

244{
245 Relation rel;
246 bool nulls[Natts_pg_subscription];
250
251 /* Look up the subscription in the catalog */
254
255 if (!HeapTupleIsValid(tup))
256 elog(ERROR, "cache lookup failed for subscription %u", subid);
257
259
260 /* Form a new tuple. */
261 memset(values, 0, sizeof(values));
262 memset(nulls, false, sizeof(nulls));
263 memset(replaces, false, sizeof(replaces));
264
265 /* Set the subscription to disabled. */
268
269 /* Update the catalog */
271 replaces);
272 CatalogTupleUpdate(rel, &tup->t_self, tup);
274
275 table_close(rel, NoLock);
276}
static Datum values[MAXATTR]
Definition bootstrap.c:190
#define ERROR
Definition elog.h:40
#define elog(elevel,...)
Definition elog.h:228
HeapTuple heap_modify_tuple(HeapTuple tuple, TupleDesc tupleDesc, const Datum *replValues, const bool *replIsnull, const bool *doReplace)
Definition heaptuple.c:1118
void heap_freetuple(HeapTuple htup)
Definition heaptuple.c:1372
void CatalogTupleUpdate(Relation heapRel, const ItemPointerData *otid, HeapTuple tup)
Definition indexing.c:313
void LockSharedObject(Oid classid, Oid objid, uint16 objsubid, LOCKMODE lockmode)
Definition lmgr.c:1088
#define AccessShareLock
Definition lockdefs.h:36
static Datum BoolGetDatum(bool X)
Definition postgres.h:112
uint64_t Datum
Definition postgres.h:70
#define RelationGetDescr(relation)
Definition rel.h:542
#define SearchSysCacheCopy1(cacheId, key1)
Definition syscache.h:91

References AccessShareLock, BoolGetDatum(), CatalogTupleUpdate(), elog, ERROR, fb(), heap_freetuple(), heap_modify_tuple(), HeapTupleIsValid, LockSharedObject(), NoLock, ObjectIdGetDatum(), RelationGetDescr, RowExclusiveLock, SearchSysCacheCopy1, table_close(), table_open(), and values.

Referenced by DisableSubscriptionAndExit().

◆ GetPublicationsStr()

void GetPublicationsStr ( List publications,
StringInfo  dest,
bool  quote_literal 
)
extern

Definition at line 50 of file pg_subscription.c.

51{
52 ListCell *lc;
53 bool first = true;
54
55 Assert(publications != NIL);
56
57 foreach(lc, publications)
58 {
59 char *pubname = strVal(lfirst(lc));
60
61 if (quote_literal)
62 {
63 if (!first)
64 appendStringInfoString(dest, ", ");
66 }
67 else
68 {
69 if (first)
70 appendStringInfo(dest, _("\"%s\""), pubname);
71 else
72 appendStringInfo(dest, _(", \"%s\""), pubname);
73 }
74
75 first = false;
76 }
77}
#define Assert(condition)
Definition c.h:943
#define _(x)
Definition elog.c:96
#define lfirst(lc)
Definition pg_list.h:172
#define NIL
Definition pg_list.h:68
char * quote_literal_cstr(const char *rawstr)
Definition quote.c:101
Datum quote_literal(PG_FUNCTION_ARGS)
Definition quote.c:76
void appendStringInfo(StringInfo str, const char *fmt,...)
Definition stringinfo.c:145
void appendStringInfoString(StringInfo str, const char *s)
Definition stringinfo.c:230
#define strVal(v)
Definition value.h:82

References _, appendStringInfo(), appendStringInfoString(), Assert, fb(), lfirst, NIL, quote_literal(), quote_literal_cstr(), and strVal.

Referenced by check_publications_origin_sequences(), check_publications_origin_tables(), fetch_relation_list(), and fetch_remote_table_info().

◆ GetSubscription()

Subscription * GetSubscription ( Oid  subid,
bool  missing_ok,
bool  aclcheck 
)
extern

Definition at line 83 of file pg_subscription.c.

84{
86 Subscription *sub;
88 Datum datum;
89 bool isnull;
90 MemoryContext cxt;
92
94
96 {
97 if (missing_ok)
98 return NULL;
99
100 elog(ERROR, "cache lookup failed for subscription %u", subid);
101 }
102
103 cxt = AllocSetContextCreate(CurrentMemoryContext, "subscription",
106
108
110 sub->cxt = cxt;
111 sub->oid = subid;
112 sub->dbid = subform->subdbid;
113 sub->skiplsn = subform->subskiplsn;
114 sub->name = pstrdup(NameStr(subform->subname));
115 sub->owner = subform->subowner;
116 sub->enabled = subform->subenabled;
117 sub->binary = subform->subbinary;
118 sub->stream = subform->substream;
119 sub->twophasestate = subform->subtwophasestate;
120 sub->disableonerr = subform->subdisableonerr;
121 sub->passwordrequired = subform->subpasswordrequired;
122 sub->runasowner = subform->subrunasowner;
123 sub->failover = subform->subfailover;
124 sub->retaindeadtuples = subform->subretaindeadtuples;
125 sub->maxretention = subform->submaxretention;
126 sub->retentionactive = subform->subretentionactive;
127
128 /* Get conninfo */
129 if (OidIsValid(subform->subserver))
130 {
132 ForeignServer *server;
133
134 server = GetForeignServer(subform->subserver);
135
136 /* recheck ACL if requested */
137 if (aclcheck)
138 {
140 subform->subserver,
141 subform->subowner, ACL_USAGE);
142
143 if (aclresult != ACLCHECK_OK)
146 errmsg("subscription owner \"%s\" does not have permission on foreign server \"%s\"",
147 GetUserNameFromId(subform->subowner, false),
148 server->servername)));
149 }
150
152 server);
153 }
154 else
155 {
157 tup,
159 sub->conninfo = TextDatumGetCString(datum);
160 }
161
162 /* Get slotname */
164 tup,
166 &isnull);
167 if (!isnull)
168 sub->slotname = pstrdup(NameStr(*DatumGetName(datum)));
169 else
170 sub->slotname = NULL;
171
172 /* Get synccommit */
174 tup,
176 sub->synccommit = TextDatumGetCString(datum);
177
178 /* Get walrcvtimeout */
180 tup,
183
184 /* Get publications */
186 tup,
189
190 /* Get origin */
192 tup,
194 sub->origin = TextDatumGetCString(datum);
195
196 /* Is the subscription owner a superuser? */
198
200
202
203 return sub;
204}
AclResult
Definition acl.h:183
@ ACLCHECK_OK
Definition acl.h:184
AclResult object_aclcheck(Oid classid, Oid objectid, Oid roleid, AclMode mode)
Definition aclchk.c:3880
#define DatumGetArrayTypeP(X)
Definition array.h:261
#define TextDatumGetCString(d)
Definition builtins.h:99
#define NameStr(name)
Definition c.h:835
#define OidIsValid(objectId)
Definition c.h:858
int errcode(int sqlerrcode)
Definition elog.c:875
#define ereport(elevel,...)
Definition elog.h:152
#define palloc_object(type)
Definition fe_memutils.h:89
char * ForeignServerConnectionString(Oid userid, ForeignServer *server)
Definition foreign.c:202
ForeignServer * GetForeignServer(Oid serverid)
Definition foreign.c:114
static void * GETSTRUCT(const HeapTupleData *tuple)
char * pstrdup(const char *in)
Definition mcxt.c:1910
MemoryContext CurrentMemoryContext
Definition mcxt.c:161
#define AllocSetContextCreate
Definition memutils.h:129
#define ALLOCSET_SMALL_SIZES
Definition memutils.h:170
char * GetUserNameFromId(Oid roleid, bool noerr)
Definition miscinit.c:990
static char * errmsg
static MemoryContext MemoryContextSwitchTo(MemoryContext context)
Definition palloc.h:138
#define ACL_USAGE
Definition parsenodes.h:84
static List * textarray_to_stringlist(ArrayType *textarray)
END_CATALOG_STRUCT typedef FormData_pg_subscription * Form_pg_subscription
static Name DatumGetName(Datum X)
Definition postgres.h:393
char * servername
Definition foreign.h:40
MemoryContext cxt
XLogRecPtr skiplsn
bool superuser_arg(Oid roleid)
Definition superuser.c:57
void ReleaseSysCache(HeapTuple tuple)
Definition syscache.c:265
Datum SysCacheGetAttrNotNull(SysCacheIdentifier cacheId, HeapTuple tup, AttrNumber attributeNumber)
Definition syscache.c:626
HeapTuple SearchSysCache1(SysCacheIdentifier cacheId, Datum key1)
Definition syscache.c:221
Datum SysCacheGetAttr(SysCacheIdentifier cacheId, HeapTuple tup, AttrNumber attributeNumber, bool *isNull)
Definition syscache.c:596

References ACL_USAGE, ACLCHECK_OK, ALLOCSET_SMALL_SIZES, AllocSetContextCreate, Subscription::binary, Subscription::conninfo, CurrentMemoryContext, Subscription::cxt, DatumGetArrayTypeP, DatumGetName(), Subscription::dbid, Subscription::disableonerr, elog, Subscription::enabled, ereport, errcode(), errmsg, ERROR, Subscription::failover, fb(), ForeignServerConnectionString(), Form_pg_subscription, GetForeignServer(), GETSTRUCT(), GetUserNameFromId(), HeapTupleIsValid, Subscription::maxretention, MemoryContextSwitchTo(), Subscription::name, NameStr, object_aclcheck(), ObjectIdGetDatum(), Subscription::oid, OidIsValid, Subscription::origin, Subscription::owner, Subscription::ownersuperuser, palloc_object, Subscription::passwordrequired, pstrdup(), Subscription::publications, ReleaseSysCache(), Subscription::retaindeadtuples, Subscription::retentionactive, Subscription::runasowner, SearchSysCache1(), ForeignServer::servername, Subscription::skiplsn, Subscription::slotname, Subscription::stream, superuser_arg(), Subscription::synccommit, SysCacheGetAttr(), SysCacheGetAttrNotNull(), textarray_to_stringlist(), TextDatumGetCString, Subscription::twophasestate, and Subscription::walrcvtimeout.

Referenced by AlterSubscription(), InitializeLogRepWorker(), and maybe_reread_subscription().

◆ MAKE_SYSCACHE() [1/2]

MAKE_SYSCACHE ( SUBSCRIPTIONNAME  ,
pg_subscription_subname_index  ,
 
)

◆ MAKE_SYSCACHE() [2/2]

MAKE_SYSCACHE ( SUBSCRIPTIONOID  ,
pg_subscription_oid_index  ,
 
)

Variable Documentation

◆ BKI_SCHEMA_MACRO

Initial value:
{
Oid oid
unsigned int Oid

Definition at line 45 of file pg_subscription.h.

◆ Form_pg_subscription

◆ FormData_pg_subscription

FormData_pg_subscription

Definition at line 117 of file pg_subscription.h.

◆ subbinary

bool subbinary

Definition at line 62 of file pg_subscription.h.

◆ subdisableonerr

bool subdisableonerr

Definition at line 70 of file pg_subscription.h.

◆ subenabled

bool subenabled

Definition at line 59 of file pg_subscription.h.

◆ subfailover

bool subfailover

Definition at line 78 of file pg_subscription.h.

◆ submaxretention

int32 submaxretention

Definition at line 86 of file pg_subscription.h.

◆ subname

◆ subpasswordrequired

bool subpasswordrequired

Definition at line 73 of file pg_subscription.h.

◆ subretaindeadtuples

bool subretaindeadtuples

Definition at line 83 of file pg_subscription.h.

◆ subretentionactive

bool subretentionactive

Definition at line 90 of file pg_subscription.h.

◆ subrunasowner

bool subrunasowner

Definition at line 75 of file pg_subscription.h.

◆ subskiplsn

XLogRecPtr subskiplsn

Definition at line 52 of file pg_subscription.h.

◆ substream

char substream

Definition at line 65 of file pg_subscription.h.

◆ subtwophasestate

char subtwophasestate

Definition at line 68 of file pg_subscription.h.