Skip to main content

Overview

The following low-level docs are aimed at core contributors.

We cover how to contribute to the core framework (aka the Core SDK).

tip

If you are interested to build on top of the framework, like creating assistants or adding app level extensions, please refer to developer docs instead.

Jan Framework

At its core, Jan is a cross-platform, local-first and AI native framework that can be used to build anything.

Extensions

Ultimately, we aim for a VSCode or Obsidian like SDK that allows devs to build and customize complex and ethical AI applications for any use case, in less than 30 minutes.

In fact, the current Jan Desktop Client is actually just a specific set of extensions & integrations built on top of this framework.

Desktop is Extensions

tip

We encourage devs to fork, customize, and open source your improvements for the greater community.

Cross Platform

Jan follows Clean Architecture to the best of our ability. Though leaky abstractions remain (we're a fast moving, open source codebase), we do our best to build an SDK that allows devs to build once, deploy everywhere.

Clean Architecture

Supported Runtimes:

  • Node Native Runtime, good for server side apps
  • Electron Chromium, good for Desktop Native apps
  • Capacitor, good for Mobile apps (planned, not built yet)
  • Python Runtime, good for MLOps workflows (planned, not built yet)

Supported OS & Architectures:

  • Mac Intel & Silicon
  • Windows
  • Linux (through AppImage)
  • Nvidia GPUs
  • AMD ROCm (coming soon)

Read more:

Local First

Jan's data persistence happens on the user's local filesystem.

We implemented abstractions on top of fs and other core modules in an opinionated way, s.t. user data is saved in a folder-based framework that lets users easily package, export, and manage their data.

Future endeavors on this front include cross device syncing, multi user experience, and more.

Long term, we want to integrate with folks working on CRDTs, e.g. Socket Runtime to deeply enable local-first software.

Read more:

caution

Our local first approach at the moment needs a lot of work. Please don't hesitate to refactor as you make your way through the codebase.

AI Native

We believe all software applications can be natively supercharged with AI primitives and embedded AI servers.

Including:

Fun Project Ideas

Beyond the current Jan client and UX, the Core SDK can be used to build many other AI-powered and privacy preserving applications.

  • Game engine: For AI enabled character games, procedural generation games
  • Health app: For a personal healthcare app that improves habits
  • Got ideas? Make a PR into this docs page!

If you are interested to tackle these issues, or have suggestions for integrations and other OSS tools we can use, please hit us up in Discord.

caution

Our open source license is copy left, which means we encourage forks to stay open source, and allow core contributors to merge things upstream.