CLI release of a secure brainstorming assistant and productivity manager.
Table of Contents
This CLI tool is designed to help developers organize thoughts and streamline workflows with the power of AI—no fuss, just results. It combines security and fun, offering a lightweight brainstorming assistant that integrates smoothly into your setup. With Retrieval-Augmented Generation (RAG) and LLMs, you can easily manage ideas, projects, and sensitive data while staying productive. It’s a simple, secure way to boost your workflow with a local AI assistant, making development more efficient and enjoyable.
For running the models locally, ensure you have ollama installed and running on your device. An error message reminding you to open ollama will appear if you forget. Ensure you have git, python (and presumably pip too). Best bet, download the official release for your platform (Operating System) from the provided homepages and their download section. On Windows, your best bet is to use the resulting Git Bash application that will become available after installing git.
Comfirm prerequisites by running the following command:
git --version && python --version && pip --version
Download and navigate into the repository:
git clone https://github.com/montymi/sesh-cli/ && cd sesh-cli
It is highly recommended to run this in an isolated installation with virtual environments.
On Unix, Linux, BSD, macOS, and Cygwin:
python -m venv venv
source venv/bin/activate
On Windows:
python -m venv venv
venv/Scripts/activate
Next install the dependencies for the project defined in requirements.txt
. On all OS run:
pip install -r requirements.txt
Navigate into the main folder for the source code:
cd src
Run the CLI using the following command:
python main.py
The script will:
- Display a list of all locally installed models within Ollama.
- Prompt you to select a model to use.
After selecting a model, a list of saved conversations will appear and you can:
- Resume a previous conversation for the selected model.
- Test conversation responses across different models.
- Start with a fresh conversation
The actual guide part is still a work in progress for the advanced features, but will be released soon.
- Seamlessly manage vector databases to enhance Retrieval-Augmented Generation (RAG) efficiency.
- Leverage optimized indexing for fast and accurate retrieval of relevant information.
- Add, update, and remove data vectors for adaptive knowledge storage.
- Effortlessly switch between locally installed models and the OpenAI API.
- Configure API keys and settings directly through the CLI for quick integration.
- Utilize OpenAI's advanced models for complex problem-solving and contextual tasks.
- Customize model behavior by defining "habits" for interaction styles, response formats, or tone preferences.
- Save and load habit configurations to ensure consistency across sessions.
- Create, edit, and organize notes within isolated research bubbles.
- Tag notes for quick reference and improved discoverability.
- Build custom plugins to extend functionality and meet specific workflow needs.
- Add plugins dynamically without interrupting active sessions.
- Use the CLI to manage, enable, or disable plugins for seamless customization.
.gitignore
config.ini
config.ini.example
docs/
├── designs/
│ ├── models.wsd
│ └── tiers.wsd
library/
├── habits.json
├── resources/
│ ├── conversations/
│ ├── journal/
│ ├── plugins/
│ └── vectors/
README.md
requirements.txt
sesh.log
src/
├── controllers/
│ ├── appcontroller.py
│ ├── clerkcontroller.py
│ ├── libcontroller.py
│ ├── servicecontroller.py
│ └── usercontroller.py
├── main.py
├── models/
│ ├── __init__.py
│ ├── app.py
│ ├── clerk.py
│ ├── commands.py
│ ├── DBLibrarian.py
│ ├── habits.py
│ ├── importers/
│ │ ├── __init__.py
│ │ ├── CSVImporter.py
│ │ ├── DirectoryImporter.py
│ │ ├── DocxImporter.py
│ │ ├── ImageImporter.py
│ │ ├── importer.py
│ │ ├── PDFImporter.py
│ │ ├── PythonImporter.py
│ │ ├── RecursiveDirectoryImporter.py
│ │ ├── TextImporter.py
│ │ └── URLImporter.py
│ ├── journal.py
│ ├── librarian.py
│ ├── managers.py
│ └── user.py
└── views/
└── cli.py
sandbox/
├── __init__.py
├── chain.py
├── chat-app.py
├── clerk.py
├── colored-input.py
├── dict.py
├── input.py
├── log.txt
├── testing.py
├── translator.py
└── tts.py
- Fix reference error for
resources/
- Add CI/CD testing for deployment to
main
- package and post to PIP
See the open issues for a full list of issues and proposed features.
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
) - Commit your Changes (
git commit -m 'Add some AmazingFeature'
) - Push to the Branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
Distributed under the GPL-3.0 License. See LICENSE.txt
for more information.
Michael Montanaro
Use this space to list any resources used or that may be helpful in understanding the project