6 Configuring Command Rules
You can create command rules or use the default command rules to protect DDL and DML statements.
- What Are Command Rules?
A command rule applies Oracle Database Vault protections with an Oracle Database SQL statement, such asALTER SESSION
. - Default Command Rules
Oracle Database Vault provides default command rules, based on commonly used SQL statements. - SQL Statements That Can Be Protected by Command Rules
You can protect a large number of SQL statements by using command rules. - Creating a Command Rule
You can create a different types of command rules using different command rule APIs. - Modifying a Command Rule
You can use theDBMS_MACADM.UPDATE_COMMAND_RULE
,DBMS_MACADM.UPDATE_CONNECT_COMMAND_RULE
,DBMS_MACADM.UPDATE_SESSION_EVENT_CMD_RULE
, andDBMS_MACADM.UPDATE_SYSTEM_EVENT_CMD_RULE
procedures to modify the definition of a command rule. - Deleting a Command Rule
Before you delete a command rule, you can locate the various references to it by querying the command rule-related Oracle Database Vault views. - How Command Rules Work
Command rules follow a set of steps to check their associated components. - Tutorial: Using a Command Rule to Control Table Creations by a User
In this tutorial, you create a simple local command rule to control whether users can create tables in theSCOTT
schema. - Guidelines for Designing Command Rules
Oracle provides guidelines for designing command rules. - How Command Rules Affect Performance
The performance of a command rule depends on the complexity of the rules in the rule set associated with the command rule. - Command Rule Related Reports and Data Dictionary View
Oracle Database Vault provides reports and a data dictionary view that are useful for analyzing command rules.
What Are Command Rules?
A command rule applies Oracle Database Vault protections with an Oracle Database SQL statement, such as ALTER SESSION
.
- About Command Rules
A command rule protects Oracle Database SQL statements that affect one or more database objects. - Command Rules in a Multitenant Environment
You can create common and local command rules in either the CDB root or the application root. - Types of Command Rules
In addition to command rules for many SQL statements, you can create command rules specifically for theCONNECT
,ALTER SYSTEM
, andALTER SESSION
SQL statements.
Parent topic: Configuring Command Rules
About Command Rules
A command rule protects Oracle Database SQL statements that affect one or more database objects.
These statements can include SELECT
, ALTER SYSTEM
, database definition language (DDL), and data manipulation language (DML) statements.
To customize and enforce the command rule, you associate it with a rule set, which is a collection of one or more rules. The command rule is enforced at run time. Command rules affect anyone who tries to use the SQL statements it protects, regardless of the realm in which the object exists.
You can use command rules to protect a wide range of SQL statements, in addition to basic Oracle Database DDL and DML statements. For example, you can protect statements that are used with Oracle Flashback Technology.
A command rule has the following attributes, in addition to associating a command rule to a command:
-
SQL statement the command rule protects
-
Owner of the object the command rule affects
-
Database object the command rule affects
-
Whether the command rule is enabled
-
An associated rule set
Command rules can be categorized as follows:
-
Command rules that have a system-wide scope. With this type, in most cases, you can only create one command rule for each database instance.
-
Command rules that are schema specific. An example of a schema-specific command rule is a command rule for the
DROP TABLE
statement. You can create only one CONNECT command rule for each schema. -
Command rules that are object specific. An example is creating a command rule for the
DROP TABLE
statement with a specific table included in the command rule definition.
When a user executes a statement affected by a command rule, Oracle Database Vault checks the realm authorization first. If it finds no realm violation and if the associated command rules are enabled, then Database Vault evaluates the associated rule sets. If all the rule sets evaluate to TRUE
, then the statement is authorized for further processing. If any of the rule sets evaluate to FALSE
, then the statement is not allowed to be executed and a command rule violation is raised.
You can define a command rule that uses factors for the CONNECT
event to permit or deny sessions after the usual steps–user authentication process,
factor initialization, and Oracle Label Security integration–are complete. For example,
you can configure a command rule that allows DDL statements such as CREATE
TABLE
, DROP TABLE
, and ALTER TABLE
in the
BIZAPP
schema to be authorized after business hours, but not during
business hours.
You can run reports on the command rules that you create in Oracle Database Vault.
You cannot create command rules that block SYS
from executing
SYS
-owned procedures.
Command Rules in a Multitenant Environment
You can create common and local command rules in either the CDB root or the application root.
Common command rules can be associated only with common realms, rule sets, and rules. Local command rules can be associated only with local realm, rule sets, and rules.
To apply these command rules to the entire multitenant environment, you must execute the command rule procedures from the CDB root or application root as a common user who has been granted the DVADM
or DVOWNER
role. A common command rule that is created in the CDB root will be applied to all PDBs in that CDB environment. A common command rule that is created in the application root will only be applied to the PDBs that are associated with this application root. To propagate the command rule to the PDBs that are associated with the CDB root or application root, you must synchronize the PDB. For example, to synchronize an application root called saas_sales_app
to its application PDBs:
ALTER PLUGGABLE DATABASE APPLICATION saas_sales_app SYNC;
To synchronize a common command rule in the CDB root to a PDB:
ALTER PLUGGABLE DATABASE APPLICATION APP$CDB$SYSTEM SYNC;
You can check a user’s roles by querying the USER_ROLE_PRIVS
data dictionary view. To find information about command rules, query the DBA_DV_COMMAND_RULE
data dictionary view.
Parent topic: What Are Command Rules?
Types of Command Rules
In addition to command rules for many SQL statements, you can create command rules specifically for the CONNECT
, ALTER SYSTEM
, and ALTER SESSION
SQL statements.
- CONNECT Command Rule
TheDBMS_MACADM.CREATE_CONNECT_CMD_RULE
procedure creates a user-specificCONNECT
command rule. - ALTER SESSION and ALTER SYSTEM Command Rules
You can create different kinds ofALTER SESSION
andALTER SYSTEM
command rules that provide fine-grained control for these SQL statements.
Parent topic: What Are Command Rules?
CONNECT Command Rule
The DBMS_MACADM.CREATE_CONNECT_CMD_RULE
procedure creates a user-specific CONNECT
command rule.
This type of command rule specifies a user, an associated rule set, an enablement status, and where to execute the CONNECT
command rule. You can enable or disable the CONNECT
command rule, or you can set it to use simulation mode. In simulation mode, violations to the command rule are logged in a designated log table with sufficient information to describe the error, such as the user name or SQL statement used.
You can create the CONNECT
command rule in either the application root or in a specific PDB. The associated rule set must be consistent with the CONNECT
command rule: if the CONNECT
command rule is in the application root, then the rule set and rules must also be in the application root. You run the CONNECT
command rule procedures from the CDB root as a common user. If the CONNECT
command rule is local to a pluggable database (PDB), then you must run the CONNECT
command rule creation command in that PDB, and the rule set and rules must be local.
The following example shows a CONNECT
command rule definition that creates a local, enabled CONNECT
command rule for the HR
user. The rule set that is associated with this command rule is local to the current PDB.
BEGIN DBMS_MACADM.CREATE_CONNECT_COMMAND_RULE( rule_set_name => 'Enabled', user_name => 'HR', enabled => DBMS_MACUTL.G_YES, scope => DBMS_MACUTL.G_SCOPE_LOCAL); END; /
Related Topics
Parent topic: Types of Command Rules
ALTER SESSION and ALTER SYSTEM Command Rules
You can create different kinds of ALTER SESSION
and ALTER SYSTEM
command rules that provide fine-grained control for these SQL statements.
The procedures to create these types of command rules are as follows:
-
DBMS_MACADM.CREATE_COMMAND_RULE
createsALTER SESSION
andALTER SYSTEM
command rules that use clauses from the corresponding SQL statement, such asADVISE
,CLOSE DATABASE LINK
,COMMIT IN PROCEDURE
, andSET
forALTER SESSION
, orARCHIVE_LOG
,CHECK DATAFILES
,CHECKPOINT
, andSET
forALTER SYSTEM
. -
DBMS_MACADM.CREATE_SESSION_EVENT
creates a command rule that is specific to theALTER SESSION SET EVENTS
SQL statement -
DBMS_MACADM_CREATE_SYSTEM_EVENT
creates a command rule that is specific to theALTER SYSTEM SET EVENTS
SQL statement.
To create these command rules, you use the appropriate Database Vault procedure to specify the clause and if applicable, the parameter of the clause, in the creation statement. If the ALTER SESSION
or ALTER SYSTEM
command rule use the SET EVENTS
setting, then you can use special parameters to specify events, components, and actions.
For example, for an ALTER SYSTEM
command rule, you could specify the SECURITY
clause and its RESTRICTED SESSION
parameter from the ALTER SYSTEM
SQL statement. To specify whether RESTRICTED SESSION
is TRUE
or FALSE
, you must create a Database Vault rule and rule set, which can test for the validity of this sequence number.
To understand how this concept works, first create the following rule and rule set, which are designed to check if the RESTRICTED SESSION
parameter is set to TRUE
:
EXEC DBMS_MACADM.CREATE_RULE('RESTRICTED SESSION TRUE', 'UPPER(PARAMETER_VALUE) = ''TRUE'''); BEGIN DBMS_MACADM.CREATE_RULE_SET( rule_set_name => 'Check RESTRICTED SESSION for TRUE', description => 'Checks if restricted session is true', enabled => DBMS_MACUTL.G_YES, eval_options => DBMS_MACUTL.G_RULESET_EVAL_ALL, audit_options => DBMS_MACUTL.G_RULESET_AUDIT_OFF, fail_options => DBMS_MACUTL.G_RULESET_FAIL_SILENT, fail_message => 'RESTRICTED SESSION is not TRUE', fail_code => 20461, handler_options => DBMS_MACUTL.G_RULESET_HANDLER_FAIL, handler => '', is_static => false); END; / EXEC DBMS_MACADM.ADD_RULE_TO_RULE_SET(Check RESTRICTED SESSION for TRUE', 'RESTRICTED SESSION TRUE');
With the rule and rule set in place, you are ready to create an ALTER SYSTEM command rule that will check if the RESTRICTED SESSION
parameter:
BEGIN DBMS_MACADM.CREATE_COMMAND_RULE( command => 'ALTER SYSTEM', rule_set_name => 'Check RESTRICTED SESSION for TRUE', object_owner => '%', object_name => '%', enabled => DBMS_MACUTL.G_YES, clause_name => 'SECURITY', parameter_name => 'RESTRICTED SESSION', scope => DBMS_MACUTL.G_SCOPE_LOCAL); END; /
In this example:
-
rule_set_name
checks whetherRESTRICTED SESSION
is set toTRUE
orFALSE
. You must create the rule set and rule in the same location as the command rule: either in the application root or locally in a PDB. -
object_owner
andobject_name
must always be set to%
for this kind ofALTER SESSION
orALTER SYSTEM
command rule. -
enabled
enables you to enable or disable the command rule, or to use simulation mode to log violations to the command rule to a designated log table. The log data describes the error, such as the user name or SQL statement used. -
clause_name
specifies theSECURITY
clause of theALTER SYSTEM
SQL statement -
parameter_name
specifies theRESTRICTED SESSION
parameter from theSECURITY
clause -
scope
sets the command rule to be local to the current PDB. The associated rule set and rule must also be local to the current PDB. If you want to create the command rule in the application root, then as a common user, you would setscope
toDBMS_MACUTL.G_SCOPE_COMMON
and run the procedure (and its accompanying rule set and rule creation procedures) from the application root.
See Also:
-
CREATE_COMMAND_RULE Procedure about the
DBMS_MACADM.CREATE_COMMAND_RULE
procedure -
CREATE_SESSION_EVENT_CMD_RULE Procedure about the
DVS.DBMS_MACADM.CREATE_SESSION_EVENT_CMD_RULE
procedure -
CREATE_SYSTEM_EVENT_CMD_RULE Procedure for more information about the
DBMS_MACADM.CREATE_SYSTEM_EVENT_CMD_RULE
procedure -
DBA_DV_COMMAND_RULE View for information about the
DBA_DV_COMMAND_RULE
data dictionary view -
Oracle Database SQL Language Reference for information about the
ALTER SESSION
SQL statement -
Oracle Database SQL Language Reference for information about the
ALTER SYSTEM
SQL statement
Parent topic: Types of Command Rules
Default Command Rules
Oracle Database Vault provides default command rules, based on commonly used SQL statements.
Table 6-1 lists the default Database Vault command rules.
Table 6-1 Default Command Rules
SQL Statement | Rule Set Name |
---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Footnote 1
The actual SQL statement that the Can Maintain Own Account rule refers to is PASSWORD
.
The following set of command rules helps you to achieve separation of duty for user management:
-
ALTER PROFILE
-
ALTER USER
-
CREATE PROFILE
-
CREATE USER
-
DROP PROFILE
-
DROP USER
To grant a user the ability to use these commands, you can grant the user the role that the rule set checks. For example, the CREATE USER
command rule ensures that a user who tries to run a CREATE USER
statement has the DV_ACCTMGR
role.
Note:
To find information about the default command rules, query the DBA_DV_COMMAND_RULE
data dictionary view.
Parent topic: Configuring Command Rules
SQL Statements That Can Be Protected by Command Rules
You can protect a large number of SQL statements by using command rules.
The SQL statements that you can protect are as follows:
SQL Statements A-A | SQL Statements A-D | SQL Statements C-U |
---|---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Related Topics
Parent topic: Configuring Command Rules
Creating a Command Rule
You can create a different types of command rules using different command rule APIs.
DBMS_MACADM.CREATE_COMMAND_RULE
, DBMS_MACADM.CREATE_CONNECT_COMMAND_RULE
, DBMS_MACADM.CREATE_SYSTEM_EVENT_CMD_RULE
. The DBMS_MACADM.CREATE_COMMAND_RULE
procedure enables you to create complex command rules for ALTER SYSTEM
and ALTER SESSION
statements. This topic describes how to create a command rule using the DBMS_MACADM.CREATE_COMMAND_RULE
procedure.
Modifying a Command Rule
You can use the DBMS_MACADM.UPDATE_COMMAND_RULE
, DBMS_MACADM.UPDATE_CONNECT_COMMAND_RULE
, DBMS_MACADM.UPDATE_SESSION_EVENT_CMD_RULE
, and DBMS_MACADM.UPDATE_SYSTEM_EVENT_CMD_RULE
procedures to modify the definition of a command rule.
Related Topics
Parent topic: Configuring Command Rules
Deleting a Command Rule
Before you delete a command rule, you can locate the various references to it by querying the command rule-related Oracle Database Vault views.
Related Topics
Parent topic: Configuring Command Rules
How Command Rules Work
Command rules follow a set of steps to check their associated components.
How Realms Work describes what happens when a database account issues a SELECT
, DDL, or DML statement that affects objects within a realm.
The following actions take place when SELECT
, DDL, or DML statement is issued:
-
Oracle Database Vault queries all the command rules that need to be applied.
For
SELECT
, DDL, and DML statements, multiple command rules may apply because the object owner and object name support wildcard notation.You can associate rule sets with both command rules and realm authorizations. Oracle Database Vault evaluates the realm authorization rule set first, and then it evaluates the rule sets that apply to the command type being evaluated.
-
For each command rule that applies, Oracle Database Vault evaluates its associated rule set.
-
If the associated rule set of any of the applicable command rules returns false or errors, Oracle Database Vault prevents the command from executing. Otherwise, the command is authorized for further processing. The configuration of the rule set with respect to auditing and event handlers dictates the auditing or custom processing that occurs.
Command rules override object privileges. That is, even the owner of an object cannot access the object if the object is protected by a command rule. You can disable either a command rule or the rule set of a command. If you disable a command rule, then the command rule does not perform the check it is designed to handle. If you disable a rule set, then the rule set always evaluates to
TRUE
. However, if you want to disable a command rule for a particular command, then you should disable the command rule because the rule set may be associated with other command rules or realm authorizations.
Parent topic: Configuring Command Rules
Tutorial: Using a Command Rule to Control Table Creations by a User
In this tutorial, you create a simple local command rule to control whether users can create tables in the SCOTT
schema.
- Step 1: Create a Table
First, userSCOTT
must create a table. - Step 2: Create a Command Rule
After the table has been created in theSCOTT
schema, you can create a command rule. - Step 3: Test the Command Rule
Next, you are ready to test theCREATE TABLE
local command rule. - Step 4: Remove the Components for this Tutorial
You can remove the components that you created for this tutorial if you no longer need them.
Parent topic: Configuring Command Rules
Step 1: Create a Table
First, user SCOTT
must create a table.
At this stage, user SCOTT
can create and drop tables. Do not exit SQL*Plus yet, and remain connected as SCOTT
. You must use it later on when SCOTT
tries to create another table.
Related Topics
Step 2: Create a Command Rule
After the table has been created in the SCOTT
schema, you can create a command rule.
Command rules take effect immediately. Right away, user SCOTT
is prevented from creating tables, even though he is still in the same user session he was in a moment ago, before you created the CREATE TABLE
command rule.
Step 3: Test the Command Rule
Next, you are ready to test the CREATE TABLE
local command rule.
-
In SQL*Plus, ensure that you are logged in to the PDB as user
SCOTT
.CONNECT SCOTT@pdb_name Enter password: password
-
Try to create a table.
CREATE TABLE t1 (num NUMBER);
The following output should appear:
ORA-47400: Command Rule violation for create table on SCOTT.T1
As you can see,
SCOTT
is no longer allowed to create tables, even in his own schema. - Now enable user
SCOTT
to create tables again.- Connect to the PDB as the user who created the command rule.
- Update the
CREATE TABLE
command rule to now enable table creations.BEGIN DBMS_MACADM.UPDATE_COMMAND_RULE( command => 'CREATE TABLE', rule_set_name => 'Enabled', object_owner => 'SCOTT', object_name => '%', enabled => DBMS_MACUTL.G_YES); END; /
-
Connect as user
SCOTT
, and then try creating the table again.CONNECT scott@hrpdb Enter password: password CREATE TABLE t1 (num NUMBER); Table created.
- User
SCOTT
does not really need this table, so drop the table.DROP TABLE t1;
Now that the CREATE TABLE
command rule is set to Enabled
, user SCOTT
is once again permitted to create tables. (Do not exit SQL*Plus.)
Step 4: Remove the Components for this Tutorial
You can remove the components that you created for this tutorial if you no longer need them.
-
Connect to the PDB as the user who created the
CREATE TABLE
command rule.For example:
CONNECT c##sec_admin_owen@hrpdb Enter password: password
- Drop the
CREATE TABLE
command rule.Remember that the
command
,object_owner
, andobject_nam
e arguments must match exactly the arguments that were used the last time the command rule was updated. You can check a command rule's definition by querying theDBA_DV_COMMAND_RULE
data dictionary view.BEGIN DBMS_MACADM.DELETE_COMMAND_RULE( command => 'CREATE TABLE', object_owner => 'SCOTT', object_name => '%'); END; /
-
If you no longer need the
SCOTT
account to be available, then connect to the PDB as the Database Vault Account Manager and enter the followingALTER USER
statement:CONNECT bea_dvacctmgr@pdb_name Enter password: password ALTER USER SCOTT ACCOUNT LOCK PASSWORD EXPIRE;
Guidelines for Designing Command Rules
Oracle provides guidelines for designing command rules.
-
Create finer-grained command rules, because they are far easier to maintain.
For example, if you want to prevent
SELECT
statements from occurring on specific schema objects, then design multiple command rules to stop theSELECT
statements on those specific schema objects, rather than creating a general command rule to preventSELECT
statements in the schema level. -
When designing rules for the
CONNECT
event, be careful to include logic that does not inadvertently lock out any required user connections. If any account has been locked out accidentally, ask a user who has been granted theDV_ADMIN
orDV_OWNER
role to log in and correct the rule that is causing the lock-out problem. TheCONNECT
command rule does not apply to users with theDV_OWNER
andDV_ADMIN
roles. This prevents improperly configuredCONNECT
command rules from causing a complete lock-out.If the account has been locked out, you can disable Oracle Database Vault, correct the rule that is causing the lock-out problem, and then reenable Oracle Database Vault. Even when Oracle Database Vault is disabled, you still can use Database Vault Administrator and the Database Vault PL/SQL packages.
-
Sometimes you must temporarily relax an enabled command rule for an administrative task. Rather than disabling the command rule, have the security manager (the account with the
DV_ADMIN
orDV_OWNER
role) log in, for the default rule setEnabled
, set theenabled
parameter toDBMS_MACUTL.G_YES
,audit_options
toDBMS_MACUTL.G_RULESET_AUDIT_FAIL + DBMS_MACUTL.G_RULESET_AUDIT_SUCCESS
, and then set the command rule back to its original rule set when the task is complete. (Be aware that in a unified auditing environment, this setting does not work. Instead, you must create a unified audit policy.) -
When designing command rules, be careful to consider automated processes such as backup where these procedures may be inadvertently disabled. You can account for these tasks by creating rules that allow the command when a series of Oracle Database Vault factors is known to be true (for example, the program being used), and the account being used or the computer or network on which the client program is running.
-
You can test the development phase of a command rule by using simulation mode, which enables the command rule but writes detailed information about it to a log file.
Parent topic: Configuring Command Rules
How Command Rules Affect Performance
The performance of a command rule depends on the complexity of the rules in the rule set associated with the command rule.
For example, suppose a rule set invokes a PL/SQL function that takes 5 seconds to run. In this case, a command rule that uses that rule set would take 5 seconds to grant access for the command statement to run.
You can check the system performance by running tools such as Oracle Enterprise Manager (including Oracle Enterprise Manager Cloud Control, which is installed by default with Oracle Database), Automatic Workload Repository (AWR), and TKPROF
.
Parent topic: Configuring Command Rules
Command Rule Related Reports and Data Dictionary View
Oracle Database Vault provides reports and a data dictionary view that are useful for analyzing command rules.
Table 6-2 lists the Oracle Database Vault report.
Table 6-2 Reports Related to Command Rules
Report | Description |
---|---|
Command Rule Audit Report |
Lists audit records generated by command rule processing operations |
Command Rule Configuration Issues Report |
Tracks rule violations, in addition to other configuration issues the command rule may have |
Object privilege reports |
List object privileges that the command rule affects |
Sensitive object reports |
List objects that the command rule affects |
Rule Set Configuration Issues Report |
Lists rules sets that have no rules defined or enabled, which may affect the command rules that use them |
You can use the DBA_DV_COMMAND_RULE
data dictionary view to find the SQL statements that are protected by command rules.
Parent topic: Configuring Command Rules