Migrating Oracle groups
The following sections outline the procedures for migrating static groups to both Ping Identity static groups and virtual static groups as well as how to migrate dynamic groups.
You can migrate Oracle static and dynamic groups to PingDirectory server groups. For more information about the differences in access control evaluation between Oracle and the PingDirectoryserver, see Migrating ACIs from Oracle to the PingDirectory server.
Migrating static groups
About this task
PingDirectory server supports static LDAP groups with structural object classes of groupOfNames, groupOfUniqueNames, or groupOfEntries. In general, you can import static groups without modification.
You can enable a First-In, First-Out (FIFO) entry cache to cache group-to-user mappings, which improves performance when accessing large entries at the expense of greater memory consumption. PingDirectory server provides an out-of-the-box FIFO entry cache object for this purpose. You must enable this object using dsconfig as described in Using the entry cache to improve the performance of large static groups.
To migrate static groups:
Steps
- 
To enumerate any schema differences between the DSEE deployment and the Ping Identity deployment, use the migrate-ldap-schematool.
- 
To enumerate any configuration differences between the DSEE deployment and the Ping Identity deployment, use the migrate-sun-ds-configtool.
- 
Import or configure any necessary schema or configuration changes recorded by the tools in steps 1 and 2. 
- 
Import the existing users and groups using the import-ldiftool.
- 
From the PingDirectory server root directory, open the docs/sun-ds-compatibility.dsconfigfile using a text editor.
- 
Go to the FIFO Entry Cache section. - 
Read the accompanying comments. 
- 
To enable the corresponding dsconfigcommand, delete the comment character ("#").Example:$ bin/dsconfig set-entry-cache-prop \ --cache-name "Static Group Entry Cache" --set enabled:true
 
- 
- 
To ensure that references to an entry are updated automatically when the entry is deleted or renamed, enable the Referential Integrity plugin. Example:$ bin/dsconfig set-plugin-prop --plugin-name "Referential Integrity" --set enabled:true
Next steps
If the PingDirectory server is part of a replication topology, enable the Referential Integrity plugin for each replica.
Migrating static groups to virtual static groups
About this task
In many cases, using virtual static groups in place of static groups can produce marked performance gains without having to update client applications. Migrating to virtual static groups varies depending on the original directory information tree (DIT), but the general approach involves identifying common membership traits for all members of each group and then expressing those traits in the form of an LDAP URL.
For this task, consider the following:
- 
The common membership trait for all members of the All Usersgroup is the parent distinguish name (DN)ou=People,dc=example,dc=com.
- 
In other cases, a common attribute might need to be used. For example, groups based on the location of its members could use the llocation orststate attribute.
- 
The common case of an All Usersgroup, which contains all entries under the parent DNou=People,dc=example,dc=com.
- 
When implemented as a virtual static group, this group can have a large membership set without incurring the overhead of a static group. 
To migrate Oracle Directory Server Enterprise Edition static groups to virtual static groups:
Steps
- 
Create a dynamic group. Example:dn: cn=Dynamic All Users,ou=Groups,dc=example,dc=com objectClass: top objectClass: groupOfURLs cn: Dynamic All Users memberURL: ldap:///ou=People,dc=example,dc=com??sub?(objectClass=person) 
- 
Create a virtual static group that references the dynamic group. Example:dn: cn=All Users,ou=Groups,dc=example,dc=com objectClass: top objectClass: groupOfUniqueNames objectClass: ds-virtual-static-group cn: All Users ds-target-group-dn: cn=Dynamic All Users,ou=Groups,dc=example,dc=com 
- 
To populate the All Usersgroup withuniqueMembervirtual attributes, enable theVirtual Static uniqueMembervirtual attribute.Example:$ bin/dsconfig set-virtual-attribute-prop --name "Virtual Static uniqueMember" \ --set enabled:true
- 
To confirm that the virtual static group is correctly configured, check a user’s membership in the group. Example:$ bin/ldapsearch --baseDN "cn=All Users,ou=Groups,dc=example,dc=com" \ --searchScope base "(uniqueMember=uid=user.0,ou=People,dc=example,dc=com)" 1.1Result:dn: cn=All Users,ou=Groups,dc=example,dc=com 
- 
If a client application requires it, enable the ability to list all members of a virtual static group. By default, this feature is disabled. Example:$ bin/dsconfig set-virtual-attribute-prop --name "Virtual Static uniqueMember" \ --set allow-retrieving-membership: trueYou can implement the virtual static group using the groupOfNamesobject class instead ofgroupOfUniqueNames. To do this, update theVirtual Static memberconfiguration object instead of theVirtual Static uniqueMemberconfiguration object.
Migrating dynamic groups
About this task
The PingDirectory server supports dynamic groups with the groupofURLs object class. In general, you can import dynamic groups without modification.
To migrate dynamic groups:
Steps
- 
To enumerate any schema differences between the Oracle Directory Server Enterprise Edition (DSEE) deployment and the Ping Identity deployment, run the migrate-ldap-schematool.
- 
To enumerate any configuration differences between the DSEE deployment and the Ping Identitiy deployment, run the migrate-sun-ds-configtool.
- 
Import or configure any necessary schema and configuration changes recorded by the tools used in steps 1 and 2. 
- 
Import the existing users and groups using the import-ldiftool.