Work with Mail policy definitions

When staging policies from a development server to a production server, use the XML configuration interface to work with a policy definition that has at least three levels of specialization. Then you can experiment with exporting and updating one or more policy levels and deleting any level of the policy definition by specifying the Path parameter. Use these examples that relate to the policy definition for the common Mail application as an illustration of how to use xmlaccess.sh when working with policy definitions for other portal resources.

Before you begin, consider the following requirements for using Policy parameters:

Before you run the XML configuration interface, create a hierarchy of Mail policies using the Resource Policies portlet. From the Administration menu, expand the Access section and click Resource Policies to display the Policy Types. Refine the main Mail policy by creating three levels of child policies. The examples used in the following procedure refer to USAMailChild1, USAMailChild11, and USAMailChild111.

When exporting, importing, and deleting Mail policies, refer to the following samples, which illustrate both the original commands and the new commands that are supported in this version of the product:

  1. Use the following XML to create a policy node Child1 which is of type Mail:

      <?xml version="1.0" encoding="UTF-8"?>
      <!-- 1  [policy-node: path= /Mail/child1] -->
      <request build="wpnext_058_01" type="update" version="7.0.0.0" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
            xsi:noNamespaceSchemaLocation="PortalConfig_7.0.0.xsd">
         <portal action="locate">
            <policy-node action="update" path="/Mail/child1">
               <parameter name="Description" type="string" update="set">
               <! [CDATA [Updated Policy manager for the IBM Common Child1 Mail Portlet]]></parameter>
               <parameter name="DescriptionLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="Editor" type="string" update="set">
               <! [CDATA [ibm.portal.PolicyEditorCPP]]></parameter>
               <parameter name="EditorLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="NameResKey" type="string" update="set">
               <! [CDATA [ManagerResKey]]></parameter>
               <parameter name="NameResKeyLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="Path" type="string" update="set">
               <! [CDATA [./child1]]></parameter>
               <parameter name="PathLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="PathType" type="string" update="set">
               <! [CDATA [/Mail]]></parameter>
               <parameter name="PathTypeLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="PznRule" type="string" update="set"/>
               <parameter name="PznRuleLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="PznType" type="string" update="set">
               <! [CDATA [child1]]></parameter>
               <parameter name="PznTypeLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="ReceiveAttachment" type="string" update="set">
               <! [CDATA [true]]></parameter>
               <parameter name="ReceiveAttachmentLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="Remote" type="string" update="set">
               <! [CDATA [Remote Manager]]></parameter>
               <parameter name="RemoteLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="SaveMessages" type="string" update="set">
               <! [CDATA [true]]></parameter>
               <parameter name="SaveMessagesLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="SendAttachment" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="SendAttachmentLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="Title" type="string" update="set">
               <! [CDATA [Child Mail Title]]></parameter>
               <parameter name="TitleLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <parameter name="Type" type="string" update="set">
               <! [CDATA [mail]]></parameter>
               <parameter name="TypeLock" type="string" update="set">
               <! [CDATA [false]]></parameter>
               <access-control externalized="false" owner="uid=wpsadmin,
               o=defaultwimfilebasedrealm" private="false"/>
            </policy-node>
         </portal>
         <status element="all" result="ok"/>
      </request>

  2. Review the policy definition to see the key attributes and values of the main (root) policy, its child policies, and the lower-level specializations of child policies. For example, a policy definition might contain two peer policies, USAMailChild1 and JAPANMailChild1. The policy USAMailChild1 might be refined by USAMailChild11, which might be refined further by USAMailChild111. If the policy JAPANMailChild1 is not specialized; it has no child policies.

  3. Modify the main policy definition or any level of child policy definition by editing the attribute values as needed.

  4. Use Personalization to create and associate a policy rule for each child policy in the hierarchy of Mail.xml on the source development server and on the target production server.

  5. Use Personalization to create and associate a policy condition for each policy rule on the source development server and on the target production server.

      Steps 4 and 5 are important because the XML configuration interface for policies does not process policy rules and their conditional expressions. The policy rule attribute (PznRule) value in a policy definition is the UUID referring to the associated rule and not the rule itself. Using Personalization explicitly create and associate policy rules (PznRule) and policy conditions (PznType) for the policy definitions that you export, update, or delete using the XML configuration interface.

  6. Use the XML configuration interface update command to import the Mail policy definition for the entire Mail node of the policy branch of the content repository.

      In the following example, the policy Type is specified as Mail and the Mail policy definition is imported from the file Mail.xml:

       
      <!-- ACTION: create or update the whole Policy -->
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="update"
            xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      	<portal action="locate">
      		<policy-node action="update" label="Mail" type="Mail">
      			<url>file:///D:/Mail/Mail.xml</url>
      		</policy-node>
      	</portal>
      </request>

  7. Use the XML configuration interface update command to import one or more levels of child policies.

      The following example illustrates an update of the child policy USAMailChild1. This update action imports USAMailChild1 and the child policies USAMailChild11 and USAMailChild111. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild1 policy uses, namely ./USA.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <!-- ACTION: create or update first-level child Policy -->
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="update"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      	<portal action="locate">
      		<policy-node action="update" label="Mail" type="Mail"
                  path="./USA">
      			<url>file:///d:/Mail/USAMailChild11.xml</url>
      		</policy-node>
      	</portal>
      </request>

      The following example illustrates an update of the child policy USAMailChild11. This update action imports USAMailChild11 and the child policy USAMailChild111. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild11 policy uses, namely ./USA/USAManager.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="update"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      	<portal action="locate">
      		<policy-node action="update" label="Mail" type="Mail"
                  path="./USA/USAManager">
      			<url>file:///d:/Mail/USAMailChild111.xml</url>
      		</policy-node>
      	</portal>
      </request>

  8. Use the XML configuration interface export command to export one or more levels of the policy hierarchy.

      The following example illustrates exporting the child policy USAMailChild11 and its child policy USAMailChild111. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild11 policy uses, namely ./USA/USAManager.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd" 
      	type="export" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      	<portal action="locate">
      		<policy-node action="export" label="Mail" type="Mail"
                   path="./USA/USAManager">  
      			<url>file:///d:/Mail/USAMailChild11.xml</url>
      		</policy-node>
      	</portal>
      </request>

      The following example illustrates exporting the child policy USAMailChild111. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild111 policy uses, namely ./USA/USAManager/USALocalityName.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="export"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      	<portal action="locate">
      		<policy-node action="export" label="Mail" type="Mail"
                  path="./USA/USAManager/USALocalityName">
      			<url>file:///d:/Mail/USAMailChild111.xml</url>
      		</policy-node>
      	</portal>
      </request>

  9. Use the XML configuration interface delete command to delete one or more levels of the policy hierarchy.

      The delete command acts on the policy level you have specified and all levels under it. The following example illustrates the deletion of the child policy USAMailChild11 and its child policy USAMailChild111. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild11 policy uses, namely ./USA/USAManager.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="update"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      <portal action="locate">
      <policy-node action="delete" type="Mail" path="./USA/USAManager">
      </policy-node>
      </portal>
      </request>

      The following example illustrates the deletion of the child policy USAMailChild111 only. Note that the Path value is the location in the content repository of the policy condition that the USAMailChild111 policy uses, namely ./USA/USAManager/USALocalityName.

      <?xml version="1.0" encoding="UTF-8" ?> 
      <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd"
         type="update"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
      <portal action="locate">
      <policy-node action="delete" type="Mail"
         path="./USA/USAManager/USALocalityName">
      </policy-node>
      </portal>
      </request>

  10. As an alternative to the examples in the previous steps, you can update a root mail policy, as well as a child policy, using standard XML format.

    1. Create the mail policy or mail child policy node specifying the Path attribute and parameters. The URL parameter that specifies a file is not needed.

        <?xml version="1.0" encoding="UTF-8"?> 
        <!-- 1  [policy-node: path= /Mail/child1] --> 
        <request build="wpnext_058_01" type="update" version="7.0.0.0" 
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
          xsi:noNamespaceSchemaLocation="PortalConfig_7.0.0.xsd"> 
          <portal action="locate"> 
            <policy-node action="update" path="/Mail/child1"> 
              <parameter name="Description" type="string" update="set">
              <! [CDATA [Updated Policy manager for the IBM Common Child1 Mail Portlet]]></parameter> 
              <parameter name="DescriptionLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="Editor" type="string" update="set">
              <! [CDATA [ibm.portal.PolicyEditorCPP]]></parameter> 
              <parameter name="EditorLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="NameResKey" type="string" update="set">
              <! [CDATA [ManagerResKey]]></parameter> 
              <parameter name="NameResKeyLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="Path" type="string" update="set">
              <! [CDATA [./child1]]></parameter> 
              <parameter name="PathLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="PathType" type="string" update="set">
              <! [CDATA [/Mail]]></parameter> 
              <parameter name="PathTypeLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="PznRule" type="string" update="set"/> 
              <parameter name="PznRuleLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="PznType" type="string" update="set">
              <! [CDATA [child1]]></parameter> 
              <parameter name="PznTypeLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="ReceiveAttachment" type="string" update="set">
              <! [CDATA [true]]></parameter> 
              <parameter name="ReceiveAttachmentLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="Remote" type="string" update="set">
              <! [CDATA [Remote Manager]]></parameter> 
              <parameter name="RemoteLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="SaveMessages" type="string" update="set">
              <! [CDATA [true]]></parameter> 
              <parameter name="SaveMessagesLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="SendAttachment" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="SendAttachmentLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="Title" type="string" update="set">
              <! [CDATA [Child Mail Title]]></parameter> 
              <parameter name="TitleLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <parameter name="Type" type="string" update="set">
              <! [CDATA [mail]]></parameter> 
              <parameter name="TypeLock" type="string" update="set">
              <! [CDATA [false]]></parameter> 
              <access-control externalized="false" owner="uid=wpsadmin,o=defaultwimfilebasedrealm" private="false"/> 
            </policy-node> 
            </portal> 
            <status element="all" result="ok"/> 
        </request> 

    2. Update a child policy named USAMailChild1 by specifying Path=/Mail/USAMailChild1:

        <?xml version="1.0" encoding="UTF-8"?>
        <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd" create-oids="true"
                type="update" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" domain="jcr" >
          <portal action="locate">
             <policy-node action="update" path="/Mail/USAMailChild1">
                <parameter update="set" name="SendAttachment" type="string">false</parameter>
                <parameter update="set" name="SendAttachmentLock" type="string">false</parameter>
                <parameter update="set" name="Title" type="string">USAMailChild1</parameter>
                <parameter update="set" name="Description" type="string">USAMailChild1 Description</parameter>
             </policy-node> 
          </portal>
        </request>

    3. Delete a child policy named USAMailChild1:

        <?xml version="1.0" encoding="UTF-8"?>
        <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd" create-oids="true"
                type="update" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" domain="jcr" >
            <portal action="locate">
                <policy-node action="delete" path="/Mail/USAMailChild1"/>
            </portal>
        </request>

    4. Export a child policy named USAMailChild1:

        <?xml version="1.0" encoding="UTF-8"?>
        <request xsi:noNamespaceSchemaLocation="PortalConfig_1.4.xsd" create-oids="true"
                type="export" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" domain="jcr" >
            <portal action="locate">
                <policy-node action="export" path="/Mail/USAMailChild1"/>
            </portal>
        </request>


Parent

Manage portal resources with policies
Policy principles
Mail policy attributes

 


+

Search Tips   |   Advanced Search