[midPoint] Override default approval policy
Jussi Jokela
jussi.jokela92 at gmail.com
Thu Feb 27 13:48:40 CET 2025
Hello again,
Seems like the code snippets were badly formatted in my previous
message, here they are again and hopefully more readable, as I wish
someone could help me with this:
<displayName>Metarole: High risk systems</displayName>
<inducement id="1">
<policyRule>
<policyConstraints>
<assignment>
<operation>add</operation>
</assignment>
</policyConstraints>
<policyActions>
<approval id="3">
<compositionStrategy>
<order>5</order>
<mergeOverwriting>true</mergeOverwriting>
</compositionStrategy>
<approvalSchema>
<stage id="4">
<name>Security</name>
<approverRef relation="org:default"
type="c:OrgType">
<filter>
<q:text>name="High_risk_systems"</q:text>
</filter>
<resolutionTime>run</resolutionTime>
</approverRef>
<evaluationStrategy>allMustApprove</evaluationStrategy>
<outcomeIfNoApprovers>reject</outcomeIfNoApprovers>
<groupExpansion>onWorkItemCreation</groupExpansion>
</stage>
</approvalSchema>
</approval>
</policyActions>
</policyRule>
</inducement>
<displayName>Default approver</displayName>
<inducement id="1">
<policyRule>
<policyConstraints>
<assignment>
<operation>add</operation>
</assignment>
</policyConstraints>
<policyActions>
<approval id="16">
<compositionStrategy>
<order>50</order>
</compositionStrategy>
<approvalSchema>
<stage id="17">
<name>Default approver</name>
<approverRef relation="org:default"
type="c:OrgType">
<filter>
<q:text>name="Default approver"</q:text>
</filter>
<resolutionTime>run</resolutionTime>
</approverRef>
<evaluationStrategy>firstDecides</evaluationStrategy>
<outcomeIfNoApprovers>reject</outcomeIfNoApprovers>
<groupExpansion>onWorkItemCreation</groupExpansion>
</stage>
</approvalSchema>
</approval>
</policyActions>
</policyRule>
</inducement>
<inducement id="59">
<targetRef oid="7c1a3009-b456-40e6-a160-be32f70c1c7c" (default
approver) relation="org:default" type="c:RoleType"/>
</inducement>
Br,
Jussi
ke 26.2.2025 klo 15.27 Jussi Jokela (jussi.jokela92 at gmail.com) kirjoitti:
>
>
> I'm having difficulties overriding my "default approver" policy. I have two metaroles, one for default approver and one for "high risk systems" (for example) and
> and the default approver is inherited from another metarole which is used when creating new roles and the high risk metarole is assigned when the created role requires it.
>
> The high risk metarole has the <mergeOverwriting>true</mergeOverwriting> but it does not seem to have effect. When the default approver and high risk system metaroles are induced to
> created role, both policy stages require manual approval when the desired outcome is just to approve the high risk system (all must approve) as it has lower order (higher priority).
>
> Here are the code snippets for both policy metaroles and the metarole that includes the default approver policy:
>
> <displayName>Metarole: High risk systems</displayName>
> <inducement id="1">
> <policyRule>
> <policyConstraints>
> <assignment>
> <operation>add</operation>
> </assignment>
> </policyConstraints>
> <policyActions>
> <approval id="3">
> <compositionStrategy>
> <order>5</order>
> <mergeOverwriting>true</mergeOverwriting>
> </compositionStrategy>
> <approvalSchema>
> <stage id="4">
> <name>Security</name>
> <approverRef relation="org:default" type="c:OrgType">
> <filter>
> <q:text>name="High_risk_systems"</q:text>
> </filter>
> <resolutionTime>run</resolutionTime>
> </approverRef>
> <evaluationStrategy>allMustApprove</evaluationStrategy>
> <outcomeIfNoApprovers>reject</outcomeIfNoApprovers>
> <groupExpansion>onWorkItemCreation</groupExpansion>
> </stage>
> </approvalSchema>
> </approval>
> </policyActions>
> </policyRule>
> </inducement>
>
> <displayName>Default approver</displayName>
> <inducement id="1">
> <policyRule>
> <policyConstraints>
> <assignment>
> <operation>add</operation>
> </assignment>
> </policyConstraints>
> <policyActions>
> <approval id="16">
> <compositionStrategy>
> <order>50</order>
> </compositionStrategy>
> <approvalSchema>
> <stage id="17">
> <name>Default approver</name>
> <approverRef relation="org:default" type="c:OrgType">
> <filter>
> <q:text>name="Default approver"</q:text>
> </filter>
> <resolutionTime>run</resolutionTime>
> </approverRef>
> <evaluationStrategy>firstDecides</evaluationStrategy>
> <outcomeIfNoApprovers>reject</outcomeIfNoApprovers>
> <groupExpansion>onWorkItemCreation</groupExpansion>
> </stage>
> </approvalSchema>
> </approval>
> </policyActions>
> </policyRule>
> </inducement>
>
> <inducement id="59">
> <targetRef oid="7c1a3009-b456-40e6-a160-be32f70c1c7c" (default approver) relation="org:default" type="c:RoleType"/>
> </inducement>
>
>
> Hope my goal is clear. :)
>
>
> Best regards,
> Jussi
More information about the midPoint
mailing list