PostgreSQL Source Code git master
Loading...
Searching...
No Matches
database.c File Reference
#include "postgres.h"
#include "access/genam.h"
#include "access/htup_details.h"
#include "access/sysattr.h"
#include "access/table.h"
#include "catalog/dependency.h"
#include "catalog/pg_database.h"
#include "commands/seclabel.h"
#include "sepgsql.h"
#include "utils/builtins.h"
#include "utils/fmgroids.h"
#include "utils/snapmgr.h"
Include dependency graph for database.c:

Go to the source code of this file.

Functions

void sepgsql_database_post_create (Oid databaseId, const char *dtemplate)
 
void sepgsql_database_drop (Oid databaseId)
 
void sepgsql_database_setattr (Oid databaseId)
 
void sepgsql_database_relabel (Oid databaseId, const char *seclabel)
 

Function Documentation

◆ sepgsql_database_drop()

void sepgsql_database_drop ( Oid  databaseId)

Definition at line 132 of file database.c.

133{
134 ObjectAddress object;
135 char *audit_name;
136
137 /*
138 * check db_database:{drop} permission
139 */
141 object.objectId = databaseId;
142 object.objectSubId = 0;
143 audit_name = getObjectIdentity(&object, false);
144
149 true);
151}
void pfree(void *pointer)
Definition mcxt.c:1616
char * getObjectIdentity(const ObjectAddress *object, bool missing_ok)
static int fb(int x)
#define SEPG_CLASS_DB_DATABASE
Definition sepgsql.h:44
#define SEPG_DB_DATABASE__DROP
Definition sepgsql.h:119
bool sepgsql_avc_check_perms(const ObjectAddress *tobject, uint16 tclass, uint32 required, const char *audit_name, bool abort_on_violation)
Definition uavc.c:420

References ObjectAddress::classId, fb(), getObjectIdentity(), pfree(), SEPG_CLASS_DB_DATABASE, SEPG_DB_DATABASE__DROP, and sepgsql_avc_check_perms().

Referenced by sepgsql_object_access().

◆ sepgsql_database_post_create()

void sepgsql_database_post_create ( Oid  databaseId,
const char dtemplate 
)

Definition at line 32 of file database.c.

33{
34 Relation rel;
37 HeapTuple tuple;
38 char *tcontext;
39 char *ncontext;
40 ObjectAddress object;
43
44 /*
45 * Oid of the source database is not saved in pg_database catalog, so we
46 * collect its identifier using contextual information. If NULL, its
47 * default is "template1" according to createdb().
48 */
49 if (!dtemplate)
50 dtemplate = "template1";
51
52 object.classId = DatabaseRelationId;
53 object.objectId = get_database_oid(dtemplate, false);
54 object.objectSubId = 0;
55
56 tcontext = sepgsql_get_label(object.classId,
57 object.objectId,
58 object.objectSubId);
59
60 /*
61 * check db_database:{getattr} permission
62 */
68 audit_name.data,
69 true);
70
71 /*
72 * Compute a default security label of the newly created database based on
73 * a pair of security label of client and source database.
74 *
75 * XXX - upcoming version of libselinux supports to take object name to
76 * handle special treatment on default security label.
77 */
79
83 ObjectIdGetDatum(databaseId));
84
86 SnapshotSelf, 1, &skey);
87 tuple = systable_getnext(sscan);
88 if (!HeapTupleIsValid(tuple))
89 elog(ERROR, "could not find tuple for database %u", databaseId);
90
92
94 tcontext,
96 NameStr(datForm->datname));
97
98 /*
99 * check db_database:{create} permission
100 */
103 quote_identifier(NameStr(datForm->datname)));
107 audit_name.data,
108 true);
109
112
113 /*
114 * Assign the default security label on the new database
115 */
116 object.classId = DatabaseRelationId;
117 object.objectId = databaseId;
118 object.objectSubId = 0;
119
120 SetSecurityLabel(&object, SEPGSQL_LABEL_TAG, ncontext);
121
122 pfree(ncontext);
123 pfree(tcontext);
124}
#define NameStr(name)
Definition c.h:765
Oid get_database_oid(const char *dbname, bool missing_ok)
#define ERROR
Definition elog.h:39
#define elog(elevel,...)
Definition elog.h:226
void systable_endscan(SysScanDesc sysscan)
Definition genam.c:603
HeapTuple systable_getnext(SysScanDesc sysscan)
Definition genam.c:514
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
static void * GETSTRUCT(const HeapTupleData *tuple)
char * sepgsql_get_label(Oid classId, Oid objectId, int32 subId)
Definition label.c:444
char * sepgsql_get_client_label(void)
Definition label.c:79
#define AccessShareLock
Definition lockdefs.h:36
FormData_pg_database * Form_pg_database
Definition pg_database.h:96
static Datum ObjectIdGetDatum(Oid X)
Definition postgres.h:262
const char * quote_identifier(const char *ident)
void ScanKeyInit(ScanKey entry, AttrNumber attributeNumber, StrategyNumber strategy, RegProcedure procedure, Datum argument)
Definition scankey.c:76
void SetSecurityLabel(const ObjectAddress *object, const char *provider, const char *label)
Definition seclabel.c:404
char * sepgsql_compute_create(const char *scontext, const char *tcontext, uint16 tclass, const char *objname)
Definition selinux.c:842
#define SEPG_DB_DATABASE__CREATE
Definition sepgsql.h:118
bool sepgsql_avc_check_perms_label(const char *tcontext, uint16 tclass, uint32 required, const char *audit_name, bool abort_on_violation)
Definition uavc.c:337
#define SEPG_DB_DATABASE__GETATTR
Definition sepgsql.h:120
#define SEPGSQL_LABEL_TAG
Definition sepgsql.h:23
#define SnapshotSelf
Definition snapmgr.h:32
#define BTEqualStrategyNumber
Definition stratnum.h:31
void resetStringInfo(StringInfo str)
Definition stringinfo.c:126
void appendStringInfoString(StringInfo str, const char *s)
Definition stringinfo.c:230
void initStringInfo(StringInfo str)
Definition stringinfo.c:97
void table_close(Relation relation, LOCKMODE lockmode)
Definition table.c:126
Relation table_open(Oid relationId, LOCKMODE lockmode)
Definition table.c:40

References AccessShareLock, appendStringInfoString(), BTEqualStrategyNumber, elog, ERROR, fb(), get_database_oid(), GETSTRUCT(), HeapTupleIsValid, initStringInfo(), NameStr, ObjectIdGetDatum(), pfree(), quote_identifier(), resetStringInfo(), ScanKeyInit(), SEPG_CLASS_DB_DATABASE, SEPG_DB_DATABASE__CREATE, SEPG_DB_DATABASE__GETATTR, sepgsql_avc_check_perms_label(), sepgsql_compute_create(), sepgsql_get_client_label(), sepgsql_get_label(), SEPGSQL_LABEL_TAG, SetSecurityLabel(), SnapshotSelf, systable_beginscan(), systable_endscan(), systable_getnext(), table_close(), and table_open().

Referenced by sepgsql_object_access().

◆ sepgsql_database_relabel()

void sepgsql_database_relabel ( Oid  databaseId,
const char seclabel 
)

Definition at line 186 of file database.c.

187{
188 ObjectAddress object;
189 char *audit_name;
190
192 object.objectId = databaseId;
193 object.objectSubId = 0;
194 audit_name = getObjectIdentity(&object, false);
195
196 /*
197 * check db_database:{setattr relabelfrom} permission
198 */
204 true);
205
206 /*
207 * check db_database:{relabelto} permission
208 */
213 true);
215}
#define SEPG_DB_DATABASE__SETATTR
Definition sepgsql.h:121
#define SEPG_DB_DATABASE__RELABELTO
Definition sepgsql.h:123
#define SEPG_DB_DATABASE__RELABELFROM
Definition sepgsql.h:122

References ObjectAddress::classId, fb(), getObjectIdentity(), pfree(), SEPG_CLASS_DB_DATABASE, SEPG_DB_DATABASE__RELABELFROM, SEPG_DB_DATABASE__RELABELTO, SEPG_DB_DATABASE__SETATTR, sepgsql_avc_check_perms(), and sepgsql_avc_check_perms_label().

Referenced by sepgsql_object_relabel().

◆ sepgsql_database_setattr()

void sepgsql_database_setattr ( Oid  databaseId)

Definition at line 159 of file database.c.

160{
161 ObjectAddress object;
162 char *audit_name;
163
164 /*
165 * check db_database:{setattr} permission
166 */
168 object.objectId = databaseId;
169 object.objectSubId = 0;
170 audit_name = getObjectIdentity(&object, false);
171
176 true);
178}

References ObjectAddress::classId, fb(), getObjectIdentity(), pfree(), SEPG_CLASS_DB_DATABASE, SEPG_DB_DATABASE__SETATTR, and sepgsql_avc_check_perms().

Referenced by sepgsql_object_access().