Programmatic Sharing Flashcards

1
Q

What behavior does the force.com platform perform as it relates to manual sharing records, when ownership changes?

A

when the owner of a record is changed, the platform deletes all the manual shares associated with the record. In effect, it “clean sthe slate” for the new owner and let them decide whether they want to share it to anybody. And if you have been writing code that shares the record, your shares will get deleted, too, because they have the same ‘manual’ row cause—the platform cannot distinguish between a sharing row you created and a sharing row created through the UI.

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

What Mechanisms does a developer have to prevent force.com from removing manual sharing records? what are the limitations?

A
  • Apex Sharing Reasons, they are a custom rowCause value. The platform will no longer ignore them when ownership changes.
  • Custom objects only (no custom sharing reasons for std objects)
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

What strategies can I employ to prevent ownership changes from removing manual sharing on std objects?

A
  1. External Assignment Engine: Use an outbound message & workflow to detect ownership change and trigger (not sfdc trigger) an external system to act as appropriate
    1. SFDC Trigger: leverage an after update trigger to send a service call to the external assignment engine
  2. Shadow Table: when the logic is simple enough to handle it all on SFDC in a custom object. Detect ownership change in an after update trigger then compare those records to any present in the shadow table and recreate records required.
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q
A
How well did you know this?
1
Not at all
2
3
4
5
Perfectly