Hi Mikael,
using pullUtils to get internal matches (if found) is exactly the best-practice for preprocess() to get internal data, congrats :-)

Regards.

On 07/12/2017 09:10, Mikael Ekblom wrote:

Hi,

Thank you for the answer. Yes, I found the SyndDeltaBuilder when I was looking around. The thing was more ,that I needed the current internal entity information together with the syncdelta due to the fact that the contents of the syncdelta (in our case )should be determined by the roles currently assigned to the user at the time we retrieve the SyncDelta through the connector. In that sense, the 2.0.6 version was more straightforward or maybe easier to use, but I do see your point here…J

Anyhow, I decided to use the pullutil to get the current user that matched the syncdelta uid to get the currently assigned roles and it seems to work.  I then just as you said rebuilt the syncdelta accordingly via the SyncDeltaBuilder.

Regards,

Mikael

*Mikael Ekblom *

System developer

Arcada, IT

Jan-Magnus Janssons plats 1,

FIN-00560 Helsingfors,

Finland

TFn: +358 207 699 467

Mobil: +358 207 699 467

*From:*Francesco Chicchiriccò [mailto:[email protected]]
*Sent:* tiistai 5. joulukuuta 2017 10.08
*To:* [email protected]
*Subject:* Re: Question regarding upcoming PullAction changes in version 2.0.7

Hi Mikael,
the SyncDelta processing was modified by SYNCOPE-1234 [1].

The new preprocess() method is invoked before any other method of the provided implementation, giving clear chance to alter the data coming from underlying resource prior to any other Syncope-side consideration.

Before [1] the logic was not adequate as the internal matching logic [3] could not be influenced by PullActions.

You have already discovered that SyncDelta instances are immutable; what you are currently missing is that you can use SyncDeltaBuilder [4] to generate new SyncDelta instances.

HTH
Regards.

[1] https://issues.apache.org/jira/browse/SYNCOPE-1234
[2] https://github.com/apache/syncope/blob/2_0_X/core/provisioning-api/src/main/java/org/apache/syncope/core/provisioning/api/pushpull/PullActions.java#L40 [3] https://github.com/apache/syncope/blob/2_0_X/core/provisioning-java/src/main/java/org/apache/syncope/core/provisioning/java/pushpull/AbstractPullResultHandler.java#L741 [4] http://connid.tirasa.net/apidocs/1.4/org/identityconnectors/framework/common/objects/SyncDeltaBuilder.html

On 04/12/2017 16:40, Mikael Ekblom wrote:

    Hi,

    I have one question: in version 2.0.7 I have noticed that you have
    added a preprocess function to the default pull actions class. We
    would like to alter the syncdelta in certain cases ie the user
    should be kept as enabled (ie. __ENABLED__ set to true) as the
    user can have two different roles simultaneously and one primary
    role should be kept even though if the user is seen to have lost
    one primary role in the case that the user (as an example) has
    graduated and has been archived within the study register
    (__ENABLED__ set to false within the connector in this case) + we
    get a match for the user and this archive. We get a match, but the
    user should be set to active.

    Arcada do not deprovision the users directly either if an entity
    matches an archived version for a specific master source.

    The user might still have a role as staff or employee and the
    syncdelta should be set to __ENABLE__=true in this particular case
    but the rest of the roles bound to the student role should be
    removed.

    This could be done in 2.0.6 within the beforeupdate function also,
    that in version 2.0.6 returned the SyncDelta but in version 2.0.7
    the same function returns void. How is this supposed to work in
    the new implementation in 2.0.7 when you do not have the  user
    information (or entity together with role information) available
    directly within the current function and syncdelta scope within
    preprocess? The SyncDelta object just has an read-only map of the
    current syncdelta attributes as far as I have seen if you try to
    alter the attributes within beforeupdate, so it seems to be too
    late for that there.  You basically have to look up the user
    through the __UID__ I guess within preprocess, but through which
    function and through which library?  What is the best option you
    have in this case?

    It is enough if you have a hint to give and I’ll find the rest. I
    hope this text is somehow understandable!

    Regards,

             Mikael

--
Francesco Chicchiriccò
Tirasa - Open Source Excellence
http://www.tirasa.net/
Member at The Apache Software Foundation
Syncope, Cocoon, Olingo, CXF, OpenJPA, PonyMail
http://home.apache.org/~ilgrosso/ <http://home.apache.org/%7Eilgrosso/>


--
Francesco Chicchiriccò

Tirasa - Open Source Excellence
http://www.tirasa.net/

Member at The Apache Software Foundation
Syncope, Cocoon, Olingo, CXF, OpenJPA, PonyMail
http://home.apache.org/~ilgrosso/

Reply via email to