<policyRule>
    <name>recompute-user-on-change-partner-status</name>
    <policyConstraints>
        <modification/>
    </policyConstraints>
    <policyActions>
        <scriptExecution>
            <object>
                <linkSource>
                    <type>UserType</type>
                </linkSource>
            </object>
            <executeScript>
                <s:recompute>
                    <s:triggered>
                        <safetyMargin>PT1M</safetyMargin>
                        <fireAfter>PT5M</fireAfter>
                    </s:triggered>
                </s:recompute>
            </executeScript>
        </scriptExecution>
    </policyActions>
</policyRule>Policy Rules Examples
| Since 4.9This functionality is available since version 4.9. | 
This page lists practical policy rule examples, and supplements the examples shown in Policy Configuration.
Recompute Users After Org Change
The following example triggers recomputation of all users in an org when there is a change in the org.
Recompute Users After User Change
The following example triggers recomputation when a user is modified.
<policyRule>
    <name>recompute-user-on-change</name>
    <policyConstraints>
        <modification>
            <operation>modify</operation>
        </modification>
    </policyConstraints>
    <policyActions>
        <scriptExecution>
            <object>
                <currentObject/>
            </object>
            <executeScript>
                <s:recompute>
                    <s:triggered>
                        <safetyMargin>PT1M</safetyMargin>
                        <fireAfter>PT5M</fireAfter>
                    </s:triggered>
                </s:recompute>
            </executeScript>
        </scriptExecution>
    </policyActions>
</policyRule>Limiting the Number of Users
The following policy rule limits the number of users of a licensed resource to 5:
<policyRule>
    <name>Limit number of assigned licenses</name>
    <policyConstraints>
        <maxAssignees>
            <multiplicity>5</multiplicity>
        </maxAssignees>
    </policyConstraints>
    <policyActions>
        <enforcement/>
    </policyActions>
</policyRule>Prevent Role Assignment
In this example, we are preventing users from being assigned to a role if either of the following is true:
- 
They already have a forwarding email address set, i.e. forwardEmailAddressis not null.
- 
They are already assigned a role named perm.m365license.allorperm.m365license.exchange.
This only applies to users who do not have the 4eb82ce9-cf90-4e8d-ab53-121bb676c756 archetype.
If the policy is violated, the assignment is blocked, and a message is shown.
<assignment>
    <policyRule>
        <name>excluded-role</name>
        <policyConstraints>
            <name>excluded-role-constraint</name>
            <or>
                <objectState>
                    <name>fwEmailValidation</name>
                    <expression>
                        <script>
                            <code>
                                boolean returnValue = false
                                if (basic.getExtensionPropertyValue(user, "http://example.org/midpoint", "forwardEmailAddress") != null) {
                                    returnValue = true
                                }
                                return returnValue
                            </code>
                        </script>
                    </expression>
                </objectState>
                <exclusion>
                    <targetRef type="RoleType">
                        <filter>
                            <q:text>name = 'perm.m365license.all' or name = 'perm.m365license.exchange'</q:text>
                        </filter>
                        <resolutionTime>run</resolutionTime>
                    </targetRef>
                    <presentation>
                        <message>
                            <fallbackMessage>Violation: perm.m365license roles are assigned for active users, could not be assigned for this user.</fallbackMessage>
                        </message>
                    </presentation>
                </exclusion>
            </or>
        </policyConstraints>
        <evaluationTarget>assignment</evaluationTarget>
        <policyActions>
            <enforcement/>
        </policyActions>
    </policyRule>
    <condition>
        <expression>
            <script>
                <code>
                    boolean returnValue = false
                    if(focus!=null){
                        returnValue = !midpoint.hasArchetype(focus, "4eb82ce9-cf90-4e8d-ab53-121bb676c756")
                    }
                    return returnValue
                </code>
            </script>
        </expression>
    </condition>
</assignment>The following example shows a global policy rule that excludes roles assigned to users based on the forwardEmailAddress attribute null check.
<globalPolicyRule>
    <name>Global policy rule for exclude roles</name>
    <policyConstraints>
        <and>
            <hasAssignment>
                <targetRef relation="org:default" type="c:RoleType">
                    <filter>
                        <q:text>name = 'accessRole1' or name = 'accessRole2'</q:text>
                    </filter>
                    <resolutionTime>run</resolutionTime>
                </targetRef>
            </hasAssignment>
            <modification>
                <operation>modify</operation>
            </modification>
        </and>
    </policyConstraints>
    <policyActions>
        <scriptExecution>
            <object>
                <currentObject/>
            </object>
            <executeScript xmlns:s="http://midpoint.evolveum.com/xml/ns/public/model/scripting-3">
                <s:unassign>
                    <s:filter>
                        <q:text>targetRef = ```
                            import com.evolveum.midpoint.schema.util.ObjectTypeUtil
                            import com.evolveum.midpoint.xml.ns._public.common.common_3.RoleType
                            ObjectTypeUtil.createObjectRef(midpoint.searchObjectByName(RoleType,"accessRole1").getOid())
                            ```
                            or targetRef = ```
                            import com.evolveum.midpoint.schema.util.ObjectTypeUtil
                            import com.evolveum.midpoint.xml.ns._public.common.common_3.RoleType
                            ObjectTypeUtil.createObjectRef(midpoint.searchObjectByName(RoleType,"accessRole2").getOid())
                            ```
                        </q:text>
                    </s:filter>
                </s:unassign>
            </executeScript>
        </scriptExecution>
    </policyActions>
    <focusSelector>
        <type>UserType</type>
        <archetypeRef oid="00000000-0000-0000-0000-000000000702" relation="org:default" type="c:ArchetypeType"/>
    </focusSelector>
    <condition>
        <source>
            <path>extension/myAttribute</path>
        </source>
        <expression>
            <script>
                <code>
                    return myAttribute!=null
                </code>
            </script>
        </expression>
    </condition>
<globalPolicyRule>