ofbiz-notifications mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Paul Foxworthy (Jira)" <j...@apache.org>
Subject [jira] [Commented] (OFBIZ-3847) Entity ECAs not triggered correctly when using Delegator.storeAll() method
Date Sat, 01 Feb 2020 01:36:00 GMT

    [ https://issues.apache.org/jira/browse/OFBIZ-3847?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17027926#comment-17027926

Paul Foxworthy commented on OFBIZ-3847:

Thanks [~mbrohl] . Yes, I'm inclined to close this issue again. Gareth did say they had directly
removed rows in Postgres, which might have confused OFBiz. I'll close this if there are no
objections in the near future.

> Entity ECAs not triggered correctly when using Delegator.storeAll() method
> --------------------------------------------------------------------------
>                 Key: OFBIZ-3847
>                 URL: https://issues.apache.org/jira/browse/OFBIZ-3847
>             Project: OFBiz
>          Issue Type: Bug
>          Components: framework
>    Affects Versions: Release Branch 10.04
>            Reporter: Martin Kreidenweis
>            Assignee: Paul Foxworthy
>            Priority: Major
>             Fix For: 17.12.01
>         Attachments: GenericDelegator.java.diff, OFBIZ-3847_Entity-ECAs-not-triggered-correctly.patch,
> The conditions don't work when updating (not creating) entities using the Delegator.storeAll()
method. E.g. the following condition does not work:
> {code}
> <eca entity="Product" operation="create-store" event="return">
>         <condition field-name="autoCreateKeywords" operator="not-equals" value="N"/>
>         <action service="indexProductKeywords" mode="sync" value-attr="productInstance"/>
> </eca>
> {code}
> The indexProductKeywords service is called anyway when the product is updated and the
autoCreateKeywords was "N" and stays "N". It works correctly for newly created products. 
> The problem is in the method GenericDelegator.storeAll(), where unchanged field values
are not passed down to the store() method. The store method calls the ECA engine, which does
not receive the unchanged values at all and thus cannot evaluate the EECA conditions correctly.

This message was sent by Atlassian Jira

View raw message