To create a Web Service connection, perform the following steps:
- In Sigma Studio, click Create > Manage > Connection.
The Create New Connection page screen appears.
In the Create New Connection page, page, provide an - Click the Web Service option.
- Provide a unique name for the connection in the Connection Name field.
- In the Connection Type field, click Web Service.
- Enter the REST web service address ending with a forward slash in the Domain Name field. This address is also called as the base URL.
Select the industry-standard authorization mechanism supported by the REST web service from the Authentication Type drop-down list. The available options are as follows:Anchor authenticationtype_config authenticationtype_config - No Authentication. If No Authentication is the authentication type, proceed to step 8. Refer No Authentication for more information.
- OAuth 2. If OAuth 2 is the authentication type, proceed to step 6. Refer OAuth 2 for more information.
- API Key. If API Key is the authentication type, proceed to step 7. Refer API Key for more information.
- If OAuth 2 is the authentication type, perform the following steps in the OAuth Connection Details section, else proceed to step 7.
Enter the field name in which the access token will be passed to the web service in the Access Token Key field.
Info Each Web service will slightly vary in terms of the registration, authorization code and access token generation process.
Enter the Java class to provide the access token to the web service in the Access Token provider field.
Info The Java class that you provide must implement the IRestServiceAccessTokenProvider interface.
For your understanding, a sample Java class to obtain the access token is as follows:Code Block language java package com.intellectdesign.canvas.webservice; public class SampleRestAccessTokenProvider implements IRestServiceAccessTokenProvider { private String accessTokenFromService; public SampleRestAccessTokenProvider() { } @Override public String getAccessToken(String connectionName, String domainName) { /* * Implementation teams are expected to override this method and return * the access token secured from the web service. Its assumed that * implementation team takes care of the steps involved in getting an * access token from a target web service secured using OAuth mechanism. */ return accessTokenFromService; } }
- Proceed to step 8.
- If API Key is the authentication type, perform the following steps in the API Key Connection Details section, else proceed to step 8.
Enter the field name in which the API key will be passed to the web service in the API-Key Key word field.
Info Each Web service will slightly vary in terms of the third party application registration process.
Enter the value of the API key in the API-key field. This is the value that was provided by the web service provider to allow access to the data.
Info Each Web service will slightly vary in terms of the third party application registration process.
- Proceed to step 8.
To specify certain conditions to fetch data from the web service, perform the following steps in the
JSON Configuration for Request section, else proceed to step 9.Anchor JSON_Config_for_Request JSON_Config_for_Request Info The fields in this section (Model Id, Model Name, Model Description) and the JSON fields (step 8d) can be used when a base URL (application) offers many web services and the data from each of these web services must be fetched based on certain JSON conditions. Each web service will expect the JSON payload request in a particular format and will expose the format to the third party applications. Therefore, you must know the payload request format expected by the web service to write the JSON conditions accordingly. The conditions can be static, dynamic or a combination of both. Basically, using these fields, the master JSON is split into multiple models (conditions such as pagination, sorting, filtering, and so on).
- Enter a unique ID for the logical blocks within the JSON in the Model Id field.
- Enter a name for the JSON block in the Model Name field.
- Enter a description for the JSON block condition in the Model Description field.
In the right pane, provide the JSON for the conditions to fetch data from the web service.
For example, let's assume a web service called finance is available at http://1.2.3.4:0101/ShreeFinancials/rest/finance/postfetch. We have three conditions – pagination, sorting and filtering based on which the data will be fetched from the finance web service. We can split these conditions into three different models and provide them in the right pane of the section as shown in the following image. These models can be reused for other data sources (Web services) of the same connection.
As shown in the example, to paginate the data, the JSON can be provided as follows:Code Block language text { "start":"$page.start", "maxNumOfRecords":"$page.size" }
To sort the data, the JSON can be provided as follows:Code Block language text { "sortFields": [{ "fieldName":"$sort.field", "direction":"$sort.direction" }] }
To filter the data, the JSON can be provided as follows:Code Block language text { "filters": [{ "level":"$filter", "$key":"runtimeFilters", "columnValue":"value1", "type":"string", "columnName":"fieldName" }] }
Info Each web service will expect the payload request to be sent in a particular format. You must know the payload request format expected by the Web service to write the JSON conditions accordingly.
- To add another JSON block, click Add and follow the steps 8a to 8d. Proceed to next step to continue.
Click Save.
Warning When you try to exit the Create New Connection screen, before saving the configured web service connection, a warning pop-up message appears, as shown in the following screen shot:
- Click Cancel, if you do not want to exit the Create New Connection screen.
- Click Ok, if you want to exit the Create New Connection screen.
Once the connection is saved correctly, the following message appears.
...
See also:
...