Getting Started • Suricate • DevTool
Retrieve data from external sources and present it in a tile-based format on Suricate dashboards.
The repository is organized as follows:
- Content: Contains all the widgets sorted by category.
- Category: A widget category (e.g. Gitlab, GitHub, Jenkins, etc.).
- Widgets: Contains all the widgets of the category.
- Widget: A widget.
- content.html: The HTML content of the widget.
- description.yml: The description of the widget.
- image.png: The image of the widget.
- params.yml: The parameters of the widget.
- script.js: The process content of the widget, defining what the widget does.
- style.css: CSS styles to apply to the widget HTML content.
- Widget: A widget.
- description.yml: The description of the category.
- icon.png: The icon of the category.
- Widgets: Contains all the widgets of the category.
- Category: A widget category (e.g. Gitlab, GitHub, Jenkins, etc.).
- Libraries: Contains all the JavaScript libraries used by all the widgets.
To create a repository of widgets, follow the steps below.
A category is a folder that contains all the widgets related to a specific topic. It contains the following files:
- A
description.yml
file that describes the category. - An
icon.png
file to associate an icon with the category in the Suricate application. - A folder that contains all the widgets related to this category.
The description.yml
file describes the category and contains associated parameters. Here is an example:
name: GitHub
technicalName: github
configurations:
-
key: 'WIDGET_CONFIG_GITHUB_TOKEN'
description: 'Token for the GitHub API'
dataType: PASSWORD
Here are the possible parameters that can be set in this file:
Param | Required | Description |
---|---|---|
name |
true | The name of the category to display in Suricate. |
technicalName |
true | The primary key of the category. This is used by the back-end to uniquely identify a category. |
configurations |
false | Parameters associated with the category. All the widgets of the category will share these parameters. Values are defined directly from the Configuration tab in the Suricate application. Each parameter must declare the following properties:
|
The icon.png
file contains the icon to be associated with the category. The icon will be displayed in the Suricate application.
The widgets folder contains all the widgets linked to the category.
For more information about creating a widget, please see the dedicated section.
A widget is a folder containing the following files:
- A
content.html
file that displays the widget in a tile format on Suricate dashboards. - A
description.yml
file that provides a description of the widget. - A
image.png
file that is used to associate an image with the widget in the Suricate application. - A
params.yml
file that describes the parameters of the widget. - A
script.js
file that contains the business logic of the widget in JavaScript. - A
style.css
file that contains the CSS style of the widget to apply to the HTML.
The content.html
file is responsible for displaying the widget on Suricate dashboards and provides the tile format for the widget. It contains the HTML code of the widget.
<div class="grid-stack-item-content-inner">
<h1 class="title">{{SURI_GITHUB_PROJECT}}</h1>
<h2 class="value">{{numberOfIssues}}</h2>
<h2 class="issues-label">{{#issuesState}} {{issuesState}} {{/issuesState}} issues</h2>
{{#evolution}}
<p class="change-rate">
<i class="fa fa-arrow-{{arrow}}"></i><span>{{evolution}}% since the last execution</span>
</p>
{{/evolution}}
</div>
<div class="github"></div>
This file is a template that will be compiled with Mustache, so feel free to use the provided directives to:
- Display data computed by the Back-End from the "script.js" file
- Display parameters from the "params.yml" file or the "description.yml" file of the related category
- Display conditional content
Note that the variable SURI_INSTANCE_ID
is available. This is a unique ID that identifies the widget instantiation on a dashboard. If you need to select the widget to use it in JavaScript or CSS, you can use the class selector .widget-{{SURI_INSTANCE_ID}}
.
As in the example above, it is possible to add custom JavaScript or calls to JavaScript libraries to improve the widget display.
The description.yml
file provides information about the widget. The following is its content:
name: Number of issues
description: Display the number of issues of a GitHub project
technicalName: githubOpenedIssues
delay: 600
The table below lists all possible parameters in this file:
Param | Required | Description |
---|---|---|
name |
true | The name of the widget to be displayed in Suricate. |
technicalName |
true | The primary key of the widget, used by the back-end to uniquely identify a widget. |
description |
true | A short description of what the widget does. |
info |
false | Usage information about the widget and what the user needs to do to get it to work. |
delay |
true | The duration (in seconds) between each update of the widget. It can be set to -1 if the widget does not need to start the script.js file. |
timeout |
false | The timeout duration (in seconds) for the widget execution. If it exceeds this duration, the widget will be stopped. |
libraries |
false | A list of the names of all the external JavaScript libraries required by the widget. The libraries must be manually imported as minified files into the libraries folder at the root of the widget repository. The libraries will be injected into the DOM at execution so that they are available for the widget. |
An image.png
file contains the image associated with the widget, which will be displayed in the Suricate application.
The params.yml
file describes the parameters of the widget that are displayed in the Suricate application when the user selects the widget to add it to a dashboard. The user can set values to the parameters directly from the application, which can then be used in the script.js
file or the content.html
file.
The params.yml
file must adhere to the following rules:
- The file should always start with the
widgetParams
keyword. - The parameters have to be described after this keyword as a YAML list format.
widgetParams:
-
name: 'SURI_GITHUB_ORG'
description: 'GitHub organization'
type: TEXT
required: true
-
name: 'SURI_GITHUB_PROJECT'
description: 'GitHub project'
type: TEXT
required: true
-
name: 'SURI_ISSUES_STATE'
description: 'Filter on the state of the issues'
type: COMBO
defaultValue: 'all'
possibleValuesMap:
-
jsKey: all
value: All
-
jsKey: open
value: Open
-
jsKey: closed
value: Closed
required: true
The following table lists all available parameters for the params.yml
file:
Param | Required | Description |
---|---|---|
name |
true | The name of the variable. It has to start with the keyword "SURI_". Then the variable can be used in the script.js file and the content.html file. It will hold the value set by the user in the Suricate application. |
description |
true | The description of the parameter. Describe the expected value. It will be displayed as an input label to the user. |
type |
true | The data type of the parameter. Here is the full list of available types to define in uppercase:
|
possibleValuesMap |
false | Contains the possible values of a combo box. This has to be set if the type of the parameter is COMBO or MULTIPLE. There are two pieces of information to set:
|
defaultValue |
false | The default value to set for the parameter. It will be displayed in the input by default in the Suricate application. |
usageExample |
false | An example of how to fill the parameter. |
usageTooltip |
false | A message to display in a tooltip when configuring the widget. |
required |
true | Defines whether the parameter is required or not. |
The script.js
file is the core of the widget. It contains the business process of the widget and defines what the widget does. Most of the time, it submits requests to REST APIs and processes the retrieved data to send to the front-end.
How does the script work?
- It is executed by the Suricate Back-End with GraalVM Polyglot.
- It has to define a function named
run
. All the data returned by the run function has to be stringified in a JSON format. - The calls to the REST APIs have to be done by invoking Packages.get() or Packages.post(). It will invoke one of the get or post methods in the Suricate Back-End.
function run() {
var data = {};
var perPage = 100;
var issues = [];
var page = 1;
var response = JSON.parse(Packages.get("https://api.github.com/repos/" + SURI_GITHUB_ORG + "/" + SURI_GITHUB_PROJECT + "/issues?page=" + page + "&per_page=" + perPage + "&state=" + SURI_ISSUES_STATE, "Authorization", "token " + WIDGET_CONFIG_GITHUB_TOKEN));
issues = issues.concat(response);
...
data.numberOfIssues = issues.length;
return JSON.stringify(data);
}
This style.css
file is used to add CSS style to the widget.
Usage information:
- It is a pure CSS style file.
- All the classes have to be prefixed by
.widget.<technicalname>
. The technical name is the one defined in the description.yml file of the widget.
.widget.githubOpenedIssues {
background-color: #FFFFFF;
}
...
.widget.githubOpenedIssues .issues-label {
color: #1B1F23;
font-size: 40px;
}
The Suricate Widget Tester is a tool that helps you to test your widget. It is available at https://github.com/michelin/suricate-widget-tester.
We welcome contributions from the community! Before you get started, please take a look at our contribution guide to learn about our guidelines and best practices. We appreciate your help in making Suricate a better tool for everyone.