Building a Custom API Connector for SAP Crystal Reports
Read / write Custom API data in SAP Crystal Reports without coding.
In this article you will learn how to quickly and efficiently integrate Custom API data in SAP Crystal Reports without coding. We will use high-performance Custom API Connector to easily connect to Custom API and then access the data inside SAP Crystal Reports.
Let's follow the steps below to see how we can accomplish that!
Building a Custom API Connector for SAP Crystal Reports is based on ZappySys API Driver which is part of ODBC PowerPack. It is a collection of high-performance ODBC drivers that enable you to integrate data in SQL Server, SSIS, a programming language, or any other ODBC-compatible application. ODBC PowerPack supports various file formats, sources and destinations, including REST/SOAP API, SFTP/FTP, storage services, and plain files, to mention a few.
Create Custom API Connector
    First of all, you will have to create your own API connector.
    For demonstration purposes, in this section we will create a simple Hello-World API connector that
    calls ZappySys Sandbox World API endpoint https://sandbox.zappysys.com/api/world/hello.
    When developing your Custom API Connector, just replace it with your real API method/endpoint.
    Let's dive in and follow these steps:
- 
	Open ODBC Data Sources (x64):   
- 
	Create a User data source (User DSN) based on ZappySys JSON Driver ZappySys JSON Driver  
- 
    Once the data source configuration window opens, enter this URL into the text box: https://sandbox.zappysys.com/api/world/hello  
- 
    Then go to the Preview tab and try to say "Hello!" to the World!   
- 
    Since the test is successful, you are ready to create the Hello-World Connector:   
- 
    The API Connector File Wizard opens, click Next:   
- 
    Leave the default option, and click Next again:   
- 
    Just click Next in the next window:   
- 
    Let's give our new custom connector a name it deserves:   
- 
    Then just click Next in the Connection Types window:   
- 
    Let's name the hello endpoint (it deserves a name too!):   
- 
    When the next window opens, delete the default table (we won't need it for now):   
- 
    Finally, specify a path, where you want to save the newly created API Connector:   
Create ODBC Data Source (DSN) based on ZappySys API Driver
Step-by-step instructions
To get data from Custom API using SAP Crystal Reports we first need to create a DSN (Data Source) which will access data from Custom API. We will later be able to read data using SAP Crystal Reports. Perform these steps:
- 
	    Download and install ODBC PowerPack. 
- 
	Open ODBC Data Sources (x64):   
- 
	Create a User data source (User DSN) based on ZappySys API Driver ZappySys API Driver  
- 
        When the Configuration window appears give your data source a name if you haven't done that already. Then set the path to your created Custom API Connector (in the example below, we use Hello-World Connector). Finally, click Continue >> to proceed:   
- 
	    Now it's time to configure the Connection Manager. Select Authentication Type, e.g. Token Authentication. Then select API Base URL (in most cases, the default one is the right one). Check your Custom API reference for more information on how to authenticate.   
- 
	Once the data source connection has been configured, it's time to configure the SQL query. Select the Preview tab and then click Query Builder button to configure the SQL query:  ZappySys API Driver - Custom APIRead / write Custom API data in SAP Crystal Reports without coding.CustomApiDSN ZappySys API Driver - Custom APIRead / write Custom API data in SAP Crystal Reports without coding.CustomApiDSN  
- 
	Start by selecting the Table or Endpoint you are interested in and then configure the parameters. This will generate a query that we will use in SAP Crystal Reports to retrieve data from Custom API. Hit OK button to use this query in the next step. SELECT * FROM Orders Some parameters configured in this window will be passed to the Custom API, e.g. filtering parameters. It means that filtering will be done on the server side (instead of the client side), enabling you to get only the meaningful data Some parameters configured in this window will be passed to the Custom API, e.g. filtering parameters. It means that filtering will be done on the server side (instead of the client side), enabling you to get only the meaningful datamuch faster .
- 
	Now hit Preview Data button to preview the data using the generated SQL query. If you are satisfied with the result, use this query in SAP Crystal Reports:  ZappySys API Driver - Custom APIRead / write Custom API data in SAP Crystal Reports without coding.CustomApiDSN ZappySys API Driver - Custom APIRead / write Custom API data in SAP Crystal Reports without coding.CustomApiDSNSELECT * FROM Orders You can also access data quickly from the tables dropdown by selecting <Select table>.A You can also access data quickly from the tables dropdown by selecting <Select table>.AWHEREclause,LIMITkeyword will be performed on the client side, meaning that thewhole result set will be retrieved from the Custom API first, and only then the filtering will be applied to the data. If possible, it is recommended to use parameters in Query Builder to filter the data on the server side (in Custom API servers).
- 
    Click OK to finish creating the data source. 
Video Tutorial
Read data in SAP Crystal Reports from the ODBC data source
- 
    First of all, open SAP Crystal Reports and create the new Crystal Report. 
   
- 
    And it will open the new data source selection window. Under ODBC(RDO) double click on the Make New Connection and Select the desired ODBC DSN, in our case we need to select CustomApiDSN which we created in upper section. And Click on Next. 
 CustomApiDSN  
- 
    Expand the Connection and under the data select the desired table(s) or view(s) and click Add > button and click on Next. 
 CustomApiDSNCustomApiDSN  
- 
    Add the desired Fields to Display in the Reports. Here we are adding all fields and click on Finish. 
   
- 
    That's it and you will be able to load the data in the Report. 
   
Using ZappySys Driver Custom Views and Stored Procedure in SAP Crystal Report
You can create parameterized Stored Procedure and Virtual Tables on the same Data Source (ODBC DSN or Data Gateway Data Source). Please refer to this article for the same. You can create procedures to encapsulate custom logic and then only pass handful parameters rather than long SQL to execute your API call.Using Custom Views in the SAP Crystal Report
After establishing the connection with CustomApiDSN Data Source you can use the custom view in SQL Crystal Report. 
Using Custom Stored Procedure in the SAP Crystal Report
- 
        First of all, create the custom stored procedure in the ZappySys Driver. Please refer to this article to create the custom stored procedure.
        
   
- 
        After establishing the connection with CustomApiDSN Data Source you can use the custom Stored Procedure in SQL Crystal Report. Same way you can write custom queries also in the query box.
        CustomApiDSN  
Conclusion
In this article we showed you how to connect to Custom API in SAP Crystal Reports and integrate data without any coding, saving you time and effort.
We encourage you to download Custom API Connector for SAP Crystal Reports and see how easy it is to use it for yourself or your team.
If you have any questions, feel free to contact ZappySys support team. You can also open a live chat immediately by clicking on the chat icon below.
Download Custom API Connector for SAP Crystal Reports Documentation
 
                     
                 
             
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
                         
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		             
		            