Skip to content

Make Dash applications from a user-friendly config file 📖 🐍

License

Notifications You must be signed in to change notification settings

JosteinGj/webviz-config

 
 

Repository files navigation

Democratizing Python web applications

Total alerts Language grade: Python


Writing a Dash web application gives a lot of flexibility, however, it also requires 🐍 Python knowledge from the person setting it up.

Webviz is a MIT-licensed configuration layer on top of Dash, which encourages making reusable components and dashboards, which can then be added/removed when creating an application using a short yaml configuration file.

This Python package, webviz-config, is the core plugin framework. For a real example repository using this plugin system, see e.g. webviz-subsurface.

These are the main user groups targeted by Webviz:

  • You do not know Python, and only want to add different predefined dashboards or visualizations/components in a certain order and/or on different pages in the application. Optionally with some text and mathematical equations (that you provide) inbetween the dashboards, explaining what the user is looking at.
  • You know Python, and want to create generic or specialized dashboards you or other users can reuse by simply asking for it in the Webviz configuration file. This can be done without knowing JavaScript (see also Dash for more information).
  • You know React, and want to create highly specialized visualization which Python or pure config-file users can reuse.

Webviz will create web applications with very 🔒 strict security headers and CSP settings, giving an rating of A+ on e.g. Mozilla observatory. It also facilitates a 🐳 Docker setup, where the Python code can be ran completely unpriviliged in a sandbox (both with respect to file system access and network communication).

Example configuration file and information about the standard plugins can be seen in the documentation.

The workflow can be summarized as this:

  1. The user provides a 📖 configuration file following the yaml standard.
  2. Webviz reads the configuration file and automatically writes the corresponding 🐍 Python code.
  3. The created application can be viewed locally, or deployed using 🐳 Docker to a cloud provider. Both out of the box.

technical_drawing


Installation

The simplest way of installing webviz-config is to run

pip install webviz-config

If you want to download the latest source code and install it manually you can run

git clone [email protected]:equinor/webviz-config.git
cd ./webviz-config
pip install .

Usage

After installation, there is a console script named webviz available. You can test the installation by using the provided test configuration file,

webviz build ./examples/basic_example.yaml

Without any additional arguments, this will

  1. create a temporary folder
  2. write the Python application code to that folder
  3. start a localhost server

When stopping the server (press CTRL+C at any time), the temporary folder is deleted.

The optional arguments can be seen when running

webviz --help

For example will

webviz build ./examples/basic_example.yaml --portable ./my_portable_app

create a portable instance (with corresponding Dockerfile) and store it in the provided folder.

A feature in Dash is hot reload. When the Dash Python code file is saved, the content seen in the web browser is automatically reloaded (no need for localhost server restart). This feature is passed on to the Webviz configuration utility, meaning that if the user runs

webviz build ./examples/basic_example.yaml

and then modifies ./examples/basic_example.yaml while the Webviz application is still running, a hot reload will occur.

For quick local analysis, webviz-config uses https and runs on localhost. In order to create your personal https certificate (only valid for localhost), run

webviz certificate --auto-install

Certificate installation guidelines will be given when running the command.

Creating new plugins

If you are interested in creating new plugins which can be configured through the configuration file, take a look at the contribution guide.

To quickly get started, we recommend using the corresponding cookiecutter template.

License

webviz-config is, with a few exceptions listed below, MIT licensed.

About

Make Dash applications from a user-friendly config file 📖 🐍

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 90.8%
  • CSS 9.2%