Express (Distributed operating systems), v8.0 > Secure applications and their environment > Authenticate users > Select a registry or repository > Manage realms in a federated repository > Virtual member manager > Develop with virtual member manager > Extend virtual member manager functionality in the application > Static model schema loading process
Static model: creating new entities and properties at deployment time
Virtual member manager is configured to use static model. We can create new entity types and their associated new property types at deployment time.
About this task
You need to add new entity types and their associated new property types. The schemas of the new entity types and property types can only be a custom extension XSD file (for example, wimextension.xsd). In the following example to create a new entity type ContactPerson and add a new property type cellPhone to this entity type.
Procedure
- Stop the virtual member manager service.
- Open the wimextension.xsd file under the VMM_HOME\model directory. If this file does not exist, create a new one with the same or a different name.
VMM_HOME is the directory where the virtual member manager files are located. This location is set to either the system property wim.home or user.install.root/config/cells/local.cell/wim.
- Edit the wimextension.xsd and add the definitions of the new entity types and property types. Make sure the XSD file is well-formed. Use a different namespace URI than the virtual member manager namespace URI: (//www.ibm.com/websphere/wim). Ensure that the XSD file is well-formed. Use a different namespace URI than the virtual member manager namespace URI: (//www.ibm.com/websphere/wim).
<?xml version="1.0" encoding="UTF-8"?> <xsd:schema targetNamespace="//www.ibm.com/websphere/wim/ext" xmlns:xsd="//publib.boulder.ibm.com/infocenter/wasinfo/v8r0/index.jsp?topic=/ ://www.w3.org/2001/XMLSchema" xmlns:ecore="//publib.boulder.ibm.com/infocenter/wasinfo/v8r0/index.jsp?topic=/ ://www.eclipse.org/emf/2002/Ecore" xmlns:wimext="//www.ibm.com/websphere/wim/ext" ecore:package="com.ibm.websphere.wim.model.ext" xmlns:wim="//www.ibm.com/websphere/wim"> <xsd:import schemaLocation="wimdatagraph.xsd" namespace="//www.ibm.com/websphere/wim"/> <!-- Custom properties --> <xsd:element name="cellPhone" type="xsd:string"/> <!-- Custom entities --> <xsd:complexType name="ContactPerson"> <xsd:complexContent> <xsd:extension base="wim:PersonAccount"> <xsd:sequence> <xsd:element maxOccurs="1" minOccurs="0" ref="wimext:cellPhone"/> </xsd:sequence> </xsd:extension> </xsd:complexContent> </xsd:complexType> </xsd:schema>- Regenerate static model packages based on the updated XSD files and deploy the jar files under class path.
- Manually add the new entity types to the virtual member manager configuration file (wimconfig.xml).
<config:supportedEntityTypes defaultParent="cn=users,dc=yourco,dc=com" name="wimext:ContactPerson"> <config:rdnProperties>uid </config:rdnProperties> </config:supportedEntityTypes> <config:repositories xsi:type="config:LdapRepositoryType"...> <config:EntityTypesNotAllowDelete>wimext:ContactPerson </config:EntityTypesNotAllowDelete> <config:ldapEntityTypes name="wimext:ContactPerson"> <config:rdnAttributes name="uid"/> <config:objectClasses>eContactPerson </config:objectClasses> <config:objectClassesForCreate>eContactPerson </config:objectClassesForCreate> <config:objectClassesForCreate>inetOrgPerson </config:objectClassesForCreate> </config:ldapEntityTypes> </config:repositories>- Manually add the new property types to each repository adapter.
- LDAP adapter
- Add the mapping of the new property types to LDAP attributes to the wimconfig.xml configuration file.
- DB adapter
- Add the definition of the new property types to the property XML file of DB Adapter (wimDBProperties.xml) and run DB property loader.
- Restart the virtual member manager service.
Parent topic: Static model schema loading process