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_RULEprocedures 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 theSCOTTschema.
- 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.
6.1 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 SESSIONSQL statements.
Parent topic: Configuring Command Rules
6.1.1 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. For example, CONNECTorALTER SYSTEMcommand rules are enforced system-wide.
- 
                           Command rules that are schema specific. An example of a schema-specific command rule is a command rule for the DROP TABLEstatement. 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 TABLEstatement with a specific table included in the command rule definition.
When a user runs 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 run 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. In addition, 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 by using the data dictionary views or the reports included in Oracle Enterprise Manager.
You cannot create command rules that block SYS from executing SYS-owned procedures. Instead, you should minimize your use of the SYS database user and, instead, create named accounts with the appropriate privileges. The SYS account should be reserved for installation, database creation, and database patching.. 
                     
6.1.2 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 run 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?
6.1.3 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_RULEprocedure creates a user-specificCONNECTcommand rule.
- ALTER SESSION and ALTER SYSTEM Command Rules
 You can create different kinds ofALTER SESSIONandALTER SYSTEMcommand rules that provide fine-grained control for these SQL statements.
Parent topic: What Are Command Rules?
6.1.3.1 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 run 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
6.1.3.2 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_RULEcreatesALTER SESSIONandALTER SYSTEMcommand rules that use clauses from the corresponding SQL statement, such asADVISE,CLOSE DATABASE LINK,COMMIT IN PROCEDURE, andSETforALTER SESSION, orARCHIVE_LOG,CHECK DATAFILES,CHECKPOINT, andSETforALTER SYSTEM.
- 
                              DBMS_MACADM.CREATE_SESSION_EVENTcreates a command rule that is specific to theALTER SESSION SET EVENTSSQL statement
- 
                              DBMS_MACADM_CREATE_SYSTEM_EVENTcreates a command rule that is specific to theALTER SYSTEM SET EVENTSSQL 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_namechecks whetherRESTRICTED SESSIONis set toTRUEorFALSE. 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_ownerandobject_namemust always be set to%for this kind ofALTER SESSIONorALTER SYSTEMcommand rule.
- 
                              enabledenables 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_namespecifies theSECURITYclause of theALTER SYSTEMSQL statement
- 
                              parameter_namespecifies theRESTRICTED SESSIONparameter from theSECURITYclause
- 
                              scopesets 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 setscopetoDBMS_MACUTL.G_SCOPE_COMMONand 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_RULEprocedure
- 
                                 CREATE_SESSION_EVENT_CMD_RULE Procedure about the DVS.DBMS_MACADM.CREATE_SESSION_EVENT_CMD_RULEprocedure
- 
                                 CREATE_SYSTEM_EVENT_CMD_RULE Procedure for more information about the DBMS_MACADM.CREATE_SYSTEM_EVENT_CMD_RULEprocedure
- 
                                 DBA_DV_COMMAND_RULE View for information about the DBA_DV_COMMAND_RULEdata dictionary view
- 
                                 Oracle Database SQL Language Reference for information about the ALTER SESSIONSQL statement
- 
                                 Oracle Database SQL Language Reference for information about the ALTER SYSTEMSQL statement
Parent topic: Types of Command Rules
6.2 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
6.3 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
6.4 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.
                  6.5 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
6.6 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
6.7 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
6.8 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, userSCOTTmust create a table.
- Step 2: Create a Command Rule
 After the table has been created in theSCOTTschema, you can create a command rule.
- Step 3: Test the Command Rule
 Next, you are ready to test theCREATE TABLElocal 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
6.8.1 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
6.8.2 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 that he was in a moment ago, before you created the CREATE TABLE command rule. 
                        
6.8.3 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, SCOTTis no longer allowed to create tables, even in their own schema.
- Now enable user SCOTTto create tables again.- Connect to the PDB as the user who created the command rule.
- Update the CREATE TABLEcommand 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 SCOTTdoes 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.)
                        
6.8.4 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 TABLEcommand rule.For example: CONNECT c##sec_admin_owen@hrpdb Enter password: password
- Drop the CREATE TABLEcommand rule.Remember that the command,object_owner, andobject_name 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_RULEdata dictionary view.BEGIN DBMS_MACADM.DELETE_COMMAND_RULE( command => 'CREATE TABLE', object_owner => 'SCOTT', object_name => '%'); END; / 
- 
                              If you no longer need the SCOTTaccount to be available, then connect to the PDB as the Database Vault Account Manager and enter the followingALTER USERstatement:CONNECT accts_admin_ace@pdb_name Enter password: password ALTER USER SCOTT ACCOUNT LOCK PASSWORD EXPIRE; 
6.9 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 SELECTstatements from occurring on specific schema objects, then design multiple command rules to stop theSELECTstatements on those specific schema objects, rather than creating a general command rule to preventSELECTstatements in the schema level.
- 
                        When designing rules for the CONNECTevent, 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_ADMINorDV_OWNERrole to log in and correct the rule that is causing the lock-out problem. TheCONNECTcommand rule does not apply to users with theDV_OWNERandDV_ADMINroles. This prevents improperly configuredCONNECTcommand 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. 
- 
                        If you must temporarily relax an enabled command rule for an administrative task, then consider switching the command rule to simulation mode. Note that this will not capture activity that meets the rule set criteria, only activity that would have violated it. 
- 
                        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
6.10 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
6.11 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