Skip to end of banner
Go to start of banner

November 2024 - Dashboard Release Notes

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 6 Next »

  • Customer Request tickets are highlighted with the 🗣️ icon

  • The 2024_11 release contains no Schema changes


EDITOR NOTE - INFORMATION TAKEN FROM DEV RELEASE NOTES AT 09:45 ON - VALIDATE NO ADDITIONAL CHANGES SINCE, BEFORE THESE ARE RELEASED

NEW FEATURES

JSON logging for the Scheduler - Default level changed to INFO 🗣️

scheduler#76

-

Logging

You can now have the Scheduler log in JSON format via checking the box in the Configuration-Tool GUI or setting the following Environment Variable to true: SCHEDULER_LOGGING_JSON. This setting, the other logging settings, and the JWT Key Path setting have also been added to the Configuration-Tool GUI.

image-20241030-154741.png

Environment Variables file will need the following:

  • SCHEDULER_LOGGING_JSON added to Scheduler list with a default of false

  • SCHEDULER_LOGGING_LEVEL default mention the change to INFO rather than ERROR

Pirana Logs with JSON format 🗣️

pirana#42

-

Logging

The option to have pirana logs output in JSON has been added. This can be configured via the config tool. You can also now successfully set the appropriate log level, with it defaulting to INFO.

Screenshot from 2024-10-25 16-32-14.png

You can use the “PIRANA_LOG_LEVEL" variable to set the log level, either to “ERROR“, “WARN”, “DEBUG” or “INFO”.

You can set the “PIRANA_LOGGER_JSON" variable to either “true” or “false”, to enable JSON logs.

Ability to use Usercode rather than Email for SAML Login and option to define custom claim names for both Usercode and Email 🗣️

pi#2618

32145

SAML Login

Previously, a hardcoded default was used for the email claim name that would attempt to link a SAML login response and a Dashboard user. This default ‘XMLSoap’ value will still be used as a last resort but you now have the ability to define a custom email claim name in the SAML section of the Global Variables screen.

Additionally, there is also a field for a custom Usercode claim name which rather than attempting to match to a user’s email address will match based upon their Dashboard Usercode (Username). If the usercode claim name is defined or the default (see below) manages to extract a value from the SAML response then the Email claim will be ignored even if provided.

The defaulting behaviour of these claims is as follows:

Usercode:

  • If defined the Custom value will be used. Should it fail to retrieve a value or the retrieved value does not match a Dashboard User’s Usercode then login will fail

  • Our namespaced default claim of “https://www.panintelligence.com/claims/usercode“ will be attempted. If it fails to return a value or match a Dashboard User then login will fail

Email:

  • If defined the Custom value will be used. Should it fail to retrieve a value or the retrieved value does not match a Dashboard User’s Email then login will fail

  • Our namespaced default claim of “/wiki/spaces/DEV/pages/1582238068 will be attempted. If it fails to return a value the final fallback will be attempted

  • The final fallback for Email is the ‘XMLSoap’ claim that was previously the only claim used. If this fails to retrieve a value or match a Dashboard User’s Email then login will fail

2618_saml-ui.png

 

Financial periods awareness and new financial magic variables 🗣️

pi#2567

31388 and 32934

Category Objects

A new system variable `START_OF_FINANCIAL_YEAR_MONTH` has been introduced to the dashboard that defines a month in which a financial year begins. This variable can be set in the Global Variables panel in Dashboard Configuration:

Screenshot from 2024-10-30 12-01-45.png

This input field accepts values from 1 to 12 to represent the starting month for the financial year, where 1 equals January and 12 equals December.

This `START_OF_FINANCIAL_YEAR_MONTH` system variable will drive the values available in the new ‘Financial’ tab in the popup panel for the date range category object type. ‘Financial’ tab will only be visible when `START_OF_FINANCIAL_YEAR_MONTH` is defined.

Screenshot_from_2024-10-23_11-43-09.png

The month name in ‘Your Financial Periods run from xx’ can be translated by adding its translated value to the messagesData.properties file. For example, in messagesData_fr_FR.properties file: January=Janvier.

The ‘From’ and ‘To’ for the selected option (e.g. ‘This Quarter’, ‘Next Year’) will be calculated based on the entry for `START_OF_FINANCIAL_YEAR_MONTH`. For example, if you enter 5 (May) for `START_OF_FINANCIAL_YEAR_MONTH` then 'Next Year' will be From: 2025-05-01 to 2026-04-30.

The same calculations for variable replacement based on `START_OF_FINANCIAL_YEAR_MONTH` definition can also be accessed by using the new financial magic variables:

- START_OF_CURRENT_FINANCIAL_QUARTER
- END_OF_CURRENT_FINANCIAL_QUARTER
- START_OF_LAST_FINANCIAL_QUARTER
- END_OF_LAST_FINANCIAL_QUARTER
- START_OF_NEXT_FINANCIAL_QUARTER
- END_OF_NEXT_FINANCIAL_QUARTER
- START_OF_CURRENT_FINANCIAL_YEAR
- END_OF_CURRENT_FINANCIAL_YEAR
- START_OF_LAST_FINANCIAL_YEAR
- END_OF_LAST_FINANCIAL_YEAR
- START_OF_NEXT_FINANCIAL_YEAR
- END_OF_NEXT_FINANCIAL_YEAR

You can find more information about these new variables here: /wiki/spaces/DEV/pages/2038202369

Ability to add temporary category objects via post message 🗣️

pi#2667

-

Embedding Category Objects

We have added the ability to add temporary category objects via a post message when embedding a category. Here is an example HTML and JS file you would use to configure this.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="parent-div"></div>
    <script src="tempcatobjpm.js" type="text/javascript"></script>
</body>
</html>
const url = "http://localhost:8080/pi/?lang=en_GB&categoryMode=0#/dashboard-system/#/redirectToDefaultCategoryState/34";
const iframe = document.createElement("iframe");
iframe.setAttribute("src", url);
iframe.style.width = "750px";
iframe.style.height = "750px";
document.getElementById('parent-div').appendChild(iframe);
window.addEventListener("message", (event) => {
    if (event.data && event.data === "canAddTempCategoryObjects") {
        const postMesssageJson = {
            type: "add-temp-category-objects",
            data: {
                categoryObjects: [
                    {
                        orgId: 1,
                        dataSourceItemIdentifier: "Dashboard Repos",
                        columnIdentifier: "Chart Name"
                    },
                    {
                        orgId: 1,
                        dataSourceItemIdentifier: "Dashboard Repos",
                        columnIdentifier: "Audit Type",
                        dynamicAttribute: "hello"
                    }
                ],
                messageIdentifier: "cat1"
            }
        }
        iframe.contentWindow.postMessage(postMesssageJson, url);
    }
}, false);
window.addEventListener("message", (event) => {
    if (event.data && event.data.message === "tempCategoryObjectsAdded" && event.data.messageIdentifier === "cat1") {
        const newHash = "PA-CA%23%23%23category%2F34%2Fc-o-p%3D34__0%2F*%24*eq__%5B%5BAudit%20Date%5D%5D%7B%7B--%20All%20--!%7C%23%7C--%20ALL%20VALUES%20ARE%20SELECTED%20--%7D%7D%2F*%24*eq__%5B%5BChart%20Name%5D%5D%7B%7BChart%20Types%7D%7D%2F*%24*eq__%5B%5BAudit%20Type%5D%5D%7B%7B--%20All%20--%7D%7D";
        const newUrl = url.split('#')[0] + '#' + newHash;
        iframe.src = newUrl;
    }
})
  1. Ensure the you wait for the event ‘canAddTempCategoryObjects’ before attempting to make this post message, this will ensure the data stores required are loaded

  2. Ensure the ‘type’ param is always ‘add-temp-category-objects’

  3. Each category object requires an org id, ‘dataSourceItemIdentifier '- which is the display name of the data source, and 'columnIdentifier’ - which is the display name of the object

  4. You can add an optional 4th param which is 'dynamicAttribute' which allows this to work with custom fields

  5. The ‘messageIdentifier’ is used to link the post message to the next event listener in the JS example, ensuring that you apply the correct hash to the correct category

  6. In the 2nd event listener, you are waiting for the category objects to be added before you update the URL hash, which will allow you to populate the category objects - alter the ‘newHash’ variable to match the data within your dashboard

Dev Ops (BETA) - Add support for branched content 🗣️

pi#2701

-

DevOps

As part of our drive to support infrastructure as code and dev ops ways of working we have added the ability to create a branch of a full setup including connection, categories, charts etc. Once created you can use import-export to migrate live content into this isolated environment and work on it, then extract it again later to move to production. Please see our docs for more information. We intend to build on this work so look forward to hearing feedback which will help us refine and extend this functionality.

Handling of and logging around exceptions that occur when an attempt to save a domain class to the DB fails despite passing validation 🗣️

pi#2478

-

Exceptions / Logging

In rare, unforeseen scenarios an exception can occur when saving to the Dashboard Repo even though the validation checks have been completed. Additional handling and logging have been added that will help diagnose these issues should they occur.

Recording the last updated time and the user that made the change 🗣️

pi#2472, pi#2611, pi#2612

-

-

New columns have been added to the database to track the last update time and the user responsible for modifications to data connections, categories, and charts.

JAVA Agent for Application Monitoring 🗣️

pi#2370

-

Observability

Added an option to enable Java Agent in order to collect and export telemetry data (metrics, traces, logs) for observability and performance monitoring.

Java Agent can be configured through the following environment variables:

  • PI_TOMCAT_MONITORING_ENABLED

  • PI_TOMCAT_MONITORING_OTLP_EXPORTER_ENDPOINT

  • PI_TOMCAT_MONITORING_OTLP_EXPORTER_PROTOCOL

  • PI_TOMCAT_MONITORING_SERVICE_NAME

Find more info about the new environment variables - /wiki/spaces/DEV/pages/2010218497

This can also be configured using configuration-tool gui:

Screenshot from 2024-10-15 15-45-03.png

Further information and examples of the setup can be found in the following link - Monitoring - Using Java Agent

SSH tunnel support for data connections 🗣️

pi#2461

29388

Data Connections

A new tab has been added to the data connections screen that allows you to configure an ssh tunnel.

Screenshot from 2024-10-10 09-58-07.png

It includes:

  1. A checkbox to allow you to include the SSH tunnel as part of your connection

  2. The SSH user name

  3. The tunnel that the port lives on

  4. A field for the private key (note: this will not be visible once it has already been saved, will be encrypted, and will not be visible when accessing a data connection from the API, and will be hidden in the JSON export file)

  5. A local port - you will need to set the port on the ‘details’ tab to be the same as this

  6. A target port - where your database lives on the target system

  7. A target host - here your database lives on the target system

If the checkbox is checked, and any fields are missing, you will not be allowed to save the data connection, and will be presented with a warning on the inputs which are missing.

Screenshot from 2024-10-15 10-29-26.png

If the connection is successful, and you are using the SSH tunnel, an additional indicator will be included on the details tab to confirm this.

Screenshot from 2024-10-15 10-29-12.png

You can only have one SSH tunnel per data connection. And each tunnel port must be unique to the system.

The SSH tunnel will be instantiated on data connection save, and will persist until you save it again with the box un-checked. A tunnel will also be created briefly upon introspection. All relevant tunnels will also be created on system start up.

All of these fields have been added to the API for you to set.

A thread will run in the background every 10 minutes to check for any closed connections, and re-open them again if they have failed.

You can set the ssh private key with a global variable, this is the only variable support we currently have for this feature. Only secure variables are supported.

Dynamic Driver functionality - initially only active for ClickHouse and SQLite 🗣️

pi#2617

32543

Data Connections

Initial steps into moving away from bundling all of the supported drivers and instead having many of them be downloaded only for those who are using them. This functionality has only been applied to the ClickHouse and SQLite JDBC drivers in this release.

Alongside the other driver directories there is a new directory named ‘dynamic_drivers’. This directory contains a JSON file that holds details related to the supported versions of the aforementioned drivers - here is the ClickHouse entry as an example:

image-20241023-095352.png

This block of JSON details the files that are needed when using a connection via the listed Driver Class Path - in this case it is both the JDBC JAR and an accompanying compression library. In this case, the dynamic downloading of these files occurs if they do not already exist in the ‘dynamic_drivers/com.clickhouse.jdbc.ClickHouseDriver’ directory or fail validation due to a SHA-256 mismatch:

  • On startup ONLY if you have a ClickHouse Data Connection defined

  • When you Introspect or Save a ClickHouse Data Connection

  • When you try to load a Chart that uses a ClickHouse Data Connection

  • Via a thread that runs every 3 minutes to sync defined Data Connections and their Dynamic Drivers if applicable

CHANGES

Change - Item 1 🗣️

GitLab

ZenDesk

Area

Pirana container base image upgraded to Debian bookworm

pirana#55

-

Containers

To remove several OS package vulnerabilities in the Pirana container we have updated to the latest stable Debian build - bookworm.

Change - Item 2 🗣️

GitLab

ZenDesk

Area

Spring Framework upgraded to 5.3.39 to resolve vulnerability

pi#2630

32887

Frameworks

To resolve vulnerability CVE-2024-38808 Spring Framework has been upgraded to 5.3.39

Change - Item 3 🗣️

GitLab

ZenDesk

Area

Go upgraded to 1.23.1 to resolve vulnerabilities

pi#2629, pi#2631, pi#2632,

32878, 32888, 32889

Frameworks

Go has been upgraded to version 1.23.1 to resolve the following vulnerabilities: CVE-2024-34158, CVE-2024-34155, CVE-2024-34156.

Change - Item 4 🗣️

GitLab

ZenDesk

Area

‘Beta’ mode removed from chart Drill to API

pi#2639

-

Chart Editor

Removed ‘Beta’ mode from Drill to API chart type.

Change - Item 5 🗣️

GitLab

ZenDesk

Area

‘Beta’ mode removed from Browser Single Chart Word exports

pi#2678

-

Exporting - Word

Our greatly enhanced, rebuilt word exports for single charts have been enabled by default in this release. If you experience any issue please let us know, for a limited time you can switch back to the old mode by using the beta flag OLD_WORD_EXPORT.

Change - Item 6 🗣️

GitLab

ZenDesk

Area

Organisations feature on for all

pi#2639

-

Organisations

Our multi-tenancy organisations feature has been enabled for all users. If you are unsure of the implications reach out to us for assistance.

Change - Item 7 🗣️

GitLab

ZenDesk

Area

Improved default Tomcat settings

pi#2668

-

Performance

Based on load testing we’ve updated some of our default settings for Tomcat to ones we believe will offer better out-of-the-box performance in many cases. Particularly important is the max threads setting (PI_TOMCAT_MAX_THREADS which defaults to 50), if your usage is heavily CPU-bound you may improve performance by lowering that which reduces the amount of work being handled concurrently. If your usage is heavily IO-bound; for example waiting for database queries to complete you may improve performance by raising that setting, increasing the amount of work being handled concurrently. We believe the new defaults will perform better for many people but you are are able to override those if you prefer the old or any other values.

Change - Item 8 🗣️

GitLab

ZenDesk

Area

SQLite upgraded to 3.46.1.3

pi#2617

-

JDBC Drivers

Upgraded from 3.34.2.1 to resolved some vulnerabilities. Please be aware, this Driver is a part of the ‘Dynamic Drivers’ feature added in this release.

Change - Item 9 🗣️

GitLab

ZenDesk

Area

Tomcat upgraded to 9.0.97

pi#2764

34018, 34047

Tomcat

Tomcat upgraded to 9.0.97 to resolve CVE-2024-52316 vulnerability.

Change - Item 10 🗣️

GitLab

ZenDesk

Area

MySQL driver upgraded to 8.4.0

pi#2763

34019

JDBC Drivers

MySQL JDBC driver upgraded to 8.4.0 to resolve CCVE-2023-22102 vulnerability.

Change - Item 11 🗣️

GitLab

ZenDesk

Area

Rounding issue with specific values that aren’t correctly handled by JavaScript

pi#2640

ZenDesk

All charts

Resolved an issue in regards to tooltips and data labels on charts where certain values would not correctly round up. I.e. 0.15, when 1 decimal was applied, would round to 0.1 instead of 0.2. This is due to underlying behaviour with the JavaScript language itself. This has been resolved, and any edge cases of 0.5s rounding down instead of up have been fixed.

Change - Item 12 🗣️

GitLab

ZenDesk

Area

Card chart auto scaling not working with bullet points

pi#2641

32893

Card charts

Fixed a bug where auto scaling did not work with bullet points with card charts. Previously, they would spill over the edge of the chart, now, they fit as normal.

Before:

Screenshot from 2024-10-31 17-35-28.png

After:

 

Screenshot from 2024-10-31 16-45-34.png

 

Change - Item 13 🗣️

GitLab

ZenDesk

Area

Organisation, User, and Role Variables not being replaced correctly in Schedules

scheduler#92

32186

Scheduling

The variable types listed above should now be correctly replaced in a Schedules Subject and Body fields as well as within any Reports and Exports attached to the Schedule.

Change - Item 14 🗣️

GitLab

ZenDesk

Area

Using ‘Search’ functionality in category objects panel when translations are used

pi#2662

33333

Category Objects

When applying i18n translations to category objects, the search functionality will now operate on translated values rather than the base language.

This will also apply to the chart and category names in the chart library.

Change - Item 15 🗣️

GitLab

ZenDesk

Area

X-Axis values truncating based upon non-translated values and displaying as untranslated

pi#2595

32559

Translations

The non-translated value of x-axis values on numerous charts were being used to determine whether or not the value should be truncated. In the cases were truncation occurred, the truncated version of the non-translated value would also be displayed rather than the translated value. These issues have been resolved.

Change - Item 16 🗣️

GitLab

ZenDesk

Area

Schedules ‘process_date’ being set to current time when upgrading

scheduler#69

27871

Scheduling

It was previously possible for the ‘process_date’ of a Schedule Job to be erroneously set to the current time during an upgrade from any version prior to 2023_02. The migration that could cause this has been identified, modified to resolve the issue, and a more robust fix to remove this behaviour has also been implemented (check Schema Changes section below for details)

Change - Item 17🗣️

GitLab

ZenDesk

Area

Admin Subscriber unable to edit certain permissions

pi#2722

 

Permissions

The following permissions are not relevant for a Subscription and therefore were not able to be set when creating one: ‘Can Logout', ‘Can Access Account’, and ‘Can Change Own Password'. This combined with the inability to edit permissions on other user’s that you do not have meant that a Subscribed Admin would be unable to set these values for a 'Main’ user.

Now, rather than hiding these permission when dealing with a Subscription they are shown with a warning icon and tooltip addition explaining that whilst they are not relevant to the Subscription they will dictate that Subscription’s ability to edit those permissions on Users they can manage within that Organisation.

Change - Item 17🗣️

GitLab

ZenDesk

Area

Upgrade tomcat embed library from version 9.0.89 to 9.0.91

pi#2554

32261

Tomcat

Upgraded the tomcat embed library within the dashboard from version 9.0.89 to version 9.0.91, fixing a vulnerability.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Card chart vertical alignment broken when auto scaling is turned off

pi#2576

30870

Card Charts

Previously, there was a bug where the vertical alignment option on card charts wouldn’t work if auto scaling had been turned off. This has now been fixed.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Extra white space on top category object panel

pi#2578

31662

Category Objects

Previously, there was an unnecessary amount of additional white space within the category object panel when it was pinned to the top of the category. Now, so long as you do not have one of the following filter types: Checkboxes, Images or Sliders - the panel will vertically shrink to reduce the white space.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Session not being overridden when logging in with a new user via JWT login

pi#2616

32025

Authentication

Previously, when attempting to log in with a JWT, when a already logged in with a user on the same browser, the dashboard would disregard the new attempt at logging in and retain the session of the previous user. Now, whether you’ve already logged in via a JWT or other means, as soon as you log in with a 2nd user, the 1st user’s session will be overridden.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Upgrading script on Linux

dashboard-deployment#110

 

Upgrading

Fixed upgrade_dashboard.sh script to make sure it accepts Tomcat in versions 8 or higher. This check is used to make sure the dashboard is in a valid state to be upgraded.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Data Connection import/export when tables have text color defined but not background color

pi#2657

33087

Data Connection Import Export

Resolved an issue with the data connection import/export functionality. Previously, if a table had color filters defined with text color set but no background color specified, exporting the data connection would omit this filter in the original JSON file. As a result, upon import, it would be detected as a change from the original content and it would override the existing color filter within the table.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

Importing a data connection into a child organisation

pi#2654

33176, 33192

Data Connection Import Export

Fixed an issue where the user was not able to import a data connection into a child organisation due to incorrect data source item being resolved. This now takes into consideration orgId and also user’s access to the parent data connection if the child data connection is being imported.

 

Change - Item 17🗣️

GitLab

ZenDesk

Area

Dashboard Repos default user

pi#2693

 

Data Connection

Fixed an issue where the dashboard repository user defaulted to ROOT. It has been updated to use pi_repos_use, a user with 'read' privileges only, to restrict unnecessary access to information schema tables.

Change - Item 17🗣️

GitLab

ZenDesk

Area

 

NULLS not appearing in SQL when drilled from a chart on null valueson null values

pi#2719

 

Charts

Previously, drilling down on null values in the chart did not include the null value in the SQL query, causing the chart to display all values upon drilldown. Now, when drilling into null values, the null value is correctly added to the URL hash with the appropriate operator, ensuring the SQL query resolves accurately.

 

Change - Item 17🗣️

GitLab

ZenDesk

Area

Exporting in single chart mode when theme falls back to default theme

pi#2754

 

Single Chart Export

Previously, browser single-chart exports failed when the dashboard fell back to the default theme because it couldn’t correctly resolve the logo image. This issue could occur, for instance, if the existing theme had been deleted. This has now been resolved with improved error handling, ensuring that if the default theme is used, the dashboard can successfully include the default logo in the export file.

Schema Changes

Remove ‘on update’ behaviour of pi_schedule_jobs ‘process_date’ column

scheduler#69

 

 

‘updatedAt’ and ‘updatedBy’ columns added to mis_categories, mis_defined_charts and mis_data_sources tables

pi#2472, pi#2611, pi#2612

 

 

'orgType' column added to mis_organisations

pi#2621

 

 

category_id index added to mis_definedCharts

pi#2712

 

 

schedule_id index added to pi_schedule_attachments

pi#2713

 

 

Changed the default value from ‘0000-00-00 00:00:00’ to ‘2000-01-01’ for:

  • mis_dashboard_jobs : START_DATE_TIME

  • mis_dashboard_jobs : END_DATE_TIME

  • mis_external_files : TABLES_LAST_UPDATED

migration#58

 

 

Removed timestamp “on update” behaviour from:

  • mis_external_files

  • user_gateway_sessions

  • people

  • mis_audits

  • mis_password_reset_keys

  • mis_service_watch

  • mis_dashboard_jobs

  • pi_schedule_jobs

  • mis_tarpit

  • pi_rate_limit_record

  • mis_defined_charts

  • passwords

  • users

migration#58

 

 

  • No labels