Data method is an interface that the developer platform provides to enable your app to retrieve product data (in the form of JSON payloads).
When an app is initialized successfully, the parent app (Freshworks product) passes a client reference to your app. Your app can use this reference and the developer platform’s data method to retrieve the different objects on the Freshworks product UI, as payloads.
To enable your app to retrieve product data, in the app.js file,
- Subscribe to the app.initialized event, through an event listener. When the app is initialized, the parent application passes a client reference to the app.
- After app initialization, use the data method - client.data.get(<objectName>) - to retrieve the specified object (<objectName>) from the product UI.
As part of the app logic, your app can process the retrieved payload to derive meaningful results.
This section,
- Lists all the objects that can be retrieved by using the data method.
- Describes all the attributes of the retrieved object.
Data objects accessible from all pages
These objects are available in all pages of the product UI. Irrespective of the page on which the app is deployed, when you use the data method -client.data.get(<objectName>)- and retrieve these objects, the corresponding payload is retrieved.
An app can retrieve the following objects irrespective of where the app is deployed:
currentHostFreshserviceFreshservice for MSPs
A global app, with module-specific app logic, can be deployed on various Freshworks products. currentHost refers to the Freshworks product on which the app is currently running. Based on the currentHost, from the back-end, we retrieve the modules that the app user working on the currentHost has subscribed to. Based on the subscribed modules, we can retrieve the product-specific urls that the app built for the modules can use, to access the product resources. The organization domain associated with the account can also be retrieved, which can be pre-populated during the app installation using utils.set(); method in the onFormLoad() callback function definition. For information on the onFormLoad() function, see Make your installation page dynamic.
For more information on currentHost, see Global app concepts.
Use the sample code shown on the right pane > Sample code tab, to retrieve the currentHost object that contains information on,
- All modules that the app user using the currentHost has access to and applicable to the app.
- All product names and the corresponding account urls through which the app built for the subscribed modules can access product resources.
Attributes of the currentHost object
- subscribed_modulesarray of stringsAll modules that the app user has subscribed to and present in the app manifest. 
- endpoint_urlsobjectProduct name and account url (domain name) to access product resources, specified as a key (product name) - value (account URL) pair. You can use the domain name to construct api calls that can access product resources. 
- org_domainstringOrganization domain is the domain value in the organization URL. This organization domain is created when you first sign up for a Freshworks product and is tied to all your accounts across different Freshworks products. You can use this value to pre-populate the organization domain value during app installation. 
- product_typesobjectInformation pertaining to the product where the app is currently running. 
loggedInUserFreshserviceFreshservice for MSPs
Use the sample code shown on the right pane > Sample code tab, to retrieve information on the agent logged into the Freshservice.
Attributes of the loggedInUser object
- availablebooleanIf the agent is in a group that has enabled Automatic Ticket Assignment, this attribute will be set to 'true' if the agent is accepting new tickets. 
- belongs_to_workspace_idsarray of integersNote:Applicable only for the Freshservice for MSPs product. Identifier(s) of the client to whom the agent belongs. 
- created_atstringContact creation timestamp. 
- group_idsarray of stringsGroup IDs associated with the agent. 
- idintegerUser ID of the agent. 
- occasionalbooleanSpecifies whether the agent is an occasional agent or a full-time agent . Possible values: true, false 
- signaturestringSignature of the agent in HTML format. 
- updated_atstringAgent updated timestamp. 
Contact details page
An app deployed on the Contact details page can use the client.data.get(<objectName>) data method and retrieve the following objects:
requesterFreshserviceFreshservice for MSPs
Use the sample code shown on the right pane > Sample code tab, to retrieve information of a requester.
Attributes of the requester object
- activebooleanSet to 'true' if the user has been verified. 
- addressstringAddress of the user. 
- created_atstringUser creation timestamp. 
- custom_fieldobjectKey value pairs containing the names and values of the custom fields. 
- deletedbooleanSet to 'true' if the user has been deleted. 
- descriptionstringA short description of the user. 
- emailstringPrimary email address of the user. 
- external_idintegerID of the user in an external system. 
- helpdesk_agentbooleanSet to 'true' if the user is an agent. 
- idintegerID of the user. 
- belongs_to_workspace_idsarray of integersNote:Applicable only for the Freshservice for MSPs product. Identifier(s) of the client associated with the contact. 
- job_titlestringJob title of the user. 
- languagestringLanguage of the user. 
- mobileintegerMobile number of the user. 
- namestringName of the user. 
- phoneintegerTelephone number of the user. 
- time_zonestringTime zone in which the user resides. 
- updated_atstringUser updated timestamp. 
departmentFreshserviceFreshservice for MSPs
Use the sample code shown on the right pane > Sample code tab, to retrieve information of the department.
Attributes of the department object
- created_atstringDepartment created timestamp. 
- custom_fieldobjectKey value pairs containing names and values of custom fields. 
- descriptionstringA short description of the department. 
- idintegerID of the department. 
- namestringName of the department. 
- updated_atstringDepartment updated timestamp.