Metadata-Version: 2.4
Name: kernl
Version: 0.4.8
Summary: To be Updated
Home-page: https://github.com/nnilayy/kernl
Author: Nilay Kumar Bhatnagar
Author-email: nnilayy.work@email.com
License: MIT
Classifier: Programming Language :: Python :: 3.11
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: POSIX
Classifier: Operating System :: POSIX :: Linux
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Development Status :: 3 - Alpha
Requires-Python: >=3.11
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: anyio==4.9.0
Requires-Dist: argon2-cffi==25.1.0
Requires-Dist: argon2-cffi-bindings==21.2.0
Requires-Dist: arrow==1.3.0
Requires-Dist: art==6.5
Requires-Dist: asttokens==3.0.0
Requires-Dist: async-lru==2.0.5
Requires-Dist: attrs==25.3.0
Requires-Dist: babel==2.17.0
Requires-Dist: beautifulsoup4==4.13.4
Requires-Dist: bleach==6.2.0
Requires-Dist: certifi==2025.7.9
Requires-Dist: cffi==1.17.1
Requires-Dist: charset-normalizer==3.4.2
Requires-Dist: colorama==0.4.6
Requires-Dist: comm==0.2.2
Requires-Dist: debugpy==1.8.14
Requires-Dist: decorator==5.2.1
Requires-Dist: defusedxml==0.7.1
Requires-Dist: executing==2.2.0
Requires-Dist: fastjsonschema==2.21.1
Requires-Dist: filelock==3.18.0
Requires-Dist: fqdn==1.5.1
Requires-Dist: fsspec==2025.5.1
Requires-Dist: h11==0.16.0
Requires-Dist: hf-xet==1.1.5
Requires-Dist: httpcore==1.0.9
Requires-Dist: httpx==0.28.1
Requires-Dist: huggingface-hub==0.33.4
Requires-Dist: idna==3.10
Requires-Dist: ipykernel==6.29.5
Requires-Dist: ipython==9.4.0
Requires-Dist: ipython-pygments-lexers==1.1.1
Requires-Dist: ipywidgets==8.1.7
Requires-Dist: isoduration==20.11.0
Requires-Dist: jedi==0.19.2
Requires-Dist: jinja2==3.1.6
Requires-Dist: json5==0.12.0
Requires-Dist: jsonpointer==3.0.0
Requires-Dist: jsonschema==4.24.0
Requires-Dist: jsonschema-specifications==2025.4.1
Requires-Dist: jupyter==1.1.1
Requires-Dist: jupyter-client==8.6.3
Requires-Dist: jupyter-console==6.6.3
Requires-Dist: jupyter-core==5.8.1
Requires-Dist: jupyter-events==0.12.0
Requires-Dist: jupyter-lsp==2.2.5
Requires-Dist: jupyter-server==2.16.0
Requires-Dist: jupyter-server-terminals==0.5.3
Requires-Dist: jupyterlab==4.4.4
Requires-Dist: jupyterlab-pygments==0.3.0
Requires-Dist: jupyterlab-server==2.27.3
Requires-Dist: jupyterlab-widgets==3.0.15
Requires-Dist: kaggle==1.7.4.5
Requires-Dist: markupsafe==3.0.2
Requires-Dist: matplotlib-inline==0.1.7
Requires-Dist: mistune==3.1.3
Requires-Dist: nbclient==0.10.2
Requires-Dist: nbconvert==7.16.6
Requires-Dist: nbformat==5.10.4
Requires-Dist: nest-asyncio==1.6.0
Requires-Dist: notebook==7.4.4
Requires-Dist: notebook-shim==0.2.4
Requires-Dist: overrides==7.7.0
Requires-Dist: packaging==25.0
Requires-Dist: pandocfilters==1.5.1
Requires-Dist: parso==0.8.4
Requires-Dist: pexpect==4.9.0
Requires-Dist: platformdirs==4.3.8
Requires-Dist: prometheus-client==0.22.1
Requires-Dist: prompt-toolkit==3.0.51
Requires-Dist: protobuf==6.31.1
Requires-Dist: psutil==7.0.0
Requires-Dist: ptyprocess==0.7.0
Requires-Dist: pure-eval==0.2.3
Requires-Dist: pycparser==2.22
Requires-Dist: pygments==2.19.2
Requires-Dist: pyngrok==7.2.12
Requires-Dist: pyperclip==1.9.0
Requires-Dist: python-dateutil==2.9.0.post0
Requires-Dist: python-json-logger==3.3.0
Requires-Dist: python-slugify==8.0.4
Requires-Dist: pyyaml==6.0.2
Requires-Dist: pyzmq==27.0.0
Requires-Dist: referencing==0.36.2
Requires-Dist: requests==2.32.4
Requires-Dist: rfc3339-validator==0.1.4
Requires-Dist: rfc3986-validator==0.1.1
Requires-Dist: rpds-py==0.26.0
Requires-Dist: send2trash==1.8.3
Requires-Dist: setuptools==80.9.0
Requires-Dist: six==1.17.0
Requires-Dist: sniffio==1.3.1
Requires-Dist: soupsieve==2.7
Requires-Dist: stack-data==0.6.3
Requires-Dist: terminado==0.18.1
Requires-Dist: text-unidecode==1.3
Requires-Dist: tinycss2==1.4.0
Requires-Dist: tornado==6.5.1
Requires-Dist: tqdm==4.67.1
Requires-Dist: traitlets==5.14.3
Requires-Dist: types-python-dateutil==2.9.0.20250708
Requires-Dist: typing-extensions==4.14.1
Requires-Dist: uri-template==1.3.0
Requires-Dist: urllib3==2.5.0
Requires-Dist: wcwidth==0.2.13
Requires-Dist: webcolors==24.11.1
Requires-Dist: webencodings==0.5.1
Requires-Dist: websocket-client==1.8.0
Requires-Dist: widgetsnbextension==4.0.14
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: description-content-type
Dynamic: home-page
Dynamic: license
Dynamic: license-file
Dynamic: requires-dist
Dynamic: requires-python
Dynamic: summary

<p align="center">
  <img src="https://raw.githubusercontent.com/nnilayy/kernl/main/assets/kernl-banner.png" alt="Kernl Banner" width="80%">
</p>

<p align="center">
  <a href="https://pypi.org/project/kernl/">
    <img src="https://img.shields.io/pypi/v/kernl.svg?color=brightgreen" alt="PyPI Version">
  </a>
  <a href="https://pepy.tech/project/kernl">
    <img src="https://static.pepy.tech/badge/kernl" alt="Downloads">
  </a>
  <img src="https://img.shields.io/pypi/pyversions/kernl.svg" alt="Python Versions">
  <a href="https://github.com/nnilayy/kernl/blob/main/LICENSE">
    <img src="https://img.shields.io/github/license/nnilayy/kernl.svg" alt="License">
  </a>
</p>

## Overview

Kernl is a secure persistent development environment system for cloud based Linux/Unix instances, providing a VSCode Web workspace backed by cloud based dataset managers such as HuggingFace 🤗 and Kaggle to keep full codebases, configurations, virtual environments, and dependencies persistent in the cloud, while supporting connections to distributed version-control platforms including GitHub, GitLab, and Bitbucket for SSH access and seamless continuation of development work from the start.

## Features

**(1) Secure VSCode Web Workspace 🔐**: Kernl provides a secure, password-protected VSCode Web workspace that offers a full development environment for cloud-based Linux/Unix instances. The workspace is exposed through ngrok tunneling and provides complete access to the VSCode interface.

**(2) Cloud-backed Persistent Environment ☁️**: Workspaces are managed by cloud dataset managers such as HuggingFace 🤗 and Kaggle, keeping full codebases, VSCode configurations, virtual environments, and dependencies consistently preserved and restorable across sessions. Environment storage uses fast tar-lz4 compression and decompression for quick upload and retrieval of workspace components.

**(3) Integrated Version-Control Connectivity 🔗**: Kernl supports connections to all major distributed version-control platforms including GitHub, GitLab, and Bitbucket. It enables authentication through platform tokens, allows adding and deleting SSH keys directly from Kernl, and provides seamless access to repositories for immediate development.

**(4) Unified Remote Development Interface 🌐**: Kernl allows you to push full environments to the cloud and pull them back whenever needed, enabling seamless continuation of work without occupying storage on the host machine, and allowing development to resume on any compatible cloud instance using the stored environments and connected distributed version-control platforms.

**(5) API and CLI Availability 🧩**: Kernl is accessible as both a Python API and a terminal-based CLI tool, allowing you to automate tasks programmatically or interact directly from the command line depending on your workflow.


## Installation

`kernl` can be installed in two ways, either directly from PyPI for regular use or by cloning the repository if you want to modify the project or contribute. Before installing `kernl`, it is recommended to create a new virtual environment.

### **Create a Virtual Environment (Recommended)**

```bash
uv venv venv --python 3.11
source venv/bin/activate
```

### **1. Install `kernl` from PyPI**

```bash
uv pip install kernl
```

This installs `kernl` and makes the `kernl` API and CLI available on your Linux or Unix based system.

### **2. Install `kernl` from Source**

```bash
git clone https://github.com/nnilayy/kernl.git
cd kernl
uv pip install -e .
```

Installing in editable mode means any changes you make to the source code will immediately apply when running `kernl`.

## Contributing
Contributions are welcome! If you have suggestions, bug reports, or feature requests, feel free to open an issue or submit a pull request.

### Steps to Contribute:
1. Fork the repository.
2. Create a new branch for your feature or bug fix.
3. Make your changes and ensure `kernl` runs as expected.
4. Submit a pull request with a clear and detailed explanation of your updates.

## License

This project is licensed under the **GNU General Public License v3.0**, check out the [LICENSE](LICENSE) file for more details.

## Support & Contact

If you have any questions or need assistance, feel free to reach out:

- **GitHub Issues**: [Issues Page](https://github.com/nnilayy/kernl/issues/new)
- **Email**: nnilayy.work@gmail.com

---
