Project Architecture
SQLSeal is an Obsidian Plugin written in TypeScript. We use the following tech stack:
- PNPM
- TypeScript
- SQL.JS: SQLite compiled into WebAssembly
- AbsurdSQL to persist SQLite page blocks into IndexedDB and not keep the database in the memory
- AGGrid - grid solution, default table renderer
- Node-SQL-Parser - to parse SQL and modify table names before sending it to SQLite
- Comlink - for Webworker communication abstraction
Architecture overview
On the high level SQLSeal uses SQLite and communicates with it using WebWorker. The main process calls that Web Worker (using Comlink as a wrapper to abstract away complexity of postMessage and wrap it into class methods returning promises instead). The database is setup in a way that individual blocks are being persisted into the IndexedDB. Thanks to that even if the database grows, the memory footprint should stay relatively low.
Extensible Architecture
The plugin is designed with extensible architecture in mind. I want to encourage people to write related plugins that expand functionality of SQLSeal or use it as the storage. Below I describe my plans. Some interfaces are already in place, some will be implemented at the later stage.
Adding new Renderers
Stage
Current Stage: Proof of Concept
SQLSeal by default gets 3 renderers (or views) bundled in: GRID (default), HTML and MARKDOWN. I want the plugin to reach the stage where external plugins can register their own renderers with thier own configuration and control how the query result is being displayed. I work on a SQLSeal Plot (codename) that allows you to chart results of your query. Once it's finished documentation and interface for this feature can be finalised.
Register new data source
Stage
Current Stage: Idea
I want to allow external plugins to register their data sources: i.e. plugin that fetches your IMDB watch history and creates new table. To allow full data ownership, the plugin would save the results on the disk (probably as CSV) so user can later use the data however they want.
Register new data types
Stage
Current Stage: Idea
Expose SQLSeal interface to other plugins
Stage
Current Stage: Development
Other plugins could extend SQLSeal's TABLE syntax so it can operate on more data types (i.e. JSON, XLSX).
Query lifecycle
Queries have the following lifecycle:
Stage | Description |
---|---|
Query Recieved | Query is either created as a codeblock or it gets refreshed |
SQLSeal Parser | Initial parsing that separates table queries, renderers (and any other potential options) and select statement |
Transform tables inside the query | Many files can define tables with the same name. To make it work, we transform name (like data user could define)into internal name like table_093fjd9sffc329 |
Executes Query | Query sent to SQLite |
Renders using chosen renderer | Renderer is determined based on intermediateContent value. For now can be either HTML , MARKDOWN or GRID but more are planned for the future (also will add posibility to register them from other plugins). |
Watches for file changes | Using Omnibus library to register eventListeners. On change refreshes the query. The change can modify table statements, renderers, etc so whole pipeline needs to be revaluated. |