The identity virtualization feature, described in Section 7.3, "Configuring the Identity Store Service", requires some additional configuration to support a split profile.
This appendix describes how to create and manage the adapters used for split profiles.
The Identity Virtualization feature enables you to query multiple LDAP directories through OPSS. For example, you can fetch data from both Oracle Internet Directory and Microsoft Active Directory in a single query.
The feature supports a "split profile" file, where an application makes use of attributes for a single identity that are stored on two different sources; for example, where the username, password, and employeeID for a single person are stored on Microsoft Active Directory, and that person's employeeID and business role are stored in Oracle Internet Directory.
For example, when a WebCenter application needs to obtain attributes for a single identity from more than one source directory, it uses the split profile to leverage the join functionality of Identity Virtualization. These joins use a standard join adapter. For details, see:
Understanding Oracle Virtual Directory Adapters in the Oracle Fusion Middleware Administrator's Guide for Oracle Virtual Directory
Understanding the Join View Adapter in the Oracle Fusion Middleware Administrator's Guide for Oracle Virtual Directory
The adapter configuration is stored in adapters.os_xml, but connection details such as host, port and credentials of a back-end directory come from OPSS.
The same user occurs in both identity stores with some attributes in one store and other attributes in the other store. A query on the user record requires data from both stores. The configuration tasks are:
Configure the identity store service with the virtualize property to enable queries against multiple LDAP stores.
For details, see Section 7.3, "Configuring the Identity Store Service."
Connect to the Weblogic Admin server to run commands to configure the join adapter for the identity stores. For information about the available WLST commands, see "Library Oracle Virtual Directory (LibOVD) Commands" in Oracle Fusion Middleware WebLogic Scripting Tool Command Reference.
For details about how to bring up the WLST prompt, see "Getting Started Using Command-Line Tools" in the Oracle Fusion Middleware Administrator's Guide.
For information about the
Create the join adapter in the primary identity store:
createJoinAdapter(adapterName="Join Adapter Name", root="Namespace", primaryAdapter="Primary adapter Name")
Add the join rule to the secondary store(s):
addJoinRule(adapterName="Join Adapter Name", secondary="Secondary Adapter Name", condition="Join Condition")
Note:
If there is more than one secondary identity store, run the addJoinRule command for each secondary store.
Run the modifyLDAPAdapter command:
modifyLDAPAdapter(adapterName="AuthenticatorName", attribute="Visible", value="Internal")
Note:
If there is more than one secondary identity store, run the modifyLDAPAdapter command for each secondary ID store.
In this example the same user occurs in two stores; the first store is Microsoft Active Directory and the second store is Oracle Internet Directory. In the example, we assume that Microsoft Active Directory is the primary store and Oracle Internet Directory is the secondary store.
Note:
When configuring the LDAP connection parameters, the user.create.bases and group.create.bases must correspond to the primary adapter's namespace. For details about the parameters, see Section 7.3.1, "What is Configured?."
cn=users,dc=acme,dc=comcn=users,dc=oid,dc=com
The steps to implement the split profile are as follows:
Create the join adapter:
createJoinAdapter(adapterName="JoinAdapter1", root="dc=acme,dc=com", primaryAdapter="AD")
The adapter name shown here is an example; use an appropriate name in actual usage.
Specify the join rule:
addJoinRule(adapterName="JoinAdapter1", secondary="OID", condition="uid=cn")
"uid=cn" is the join condition in the above example which indicates that if uid value of a user in Oracle Internet Directory (secondary) matches with cn value of the Microsoft Active Directory user (primary), then the attributes are combined.
The attribute on the left side of the condition is the attribute in the secondary adapter and the attribute on the right side is the attribute in the primary adapter.
Modify the adapters:
modifyLDAPAdapter(adapterName="OID", attribute="Visible", value="Internal") modifyLDAPAdapter(adapterName="AD", attribute="Visible", value="Internal")
The adapter names used here are the actual name of the authenticators. The adapter names in all the primary and secondary parameters also refer to the authenticator name. The join adapter name can be any name you choose.
Restart Weblogic Admin and Managed servers.
You use the removeJoinRule command to remove a join rule from a join adapter.
removeJoinRule(adapterName="JoinAdapter1", secondary="OID")
You use the deleteAdapter command to delete a join adapter.
deleteAdapter(adapterName="JoinAdapter1")
You use the modifyLDAPAdapter command to change the visibility of the adapters. For example:
modifyLDAPAdapter(adapterName="AuthenticatorName", attribute="Visible", value="Yes")
Enabling access logging for Identity Virtualization Library allows you to capture all requests and responses flowing through Identity Virtualization Library, which can be very useful if you are trying to triage performance issues.
To enable access logging for Identity Virtualization Library:
Remove any Identity Virtualization Library loggers that were previously configured in Debug mode. You must remove these loggers to see real performance numbers.
Create a WebLogic logger named oracle.ods.virtualization.accesslog in WebLogic Server with NOTIFICATION level.
Create a WebLogic loghandler, specifying a file name similar to ovd-access.log and associate that log handler to the logger you created in step 2.
This loghandler logs all Oracle Virtual Directory access log messages into a separate file.
Create a backup of the DOMAIN_HOME/config/fmwconfig/ovd/default/provider.os_xml file, and then add the following XML fragment (if it is not already present):
<providers ..>
   ...
   <auditLogPublisher>
      <provider name="FMWAuditLogPublisher">
        ...
      </provider>
      <provider name="AccessLogPublisher">
 
<configClass>oracle.ods.virtualization.config.AccessLogPublisherConfig</configClass>
         <properties>
            <property name="enabled" value="true"/>
         </properties>
      </provider>
   </auditLogPublisher>
   ...
</providers>
Restart the WebLogic Server Admin and Managed servers.
Oracle Virtual Library can now generate the access log in the ovd-access.log file.