Integrate Datylon Report Server with our API to automate reports and charts

Learn how to integrate the Datylon Report Server using the API

Introduction

The Datylon Report Server is a platform that allows organizations to automate the production of charts, dashboards, or complete reports based on graphically rich and on-brand templates created with Datylon for Illustrator.

The Datylon Report Server consists of the following components: 

  • Datylon for Illustrator
    An Adobe Illustrator plugin to create advanced graphs and data visualizations. The resulting designs are exported as templates to the Datylon Report Server for automated data updates. Read more on Datylon for Illustrator https://www.datylon.com/product/datylon-for-illustrator
  • Datylon web app
    State of the art web application allowing the user to create, view, style, manage and use templates exported from Datylon for Illustrator. New charts, pages, or reports are created based on these templates by binding new data sources to them. This binding process can be done manually or automatically using the Datylon Render Report Server API.
  • Datylon Report Server
    A REST API addressable service that allows the user to render Datylon templates with new data and some rendering options, and retrieve the result as SVG, PNG, or PDF. 

A separate article about how to build an automated reporting solution with Datylon Report Server can be found here

Below you’ll find details on how to connect external applications by sending requests to the Datylon Render Report Server. For more information on creating templates with Datylon for Illustrator, click here

Datylon Report Server

The Datylon Report Server includes the following features: 

  • Authentication of a request.
  • Conversion of the request payload to a data structure that is used to render the template.
  • Fetching the template from https://insights.datylon.com based on a Datylon template or design uuid.
  • Returning the render result as the request response.

For proper authentication, you need a Datylon account with a password. A Datylon account created with a Google single sign on is not supported.  

Tip: At first, start small. Use a template with a single bar or line chart and a small data set to get started with the integration service.

 

Render endpoint

To render a template with data, an HTTP POST request characterized by the following properties should be sent:

HTTP request and URL

Please contact Datylon via the contact form or getsupport@datylon.com to provide the URL and API key.

HTTP headers

HTTP header keys and values (except authorization) shall be in lower case. 

  • authorization
    • Basic HTTP authorization header. E.g. assuming a Datylon account with email "me@acme.com" and password "secret", the header becomes
      Basic bWVAYWNtZS5jb206c2VjcmV0
  • content-type
    • application/json → data should be provided as json (see further)
  • accept
    • image/svg+xml → return render result as SVG
    • image/png → return render result as PNG
    • application/pdf → return render result as PDF
  • x-graph-template-id
    • UUID of the Datylon template or design to be rendered, located on the Datylon Report Server. 
    • To retrieve this UUID, open the template or design in https://insights.datylon.com/create/stories and copy the alphanumeric string at the end of the URL. 
  • x-api-key
    • Unique API key which will be provided on request.

URL/query parameters

There are some URL/query parameters available to set different output properties such as page dimensions, resolution, scale factor, background settings, etc. 

Using the linked data source URL/query parameter, one can also use linked data sources (Google sheets) which are specified in the template as a data source, on condition no data is provided in the payload of the request. 

Contact us at getsupport@datylon.com for more details. 

HTTP payload

Max Size

The maximum size of the JSON payload is 128 MB.

Data

A sample of a JSON file of any workbook used, can be downloaded using either the Datylon for Illustrator plugin (Data manager > click the download button > JSON) or the Datylon web app (open a Design or a Template > click on the JSON button in the Attached Data section in below right corner). 

 

It is essential the structure of the JSON file exactly matches the structure of the data used in the Datylon template.

If the ‘default workbook' is used when creating the template, it should be referred to as ‘main template datasheet container’ in the JSON payload. 


Find below the JSON structure for use with the 'default workbook' :

{

  "main template datasheet container": {

    "name of first sheet": [

        ["row 1,col 1","row 1,col 2",...,"row 1,col n"],

        ["row 2,col 1","row 2,col 2",...,"row 2,col n"],

        ....

    ],

    "name of second sheet": [

        ["row 1,col 1","row 1,col 2",...,"row 1,col n"],

        ["row 2,col 1","row 2,col 2",...,"row 2,col n"],

        ....

    ],

    "name of third sheet": [

      ...

    ],

    ....

  }

}

Row x, col y refers to the values in row x, column y of the corresponding sheet.


Below an example in case of one or more other workbooks are used:

{
 "Name of first workbook":{
    "Sheet 1":[["Category","v1","v2"],["category1","12","14"],["category2","3","13"],["category3","43","12"],["category4","2","11"]]
   }
,"name of 2nd workbook":{
  "Sheet 1":[["Category","Value"],["A1","1"],["A2","50"],["A3","2"],["A4","50"],["A5","5"],["A6","32"],["A7","4"],["A8","6"],["A9","7"],["A10","8"],["A11","44"]],
  "Sheet 2":[["Cat 4","Val 4"],["aaa","44"],["bbb","44"],["ccc","44"]]
   }
,"Name of 3rd workbook":{
  "Sheet 1":[["v1","Value"],["c1","122.1"],["c2","443.9"],["c3","322.322"]]
    }
}

The number of sheets and the sheet names in the JSON should match exactly the number of sheets and names in the Datylon design/template. The sheet names are case-sensitive. 

 

 

HTTP Payload

Optional "visible" chart property

Datylon Report Server allows you to overwrite the "visible" property of a chart by means of an optional stylePatches object in the JSON payload. With this specific property, you can hide or show complete charts. This property can be applied to all chart types. 

The data structure in the JSON to enable this feature is as follows: 

"stylePatches" : {

"ChartName-1": [

{"op": "replace", "path": "/visible", "value": true}

],

"ChartName-n": [

{"op": "replace", "path": "/visible", "value": false}

]
}
  • ChartName-n is the unique name of the chart as given in the Datylon editor (in the header of the Datylon editor next to the chart icon). 
  • "true" shows the chart, and "false" hides the chart. 
  • If the stylePatches object is used, the object "data" needs to be added before the data set. See below the example.
  • When the stylePatches object is omitted, the chart keeps its original visible property as set in the template. 


The "visible" property can be simulated in the Datylon editor by clicking on the eye icon next to Styling > General. Note, the "visible" chart property is not added to the JSON which is be downloaded from the Datylon editor. 

 

Number formatting options

Property name

 

Type

 

Possible values

 

minus-sign

string

'U+2212 (−)', 'hyphen (-)'

absolute-values

boolean

true, false

add-plus

boolean

true, false

decimal-separator

string

any string

thousand-separator

string

any string

short-notation

string

'none', 'auto', 'nano', 'micro', 'milli', 'kilo', 'mega', 'giga'

precision

object

{value: null | number}. null means no precision (will look like it is in the data), number is the amount of decimals after comma, must be a multiple of one

 

Examples

A separate article about how to build an automated reporting solution with Datylon Report Server can be found here

 

On our inspiration page, you can open any design and download a JSON file as a sample. 

Example 1

 

The template above with dummy data is rendered using the following URL, headers, and data sets: 

  • URL: To be provided. Please contact Datylon.
  • authorization: Your Datylon account and password 
  • content-type: application/json. See data set below
  • accept: image/png
  • x-graph-template-id: 155d6153-4b8d-49d9-a8ba-d94417aa5111


JSON. Including the optional stylePatches object with the "visible" chart property all on "true". 

{

"stylePatches" : {

"Linechart": [
{"op": "replace", "path": "/visible", "value": true}
],

"Barchart": [
{"op": "replace", "path": "/visible", "value": true}
],

"Piechart": [
{"op": "replace", "path": "/visible", "value": true}

]
},

"data" : {
"main template datasheet container": {

"line": [

["X","Y1","Y2","Y3"],

["jan","60","47","5"],

["feb","50","37","20"],

["mar","56","32","25"]

],

"bar-and-pie": [

["Category","Value"],

["Cat","60"],

["Dog","15"],

["Bird","9"],

["Mouse","5"],

["Horse","11"]

]

}

}

}

The response is the png below:

Example 2

Another example on how to use style patches including the number-format options on render-server. In the request body we have to provide the object with two properties stylePatches and data.

{
    "stylePatches": {
        "Bar Chart": [
            {
                "op": "replace",
                "path": "/datalabels/format/absolute-values",
                "value": true
            },
            {
                "op": "replace",
                "path": "/datalabels/format/decimal-separator",
                "value": "..."
            },
            {
                "op": "replace",
                "path": "/datalabels/format/precision",
                "value": {"value": 2}
            },
            {
                "op": "replace",
                "path": "/x-axis/labels/visible",
                "value": true
            },
            {
                "op": "replace",
                "path": "/x-axis/number-format/precision",
                "value": {"value": null}
            },
            {
                "op": "replace",
                "path": "/y-axis/number-format/precision",
                "value": {"value": 3}
            }
        ]
    },
    "data": {
        
    }
}

“Bar Chart” is the name of the chart we want to apply new style properties to.

“data” contains new datasource to render the chart.

 

Data security & on-premise deployment

Besides the cloud-deployed Datylon render service, accessible from ‘anywhere’, the render service can also be deployed on-premise as a Docker instance. This allows to set up a rendering workflow keeping privacy-sensitive data on-site while the templates are stored in the Datylon web app.

Such an architecture combines the advantages of secure cloud technologies with the requirement to keep sensitive data behind a corporate firewall at all times - the on-site deployed Datylon render service will retrieve the Datylon template from the web app through a secured channel and combine it with the provided data, rendering the result as one of the supported output formats.

Support

For support please use the contact form or chat in the Help Center, or email us at getsupport@datylon.com

Use this link if you'd like to book a demo with our solution architect and learn more about Datylon Report Server. Check this page for more information about Datylon Report Server and use cases.