<!-- START doctoc generated TOC please keep comment here to allow auto update -->
<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*
- [Overview](#overview)
- [What is this and why did you make it?](#what-is-this-and-why-did-you-make-it)
- [How did you make this?](#how-did-you-make-this)
- [What's it look like?](#whats-it-look-like)
- [Features](#features)
- [Quick Start](#quick-start)
- [Step 1 - Install](#step-1---install)
- [Step 2 - Create your configuration file](#step-2---create-your-configuration-file)
- [Step 3 - Launch!](#step-3---launch)
- [Usage](#usage)
- [Building the app](#building-the-app)
- [Building the installer](#building-the-installer)
- [Developing the app](#developing-the-app)
- [Configuration File](#configuration-file)
- [Configuration File - Defaults](#app-defaults)
- [Storing credentials - OS Keyring](#storing-credentials---os-keyring)
- [Windows](#windows)
- [Lessons](#lessons)
- [Jinja Templating](#jinja-templating)
- [WebTerminal](#webterminal)
- [Appendix](#appendix)
- [Github Pages](#github-pages)
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
<a name="top"></a>
===================
Bert's Dashboard
===================
<a name="top"></a>
<a name="overview"></a>
# Overview
<a name="what-is-this-and-why-did-you-make-it"></a>
## What is this and why did you make it?
This is my attempt at creating a sort of life dashboard for myself.
The aim is to make it as customizable as possible in as easy a way as possible.
This project is the successor to [bert.bill](https://github.com/berttejeda/bert.bill).
As such, the interactive lesson features from that project have been ported over.
As with the previous project, the interactive lesson feature was inspired by [Katacoda](https://www.katacoda.com/).
And, as with the previous iteration of my work, instead of a website with learning examples, you have a web app that creates hands-on lessons from markdown-formatted, jina-templated documents,
complete with a web terminal for interactive practice.
<a name="how-did-you-make-this"></a>
## How did you make this?
- The UI
- [ReactJS](https://reactjs.org/) for the UI framework
- [TailwindCSS](https://tailwindcss.com/) for easier CSS
- [Mosaic Lite Admin Dashboard](https://github.com/cruip/tailwind-dashboard-template) for the UI layout
- [React Redux](https://react-redux.js.org/) for session state management
- The API
- [Python Flask](https://flask.palletsprojects.com/en/2.1.x/)
<a name="whats-it-look-like"></a>
## What's it look like?
Here's a screenshot of the dashboard:
![dashboard](res/dashboard.png)
Here's a screenshot of the Knowledgebase layout:
![knowledgebase](res/knowledgebase.png)
Here's a screenshot of an interactive lesson:
![lesson](res/lesson.gif)
<a name="features"></a>
# Features
* The dashboard cards can be configured via the dashboard configration file: [etc/dashboard.yaml](etc/dashboard.yaml).
* The knowledgebase catalog is configured via the lessons configuration file: [etc/lessons.yaml](etc/lessons.yaml)
* [Lessons](#Lessons) are Markdown-formatted files
1. First rendered as [jinja](https://jinja.palletsprojects.com/en/3.0.x/) templates
1. Then rendered as HTML<br />
* Web-based terminals via [xtermjs](https://github.com/xtermjs/xterm.js/) component<br />
See section on [WebTerminal](#webterminal)
* Local Webterminal websocket is also available
* Utilizes [spyder-terminal](https://github.com/spyder-ide/spyder-terminal) component
* You can practice the lesson material with your own OS/system
* Simply **click** on a command, and it will be executed in the underlying shell via web terminal!
* Default shell is bash (for now)
<a name="quick-start"></a>
# Quick Start
<a name="step-1---install"></a>
## Step 1 - Install
**Note** You'll need a minimum python version of 3.7 for the app to work
You can install the app in any of the following ways:
* Install pip package from pypi.org: `pip install btdashboard`
* Install pip package from locally cloned repo: <br />
```
git clone -b ${REMOTE_BRANCH-main} https://github.com/berttejeda/bert.dashboard.git
cd bert.dashboard
nvm install
npm config set timeout 100000
npm install -g parcel yarn
yarn install --frozen-lockfile --network-timeout 100000
yarn compile:ui:dev
pip install .
```
* From the above, [nvm](https://github.com/nvm-sh/nvm) is used to install
[nodejs](https://nodejs.org/en/), and we use [yarn](https://yarnpkg.com/) for installing package dependencies,
and [parcel](https://parceljs.org/) for the web build.
* [.nvmrc](.nvmrc) is set to use node v16.5.0
* To install from the locally cloned repo in development mode, do the same as above, but with `pip install -e .` instead
* You can also install the pip package directly from git repo `pip install git+http://www.github.com/berttejeda/bert.dashboard.git`,<br />
but you'll need to obtain the HTML assets and point the app to them, see the [Appendix](#appendix)
<a name="step-2---create-your-configuration-file"></a>
## Step 2 - Adjust your configuration files as needed
Under the [etc](etc) directory, you'll find the following configuration files:
- [app.yaml](etc/app.yaml)
- [dashboard.yaml](etc/dashboard.yaml)
- [lessons.yaml](etc/lessons.yaml)
- [sidebar.yaml](etc/sidebar.yaml)
If not specified, the app will use the configuration files above.
TODO: Documentation on configuration file options.
<a name="step-3---launch"></a>
## Step 3 - Launch!
* If installed via pip, launch the app from your terminal: `btdashboard`
* If installed via pip as a [development instance](#step-1---install), launch via python with `python ./btdashboard/app.py`<br />
<a name="usage"></a>
### Usage
Usage information can be obtained by invoking the executable with the `--help` flag, as with: `btdashboard --help` or `python ./btdashboard/app.py --help`.
The help output should be similar to:
```
usage: btdashboard [-h] [--username USERNAME] [--password PASSWORD]
[--lesson-url LESSON_URL]
[--static-assets-folder STATIC_ASSETS_FOLDER] [--app-id APP_ID]
[--app-user APP_USER] [--app-config-file APP_CONFIG_FILE]
[--lessons-config-file LESSONS_CONFIG_FILE]
[--dashboard-config-file DASHBOARD_CONFIG_FILE]
[--sidebar-config-file SIDEBAR_CONFIG_FILE]
[--cors-origin CORS_ORIGIN] [--logfile-path LOGFILE_PATH]
[--host-address HOST_ADDRESS] [--port PORT]
[--webterminal-listen-host WEBTERMINAL_LISTEN_HOST]
[--webterminal-listen-port WEBTERMINAL_LISTEN_PORT]
[--webterminal-host WEBTERMINAL_HOST]
[--webterminal-shell WEBTERMINAL_SHELL]
[--webterminal-shell-command WEBTERMINAL_SHELL_COMMAND]
[--open-browser-delay OPEN_BROWSER_DELAY]
[--logfile-write-mode {a,w}] [--config-file-templatized]
[--api-only] [--webterminal-only] [--all-in-one] [--no-browser]
[--debug] [--no-verify-tls] [--no-render-markdown]
[run]
Bert's Dashboard
positional arguments:
run
optional arguments:
-h, --help show this help message and exit
--username USERNAME, -U USERNAME
Username, if the URL requires authentication
--password PASSWORD, -P PASSWORD
Password, if the URL requires authentication
--lesson-url LESSON_URL, -url LESSON_URL
The URL for the lesson definition
--static-assets-folder STATIC_ASSETS_FOLDER, -S STATIC_ASSETS_FOLDER
Explicity specify the folder for static HTML assets
--app-id APP_ID, -id APP_ID
Specify the App's Identifier
--app-user APP_USER, -iu APP_USER
Specify the App's User
--app-config-file APP_CONFIG_FILE, -cfa APP_CONFIG_FILE
Path to app configuration file
--lessons-config-file LESSONS_CONFIG_FILE, -cfl LESSONS_CONFIG_FILE
Path to lessons configuration file
--dashboard-config-file DASHBOARD_CONFIG_FILE, -cfd DASHBOARD_CONFIG_FILE
Path to dashboard configuration file
--sidebar-config-file SIDEBAR_CONFIG_FILE, -cfs SIDEBAR_CONFIG_FILE
Path to sidebar configuration file
--cors-origin CORS_ORIGIN, -o CORS_ORIGIN
Override CORS origin pattern
--logfile-path LOGFILE_PATH, -L LOGFILE_PATH
Path to logfile
--host-address HOST_ADDRESS, -l HOST_ADDRESS
Override default host address
--port PORT, -p PORT Override default listening port
--webterminal-listen-host WEBTERMINAL_LISTEN_HOST, -wlh WEBTERMINAL_LISTEN_HOST
Override default listening host address for the
webterminal socket
--webterminal-listen-port WEBTERMINAL_LISTEN_PORT, -wlp WEBTERMINAL_LISTEN_PORT
Override default listening port for the webterminal
socket
--webterminal-host WEBTERMINAL_HOST, -wh WEBTERMINAL_HOST
Override the webterminal socket address to which the
UI initially connects
--webterminal-shell WEBTERMINAL_SHELL, -wS WEBTERMINAL_SHELL
Override default shell for the webterminal session
--webterminal-shell-command WEBTERMINAL_SHELL_COMMAND, -wSc WEBTERMINAL_SHELL_COMMAND
Override default shell command for the webterminal
session
--open-browser-delay OPEN_BROWSER_DELAY, -bd OPEN_BROWSER_DELAY
Override default time in seconds to delay when opening
the system's web browser
--logfile-write-mode {a,w}, -w {a,w}
File mode when writing to log file, 'a' to append, 'w'
to overwrite
--config-file-templatized, -fT
Render configuration via jinja2 templating
--api-only Don't serve static assets, only start API
--webterminal-only Don't serve static assets or start API, only invoke
Webterminal Websocket
--all-in-one, -aio Run the shell websocket process alongside app
--no-browser, -nobrowser
If applicable, don't open the web browser
--debug
--no-verify-tls, -notls
Verify SSL cert when downloading web content
--no-render-markdown, -nomarkdown
```
<a name="building-the-app"></a>
# Starting the development instance of the app
* Install Python 3.7+
* Install this project's required version of [nodejs](https://nodejs.org/en/) (v18.11.0): `nvm install`<br />
Note that this command implicitly reads the local [.nvmrc](.nvmrc)
* Install yarn & parcel: `npm install -g yarn parcel`
* Install node modules: `yarn install --frozen-lockfile`
* Install python prerequisites: `pip3 install -e .`
* Launch the development instance of the UI: `yarn start:dev:ui`<br />
* Launch the api and local webterminal process: `yarn start:api`<br />
Under the hood, this launches `python btdashboard/app.py --debug --api-only -aio`,
see [package.json](package.json)
[Back to Top](#top)
<a name="developing-the-app"></a>
# Developing the app
Starting the development instance of the UI will cause it to reload
whenever you make changes to any of the UI
files under the [src](src) folder.
This functionality helps increase UI development velocity.
I have not yet implemented similar functionality for the API files under [btdashboard](btdashboard),
so you'll have to kill and reload the API whenever you make changes.
<a name="app-defaults"></a>
# App Defaults
If no settings can be found, the app will resort to its defaults,
see [defaults.py](btdashboard/defaults.py)
As such, the defaults settings call for the import of an external config, hosted in my [bert.lessons](https://github.com/berttejeda/bert.lessons) repo: <br />
see [bert.lessons/lessons.yaml](https://raw.githubusercontent.com/berttejeda/bert.lessons/main/lessons.yaml)
This external config is where I am listing all of my (mostly) hand-crafted tutorials and learning materials.
<a name="lessons"></a>
# Lessons
As already mentioned, lessons are Markdown-formatted
files interpreted as [jinja](https://jinja.palletsprojects.com/en/3.0.x/)
templates.
These are defined in the [lessons.yaml](etc/lessons.yaml) configuration file.
You can override the location of this file via the appropriate cli parameter.
Review the `--help` output for details.
## TODO
Implement per-lesson credentials
<a name="jinja-templating"></a>
## Jinja Templating
To add to the templating goodies provided by the Jinja library,
I've exposed the OS Environment via the _environment_ key of a
special variable named _session_.
This means you should be able to dynamically load any OS-level environment
variable into your lesson material, e.g.
```markdown
# Overview
{% set USERNAME = session['environment'].get('USER') or session['environment'].get('USERNAME') %}
Hello {{ USERNAME }}, welcome to Lesson 1
```
<a name="webterminal"></a>
# WebTerminal
Every lesson rendered through the app includes a web-based terminal
emulator component that allows for practicing the lesson material.
These web terminals are embedded in the user interface,
available at its footer.
As mentioned before, the underlying technology for these web
terminals is [xterm.js](https://github.com/xtermjs/xterm.js/).
As such, the xterm.js component requires a websocket to a bash process.
By [default](btdashboard/defaults.py), the bert.dashboard web app
will attempt to connect to a local instance of the websocket via _http://127.0.0.1:10001/_.
You can get this websocket running either by:
- Installing btdashboard with `pip install btdashboard` and running `btdashboard -aio` or by installing all requirements and running `python btdashboard/app.py -aio`<br />
Doing so will launch a local websocket that forwards keystrokes to a bash process on your system
<a name="appendix"></a>
# Appendix
<a name="configuration-files"></a>
## Configuration files
Important note about the configuration files:
- Environment variable interpolation is supported, e.g.<br />
`user: ${USER}`, <br />
You can see this in use in the [app](etc/app.yaml) config file
<a name="github-pages"></a>
## Github Pages
If you want to publish the assets from your own fork of this repo:
1. Fork this repo
1. Configure [Github Pages](https://docs.github.com/en/pages/quickstart)
1. Run `yarn install` to initialize the project requirements
1. Run `yarn deploy` to publish the static assets to the `gh-pages` branch
Raw data
{
"_id": null,
"home_page": "https://github.com/berttejeda/bert.dashboard",
"name": "btdashboard",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": "",
"keywords": "yaml,configuration,config,file,python,settings",
"author": "Engelbert Tejeda",
"author_email": "berttejeda@gmail.com",
"download_url": "https://files.pythonhosted.org/packages/69/36/c0ff094e7afb4b326f8accc7519192369b539a263a2b4383fa0b06092028/btdashboard-1.1.0.tar.gz",
"platform": null,
"description": "<!-- START doctoc generated TOC please keep comment here to allow auto update -->\n<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->\n**Table of Contents** *generated with [DocToc](https://github.com/thlorenz/doctoc)*\n\n- [Overview](#overview)\n - [What is this and why did you make it?](#what-is-this-and-why-did-you-make-it)\n - [How did you make this?](#how-did-you-make-this)\n - [What's it look like?](#whats-it-look-like)\n- [Features](#features)\n- [Quick Start](#quick-start)\n - [Step 1 - Install](#step-1---install)\n - [Step 2 - Create your configuration file](#step-2---create-your-configuration-file)\n - [Step 3 - Launch!](#step-3---launch)\n - [Usage](#usage)\n- [Building the app](#building-the-app)\n- [Building the installer](#building-the-installer)\n- [Developing the app](#developing-the-app)\n- [Configuration File](#configuration-file)\n - [Configuration File - Defaults](#app-defaults)\n - [Storing credentials - OS Keyring](#storing-credentials---os-keyring)\n - [Windows](#windows)\n- [Lessons](#lessons)\n - [Jinja Templating](#jinja-templating)\n- [WebTerminal](#webterminal)\n- [Appendix](#appendix)\n - [Github Pages](#github-pages)\n\n<!-- END doctoc generated TOC please keep comment here to allow auto update -->\n\n<a name=\"top\"></a>\n===================\nBert's Dashboard\n===================\n\n<a name=\"top\"></a>\n<a name=\"overview\"></a>\n# Overview\n\n<a name=\"what-is-this-and-why-did-you-make-it\"></a> \n## What is this and why did you make it? \n\nThis is my attempt at creating a sort of life dashboard for myself.\n\nThe aim is to make it as customizable as possible in as easy a way as possible.\n\nThis project is the successor to [bert.bill](https://github.com/berttejeda/bert.bill).\n\nAs such, the interactive lesson features from that project have been ported over.\n\nAs with the previous project, the interactive lesson feature was inspired by [Katacoda](https://www.katacoda.com/).\nAnd, as with the previous iteration of my work, instead of a website with learning examples, you have a web app that creates hands-on lessons from markdown-formatted, jina-templated documents, \ncomplete with a web terminal for interactive practice.\n\n<a name=\"how-did-you-make-this\"></a> \n## How did you make this?\n\n- The UI\n - [ReactJS](https://reactjs.org/) for the UI framework\n - [TailwindCSS](https://tailwindcss.com/) for easier CSS\n - [Mosaic Lite Admin Dashboard](https://github.com/cruip/tailwind-dashboard-template) for the UI layout\n - [React Redux](https://react-redux.js.org/) for session state management\n- The API \n - [Python Flask](https://flask.palletsprojects.com/en/2.1.x/)\n\n<a name=\"whats-it-look-like\"></a> \n## What's it look like?\n\nHere's a screenshot of the dashboard:\n\n![dashboard](res/dashboard.png)\n\nHere's a screenshot of the Knowledgebase layout:\n\n![knowledgebase](res/knowledgebase.png)\n\nHere's a screenshot of an interactive lesson:\n\n![lesson](res/lesson.gif)\n\n<a name=\"features\"></a>\n# Features\n\n* The dashboard cards can be configured via the dashboard configration file: [etc/dashboard.yaml](etc/dashboard.yaml).\n* The knowledgebase catalog is configured via the lessons configuration file: [etc/lessons.yaml](etc/lessons.yaml)\n * [Lessons](#Lessons) are Markdown-formatted files\n 1. First rendered as [jinja](https://jinja.palletsprojects.com/en/3.0.x/) templates\n 1. Then rendered as HTML<br />\n* Web-based terminals via [xtermjs](https://github.com/xtermjs/xterm.js/) component<br />\n See section on [WebTerminal](#webterminal)\n* Local Webterminal websocket is also available\n * Utilizes [spyder-terminal](https://github.com/spyder-ide/spyder-terminal) component\n * You can practice the lesson material with your own OS/system\n * Simply **click** on a command, and it will be executed in the underlying shell via web terminal!\n * Default shell is bash (for now)\n\n<a name=\"quick-start\"></a>\n# Quick Start\n \n<a name=\"step-1---install\"></a>\n## Step 1 - Install\n\n**Note** You'll need a minimum python version of 3.7 for the app to work\n\nYou can install the app in any of the following ways:\n\n* Install pip package from pypi.org: `pip install btdashboard`\n* Install pip package from locally cloned repo: <br />\n```\ngit clone -b ${REMOTE_BRANCH-main} https://github.com/berttejeda/bert.dashboard.git\ncd bert.dashboard\nnvm install\nnpm config set timeout 100000\nnpm install -g parcel yarn\nyarn install --frozen-lockfile --network-timeout 100000\nyarn compile:ui:dev\npip install .\n```\n * From the above, [nvm](https://github.com/nvm-sh/nvm) is used to install \n [nodejs](https://nodejs.org/en/), and we use [yarn](https://yarnpkg.com/) for installing package dependencies,\n and [parcel](https://parceljs.org/) for the web build.\n * [.nvmrc](.nvmrc) is set to use node v16.5.0\n * To install from the locally cloned repo in development mode, do the same as above, but with `pip install -e .` instead\n* You can also install the pip package directly from git repo `pip install git+http://www.github.com/berttejeda/bert.dashboard.git`,<br />\n but you'll need to obtain the HTML assets and point the app to them, see the [Appendix](#appendix)\n\n<a name=\"step-2---create-your-configuration-file\"></a>\n## Step 2 - Adjust your configuration files as needed\n\nUnder the [etc](etc) directory, you'll find the following configuration files:\n\n- [app.yaml](etc/app.yaml)\n- [dashboard.yaml](etc/dashboard.yaml)\n- [lessons.yaml](etc/lessons.yaml)\n- [sidebar.yaml](etc/sidebar.yaml)\n\nIf not specified, the app will use the configuration files above.\n\nTODO: Documentation on configuration file options.\n\n<a name=\"step-3---launch\"></a>\n## Step 3 - Launch!\n\n* If installed via pip, launch the app from your terminal: `btdashboard`\n* If installed via pip as a [development instance](#step-1---install), launch via python with `python ./btdashboard/app.py`<br />\n\n<a name=\"usage\"></a>\n### Usage\n\nUsage information can be obtained by invoking the executable with the `--help` flag, as with: `btdashboard --help` or `python ./btdashboard/app.py --help`.\n\nThe help output should be similar to:\n\n```\nusage: btdashboard [-h] [--username USERNAME] [--password PASSWORD]\n [--lesson-url LESSON_URL]\n [--static-assets-folder STATIC_ASSETS_FOLDER] [--app-id APP_ID]\n [--app-user APP_USER] [--app-config-file APP_CONFIG_FILE]\n [--lessons-config-file LESSONS_CONFIG_FILE]\n [--dashboard-config-file DASHBOARD_CONFIG_FILE]\n [--sidebar-config-file SIDEBAR_CONFIG_FILE]\n [--cors-origin CORS_ORIGIN] [--logfile-path LOGFILE_PATH]\n [--host-address HOST_ADDRESS] [--port PORT]\n [--webterminal-listen-host WEBTERMINAL_LISTEN_HOST]\n [--webterminal-listen-port WEBTERMINAL_LISTEN_PORT]\n [--webterminal-host WEBTERMINAL_HOST]\n [--webterminal-shell WEBTERMINAL_SHELL]\n [--webterminal-shell-command WEBTERMINAL_SHELL_COMMAND]\n [--open-browser-delay OPEN_BROWSER_DELAY]\n [--logfile-write-mode {a,w}] [--config-file-templatized]\n [--api-only] [--webterminal-only] [--all-in-one] [--no-browser]\n [--debug] [--no-verify-tls] [--no-render-markdown]\n [run]\n\nBert's Dashboard\n\npositional arguments:\n run\n\noptional arguments:\n -h, --help show this help message and exit\n --username USERNAME, -U USERNAME\n Username, if the URL requires authentication\n --password PASSWORD, -P PASSWORD\n Password, if the URL requires authentication\n --lesson-url LESSON_URL, -url LESSON_URL\n The URL for the lesson definition\n --static-assets-folder STATIC_ASSETS_FOLDER, -S STATIC_ASSETS_FOLDER\n Explicity specify the folder for static HTML assets\n --app-id APP_ID, -id APP_ID\n Specify the App's Identifier\n --app-user APP_USER, -iu APP_USER\n Specify the App's User\n --app-config-file APP_CONFIG_FILE, -cfa APP_CONFIG_FILE\n Path to app configuration file\n --lessons-config-file LESSONS_CONFIG_FILE, -cfl LESSONS_CONFIG_FILE\n Path to lessons configuration file\n --dashboard-config-file DASHBOARD_CONFIG_FILE, -cfd DASHBOARD_CONFIG_FILE\n Path to dashboard configuration file\n --sidebar-config-file SIDEBAR_CONFIG_FILE, -cfs SIDEBAR_CONFIG_FILE\n Path to sidebar configuration file\n --cors-origin CORS_ORIGIN, -o CORS_ORIGIN\n Override CORS origin pattern\n --logfile-path LOGFILE_PATH, -L LOGFILE_PATH\n Path to logfile\n --host-address HOST_ADDRESS, -l HOST_ADDRESS\n Override default host address\n --port PORT, -p PORT Override default listening port\n --webterminal-listen-host WEBTERMINAL_LISTEN_HOST, -wlh WEBTERMINAL_LISTEN_HOST\n Override default listening host address for the\n webterminal socket\n --webterminal-listen-port WEBTERMINAL_LISTEN_PORT, -wlp WEBTERMINAL_LISTEN_PORT\n Override default listening port for the webterminal\n socket\n --webterminal-host WEBTERMINAL_HOST, -wh WEBTERMINAL_HOST\n Override the webterminal socket address to which the\n UI initially connects\n --webterminal-shell WEBTERMINAL_SHELL, -wS WEBTERMINAL_SHELL\n Override default shell for the webterminal session\n --webterminal-shell-command WEBTERMINAL_SHELL_COMMAND, -wSc WEBTERMINAL_SHELL_COMMAND\n Override default shell command for the webterminal\n session\n --open-browser-delay OPEN_BROWSER_DELAY, -bd OPEN_BROWSER_DELAY\n Override default time in seconds to delay when opening\n the system's web browser\n --logfile-write-mode {a,w}, -w {a,w}\n File mode when writing to log file, 'a' to append, 'w'\n to overwrite\n --config-file-templatized, -fT\n Render configuration via jinja2 templating\n --api-only Don't serve static assets, only start API\n --webterminal-only Don't serve static assets or start API, only invoke\n Webterminal Websocket\n --all-in-one, -aio Run the shell websocket process alongside app\n --no-browser, -nobrowser\n If applicable, don't open the web browser\n --debug\n --no-verify-tls, -notls\n Verify SSL cert when downloading web content\n --no-render-markdown, -nomarkdown\n```\n\n<a name=\"building-the-app\"></a>\n# Starting the development instance of the app\n\n* Install Python 3.7+\n* Install this project's required version of [nodejs](https://nodejs.org/en/) (v18.11.0): `nvm install`<br />\n Note that this command implicitly reads the local [.nvmrc](.nvmrc)\n* Install yarn & parcel: `npm install -g yarn parcel`\n* Install node modules: `yarn install --frozen-lockfile`\n* Install python prerequisites: `pip3 install -e .`\n* Launch the development instance of the UI: `yarn start:dev:ui`<br />\n* Launch the api and local webterminal process: `yarn start:api`<br />\n Under the hood, this launches `python btdashboard/app.py --debug --api-only -aio`, \n see [package.json](package.json)\n\n[Back to Top](#top)\n<a name=\"developing-the-app\"></a>\n# Developing the app\n\nStarting the development instance of the UI will cause it to reload\nwhenever you make changes to any of the UI \nfiles under the [src](src) folder.\n\nThis functionality helps increase UI development velocity.\n\nI have not yet implemented similar functionality for the API files under [btdashboard](btdashboard),\nso you'll have to kill and reload the API whenever you make changes.\n\n<a name=\"app-defaults\"></a>\n# App Defaults\n\nIf no settings can be found, the app will resort to its defaults, \nsee [defaults.py](btdashboard/defaults.py) \n\nAs such, the defaults settings call for the import of an external config, hosted in my [bert.lessons](https://github.com/berttejeda/bert.lessons) repo: <br />\nsee [bert.lessons/lessons.yaml](https://raw.githubusercontent.com/berttejeda/bert.lessons/main/lessons.yaml)\n\nThis external config is where I am listing all of my (mostly) hand-crafted tutorials and learning materials.\n\n<a name=\"lessons\"></a>\n# Lessons\n\nAs already mentioned, lessons are Markdown-formatted \nfiles interpreted as [jinja](https://jinja.palletsprojects.com/en/3.0.x/) \ntemplates.\n\nThese are defined in the [lessons.yaml](etc/lessons.yaml) configuration file.\n\nYou can override the location of this file via the appropriate cli parameter.\n\nReview the `--help` output for details.\n\n## TODO \n\nImplement per-lesson credentials\n\n<a name=\"jinja-templating\"></a>\n## Jinja Templating\n\nTo add to the templating goodies provided by the Jinja library,\nI've exposed the OS Environment via the _environment_ key of a\nspecial variable named _session_.\n\nThis means you should be able to dynamically load any OS-level environment \nvariable into your lesson material, e.g. \n\n```markdown\n# Overview\n\n{% set USERNAME = session['environment'].get('USER') or session['environment'].get('USERNAME') %}\nHello {{ USERNAME }}, welcome to Lesson 1\n```\n\n<a name=\"webterminal\"></a>\n# WebTerminal\n\nEvery lesson rendered through the app includes a web-based terminal \nemulator component that allows for practicing the lesson material.\n\nThese web terminals are embedded in the user interface, \navailable at its footer.\n\nAs mentioned before, the underlying technology for these web \nterminals is [xterm.js](https://github.com/xtermjs/xterm.js/).\n\nAs such, the xterm.js component requires a websocket to a bash process.\n\nBy [default](btdashboard/defaults.py), the bert.dashboard web app \nwill attempt to connect to a local instance of the websocket via _http://127.0.0.1:10001/_.\n\nYou can get this websocket running either by:\n\n- Installing btdashboard with `pip install btdashboard` and running `btdashboard -aio` or by installing all requirements and running `python btdashboard/app.py -aio`<br />\n Doing so will launch a local websocket that forwards keystrokes to a bash process on your system\n\n<a name=\"appendix\"></a>\n# Appendix\n\n<a name=\"configuration-files\"></a>\n## Configuration files\n\nImportant note about the configuration files:\n\n- Environment variable interpolation is supported, e.g.<br />\n `user: ${USER}`, <br />\n You can see this in use in the [app](etc/app.yaml) config file\n\n<a name=\"github-pages\"></a>\n## Github Pages\n\nIf you want to publish the assets from your own fork of this repo:\n\n1. Fork this repo\n1. Configure [Github Pages](https://docs.github.com/en/pages/quickstart) \n1. Run `yarn install` to initialize the project requirements\n1. Run `yarn deploy` to publish the static assets to the `gh-pages` branch\n",
"bugtrack_url": null,
"license": "",
"summary": "Bert's Dashboard",
"version": "1.1.0",
"project_urls": {
"Homepage": "https://github.com/berttejeda/bert.dashboard"
},
"split_keywords": [
"yaml",
"configuration",
"config",
"file",
"python",
"settings"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "99c12222ee12a2a031010763769eb8a00d32ae6be974cb7252c371bc4b868c37",
"md5": "fb380c5bafc4cc637c64f2778f2272ea",
"sha256": "1f41469780802294f289aedc14345ada5d6181c1908499db71d0ecbab3fddcb5"
},
"downloads": -1,
"filename": "btdashboard-1.1.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "fb380c5bafc4cc637c64f2778f2272ea",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 4444791,
"upload_time": "2023-11-09T05:21:25",
"upload_time_iso_8601": "2023-11-09T05:21:25.647075Z",
"url": "https://files.pythonhosted.org/packages/99/c1/2222ee12a2a031010763769eb8a00d32ae6be974cb7252c371bc4b868c37/btdashboard-1.1.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "6936c0ff094e7afb4b326f8accc7519192369b539a263a2b4383fa0b06092028",
"md5": "a9be35304461b3549c4b519e96707002",
"sha256": "6bc3cfdc808c2dc868de3e1cce89662cbc0dc6aa32707f3818038b54094a5033"
},
"downloads": -1,
"filename": "btdashboard-1.1.0.tar.gz",
"has_sig": false,
"md5_digest": "a9be35304461b3549c4b519e96707002",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 22148650,
"upload_time": "2023-11-09T05:21:47",
"upload_time_iso_8601": "2023-11-09T05:21:47.414393Z",
"url": "https://files.pythonhosted.org/packages/69/36/c0ff094e7afb4b326f8accc7519192369b539a263a2b4383fa0b06092028/btdashboard-1.1.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-11-09 05:21:47",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "berttejeda",
"github_project": "bert.dashboard",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "btdashboard"
}