Data Model
Data model and entity relationships in Flexible Team Share.
Main Data Model
flowchart TB
PARENT["<b>Parent Record</b><br/>(Account, Case, etc.)<br/>βββββββββββ<br/>β’ Id<br/>β’ OwnerId<br/>β’ Name"]
PARENT -->|"Record_Id__c<br/>(Text - composite key)"| OTM
OTM["<b>ObjectTeamMember__c</b><br/>βββββββββββ<br/>β’ Record_Id__c<br/>β’ User_Id__c<br/>β’ Access_Level__c<br/>β’ Role__c<br/>β’ End_Date__c"]
OTM -->|"User_Id__c"| USER
USER["<b>User</b><br/>(Standard Object)<br/>βββββββββββ<br/>β’ Id<br/>β’ Name<br/>β’ Email"]
OTM -->|"Triggers share<br/>record creation"| SHARE
SHARE["<b>[Object]Share</b><br/>(AccountShare, CaseShare, etc.)<br/>βββββββββββ<br/>β’ ParentId<br/>β’ UserOrGroupId<br/>β’ AccessLevel<br/>β’ RowCause = 'Manual'"]
Entity Relationship Diagram
erDiagram
PARENT_RECORD ||--o{ ObjectTeamMember__c : "Record_Id__c"
User ||--o{ ObjectTeamMember__c : "User_Id__c"
ObjectTeamMember__c ||--o| OBJECT_SHARE : "triggers creation"
PARENT_RECORD {
Id Id PK
Id OwnerId
String Name
}
ObjectTeamMember__c {
Id Id PK
Text Record_Id__c FK
Lookup User_Id__c FK
Picklist Access_Level__c
Picklist Role__c
Date End_Date__c
}
User {
Id Id PK
String Name
String Email
}
OBJECT_SHARE {
Id Id PK
Id ParentId FK
Id UserOrGroupId FK
String AccessLevel
String RowCause
}
Custom Objects
ObjectTeamMember__c
Stores team member assignments linking a user to a parent record.
| Field | Type | Description |
|---|---|---|
Record_Id__c | Text | Composite key in format ObjectName:RecordId |
User_Id__c | Lookup(User) | The team member user |
Access_Level__c | Picklist | Read Only, Read/Write |
Role__c | Picklist | Owner, Manager, User |
End_Date__c | Date | Optional expiration date for temporary access |
Team_Sharing_Config__c
Per-object configuration for team sharing.
| Field | Type | Description |
|---|---|---|
Object_Api_Name__c | Text | API name of the configured object |
Object_Label__c | Text | Display label for the object |
Is_Active__c | Checkbox | Whether team sharing is active for this object |
FlexiTeamShare_Config__mdt
App-level configuration stored as Custom Metadata.
| Field | Type | Description |
|---|---|---|
IsActive__c | Checkbox | Master toggle for the app |
Cleanup_Batch_Size__c | Number | Batch size for cleanup jobs |
Enable_Batch_Logging__c | Checkbox | Enable debug logging in batch jobs |
Enable_Expired_Member_Cleanup__c | Checkbox | Enable automatic cleanup of expired members |
Configuration Objects
flowchart LR
MDT["<b>FlexiTeamShare_Config__mdt</b><br/>(Custom Metadata)<br/>βββββββββββ<br/>β’ IsActive__c<br/>β’ Cleanup_Batch_Size__c<br/>β’ Enable_Batch_Logging__c<br/>β’ Enable_Expired_Member_Cleanup__c"]
MDT -->|"Configures behavior"| TSC
TSC["<b>Team_Sharing_Config__c</b><br/>βββββββββββ<br/>β’ Object_Api_Name__c<br/>β’ Object_Label__c<br/>β’ Is_Active__c"]
TSC -->|"Enables object"| PARENT["<b>Parent Objects</b><br/>(Account, Case, etc.)"]
Complete Model Overview
flowchart TB
PARENT["Parent Record<br/>(Account, Case, etc.)"]
USER["User"]
OTM["ObjectTeamMember__c"]
SHARE["[Object]Share"]
TSC["Team_Sharing_Config__c"]
MDT["FlexiTeamShare_Config__mdt"]
PARENT --> OTM
USER --> OTM
OTM --> SHARE
MDT --> TSC
TSC --> PARENT