Skip to content

A set of code analysis and transform scripts to further the goals of integrations and Kibana visualizations teams

Notifications You must be signed in to change notification settings

elastic/visualizations_integrations_tools

Repository files navigation

visualizations integrations tools

This package currently has several functionalities:

  • Analyzes the usage of legacy visualization types in the beats and integrations dashboard and indexes them into an Elasticsearch instance.
  • Inlines the visualizations in a given directory as "by values" panels
  • Tracks the usage of @elastic/charts vs the Lens embeddable in the Kibana code base

Prep

  • Have locally installed node (tested with 16.14.2)
  • Init submodules using git submodule update --init --recursive
  • Install dependencies using yarn

Legacy vis analyzer usage

  • Install Go
  • Run ELASTICSEARCH_URL="<elasticsearch connection string>" go run index.go

Code analyzer usage

  • Run ES="<elasticsearch connection string>" node index_kibana.js

Inliner usage

The inliner takes all "by reference" visualizations in a given directory, uses the provided running Kibana instance to migrate them to the latest version, migrates the dashboard saved object as well, then transforms the by-reference visualizations into by-value panels, deletes the visualization json files and updates the dashboard json files.

Important notes:

  • Using the inliner script will make the dashboards incompatible with earlier versions of the stack e.g., if it has been run with a stack version 8.2, then the new dashboard JSON files will only work on version 8.2 and above.

  • For old dashboards (prior to 7.10), some "agg based" visualizations might break if a target version of 7.17 or 8.0 is used. In these cases, please use at least a stack version of 8.1

  • Run KIBANA="<kibana connection string>" node inline.js <path to kibana folder> (e.g. ./integrations/packages/system/kibana/)

    • The Kibana connection string has to include the password (for instances with security enabled) and the base path (for instances with configured base path), for example KIBANA="http://elastic:changeme@localhost:5601/mgp"
    • You may need to run export NODE_TLS_REJECT_UNAUTHORIZED=0 if you are connecting to Kibana over TLS (https)
  • Review changes in the submodule repo

    • This review should include loading the dashboard into an instance with data to make sure everything is displayed properly
  • If everything works fine, create a PR

About

A set of code analysis and transform scripts to further the goals of integrations and Kibana visualizations teams

Resources

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published