DEV Community

Jerod Johnson
Jerod Johnson

Posted on

2

Analyze Live Salesforce Data in Infragistics Reveal

Infragistics Reveal is a data visualization solution that simplifies the way you add embedded analytics and visualizations to your apps. Reveal supports connecting to OData APIs, but many enterprise APIs are not built using the OData standard. By combining Reveal with CData solutions, you can instantly build dynamic dashboards from live enterprise data sources like Salesforce.

With access to live data, you can build real-time, responsive dashboards that retrieve new data points with every refresh. CData Connect Cloud and API Server let you generate standard data APIs like OData for all your data, offering out-of-the-box connectivity to tools like Reveal.

In this article, we walk through how to connect to Salesforce to Infragistics Reveal to create a simple dashboard, leveraging CData Connect Cloud and CData API server to facilitate the connection.

Why CData?

Both CData Connect Cloud and CData API Server provide a single point of contact for all your enterprise data through standard data interfaces like SQL and OData. Instead of migrating data from dozens of sources to a static data store or writing your own integrations, simply point your tools to Connect Cloud or API Server and get instant, live access to all your data.

Why Connect Cloud?

As a cloud-based integration platform, Connect Cloud is ideal for working with cloud apps that have embedded Reveal visualizations. With no servers to configure or data proxies to set up, you can simply use the Web-based UI to create a virtual database for Salesforce, generate an OData API, and connect from Reveal to start building dashboards based on live Salesforce data.

Why CData API Server?

CData API Server can be installed on-prem or in a self-hosted environment enabling you to connect to data from on-prem or self-hosted apps built on Reveal dashboards. Create an OData endpoint for Salesforce using the straightforward point-and-click interface and connect from Reveal to create dynamic Salesforce visualizations.

Getting Started: Salesforce Connection Properties

To work with live Salesforce data in Reveal, you need to authenticate with Salesforce. There are several authentication methods available for connecting to Salesforce: Login, OAuth, and SSO. The Login method requires you to have the username, password, and security token of the user.

If you do not have access to the username and password or do not wish to require them, you can use OAuth authentication.

Use SSO (single sign-on) by setting the SSOProperties, SSOLoginUrl, and TokenUrl connection properties, which allow you to authenticate to an identity provider. See the "Getting Started" chapter in the help documentation for more information.

Using CData Connect Cloud

To connect to your Salesforce data in Connect Cloud and enable OData access, navigate to the web interface for your Connect Cloud instance (https://www.cdatacloud.net/myinstance). Follow the steps below to configure Connect Cloud. (Jump to building a dashboard.)

Add a Connect Cloud User

Create a User to connect to Salesforce from Reveal through Connect Cloud.

  1. Click Users -> Add

  2. Configure a User

Image description

  1. Click Save Changes and make a note of the Authtoken for the new user

Image description

Connect to Salesforce from Connect Cloud

CData Connect Cloud uses a straightforward, point-and-click interface to connect to data sources and generate APIs.

  1. Open Connect Cloud and click Databases

Image description

  1. Select "Salesforce" from Available Data Sources

  2. Enter the necessary authentication properties to connect to Salesforce (see above)

Image description

  1. Click Test Database

  2. Click Privileges -> Add and add the new user (or an existing user) with the appropriate permissions (SELECT is the only required permission for Reveal)

Add Salesforce OData Endpoints in Connect Cloud

After connecting to Salesforce, create OData Endpoint for the desired table(s).

  1. Click OData -> Tables -> Add Tables

Image description

  1. Select the Salesforce database

Image description

  1. Select the table(s) you wish to work with and click Next

Image description

  1. (Optional) Edit the resource to select specific fields and more

  2. Save the settings

(Optional) Configure Cross-Origin Resource Sharing (CORS)

When accessing and connecting to multiple different domains from an application such as Ajax, there is a possibility of violating the limitations of cross-site scripting. In that case, configure the CORS settings in OData -> Settings.

  • Enable cross-origin resource sharing (CORS): ON

  • Allow all domains without '*': ON

  • Access-Control-Allow-Methods: GET, PUT, POST, OPTIONS

  • Access-Control-Allow-Headers: Authorization

Save the changes to the settings.

Image description

Using API Server

To connect to your Salesforce data in API Server and enable OData access, navigate to the web interface for your API Server instance (https://localhost:8153). Follow the steps below to configure the API Server. (Jump to building a dashboard.)

Connect to Salesforce from API Server

CData API Server uses a straightforward, point-and-click interface to connect to data sources and generate APIs.

  1. Open API Server and click Settings -> Connection -> Add Connection

Image description

  1. Select "Salesforce"

Image description

  1. Enter the necessary authentication properties to connect to Salesforce (see above)

Image description

Add Salesforce Resource Definitions in API Server

After connecting to Salesforce, create Resources, which represent API endpoints for Salesforce data.

  1. Click Settings -> Resources -> Add Resource

Image description

  1. Select the Salesforce connection

Image description

  1. Select the table you wish to retrieve and click Next

Image description

  1. (Optional) Edit the resource to select specific fields and more

  2. Save the settings

Add an API Server User

Create a User to connect to Salesforce from Reveal through API Server.

  1. Click Settings -> Users

  2. Click Add

  3. Configure a User with access to the Salesforce Connection and Resource(s)

Image description

Image description

(Optional) Configure Cross-Origin Resource Sharing (CORS)

When accessing and connecting to multiple different domains from an application such as Ajax, there is a possibility of violating the limitations of cross-site scripting. In that case, configure the CORS settings in Settings -> Server.

  • Enable cross-origin resource sharing (CORS): ON

  • Allow all domains without '*': ON

  • Access-Control-Allow-Methods: GET, PUT, POST, OPTIONS

  • Access-Control-Allow-Headers: Authorization

Save the changes to the settings.

Image description

Create a Dashboard in Reveal

With the API Server configured, we can visualize Salesforce data in Reveal.

  1. Log into Reveal and click Dashboards -> New

Image description

  1. Click Data Source -> OData Feed

Image description

  1. Specify the API Server or Connect Cloud API endpoint URL, for example, https://serverurl/api.rsc

Image description

  1. Select Generic Credentials and specify the API Server username and authentication token

Image description

  1. Select the entity you wish to visualize

Image description

  1. Select fields and choose a chart type

Image description

More Information

Companies everywhere are looking to leverage their data to make effective decisions and grow their businesses.

By providing industry-standard connectivity, both CData Connect Cloud and CData API Server democratize Salesforce access. Now everyone in the organization, from IT professionals & app developers to citizen analysts & data scientists can work with and find value from the entire Salesforce platform.

Image of Bright Data

Maintain Seamless Data Collection – No more rotating IPs or server bans.

Avoid detection with our dynamic IP solutions. Perfect for continuous data scraping without interruptions.

Avoid Detection

Top comments (0)

👋 Kindness is contagious

Discover a treasure trove of wisdom within this insightful piece, highly respected in the nurturing DEV Community enviroment. Developers, whether novice or expert, are encouraged to participate and add to our shared knowledge basin.

A simple "thank you" can illuminate someone's day. Express your appreciation in the comments section!

On DEV, sharing ideas smoothens our journey and strengthens our community ties. Learn something useful? Offering a quick thanks to the author is deeply appreciated.

Okay