An AI-powered tool to suggest Linux commands based on user input
Project description
SnapShell
SnapShell is a powerful command-line utility designed to enhance your Linux terminal experience by auto-completing commands using a Language Learning Model (LLM). SnapShell intelligently suggests commands based on your input, maintains a history of suggested commands, and allows you to manage your command history with ease.
Features
- Informed Sugestion: Get AI-powered command suggestions based on the query and your system's installed packages.
- Command History: Review previously suggested commands at any time.
- History Management: Clear the command history with a single command.
- Database Update: Easily update the database with the installed packages on your system.
Installation
Prerequisites
- Python 3.10 or higher
pip
package manager
Installing via pip
Install SnapShell with the following command:
pip install snapshell
Custom Installation
SnapShell requires your Groq Api key during installation. Follow the on-screen instructions after installation
The installation will automatically store the key in ~/.snapshell_config.json
file.
OR
git clone https://github.com/KTS-o7/snapshell.git
cd snapshell
python -m venv env
source env/bin/activate
pip install -r requirements.txt
python setup.py install
Dependencies
SnapShell requires the following libraries:
argparse
: For parsing command-line arguments.sqlite3
: For local database operations.os
: To interact with your operating system.
Configuration Instructions
To use SnapShell, you need to provide GROQ_API_KEY
when prompted for the first time.
For any changes in the key you can edit ~/.snapshell_config.json
file and add the appropriate key.
Usage
Run SnapShell in your terminal using:
snapshell
Command-line Arguments
SnapShell supports the following arguments:
--update-db
: Updates the database with currently installed packages.--view-history
: Displays the command suggestion history.--clear-history
: Clears all entries from the command history.
Example usage:
snapshell --update-db
snapshell --view-history
snapshell --clear-history
Advanced Usage
SnapShell is intuitive and primitive to use. It suggests commands based on your input and maintains a history of suggestions. You can view or clear the command history at any time.
How It Works
SnapShell leverages a Language Learning Model to suggest relevant Linux commands based on user input. It keeps a local history of suggestions that can be reviewed or cleared at your discretion. Upon installation, SnapShell can update its internal database with packages installed on your system, ensuring up-to-date suggestions.
Functions
view_history()
: Fetch and display the command history from the local database.clear_history()
: Clear the command history in the local database.main()
: The primary function that handles user input, command-line arguments, and interaction.
API Documentation
SnapShell does not directly expose API endpoints, but it interacts with the GROQ API under the hood. Here’s a brief overview:
- GROQ API Key: Used to authenticate the SnapShell tool.
- Command Suggestions: SnapShell queries the GROQ API with the user's input to retrieve command suggestions in real-time. If the project exposes new APIs in the future, detailed endpoint documentation should be added here.
Contributing
We welcome contributions! If you'd like to contribute, please follow these steps:
- Fork the repository:Click the "Fork" button at the top of the GitHub repository page.
- Create a branch: Create a new feature or bugfix branch.
git checkout -b feature/new-feature
- Code Style: Follow PEP 8 guidelines for Python code.
- Testing: Ensure your code passes all existing tests and add new tests if necessary.
- Submit a Pull Request: Once your changes are ready, submit a pull request for review.
We currently need help to integrate SnapShell with more shells and support more platforms like windows.
Troubleshooting
Common Issues
- Installation Errors: Ensure that you have the correct version of Python and pip installed. If dependencies fail to install, try updating pip:
pip install --upgrade pip
- Missing GROQ_API_KEY: If SnapShell is not functioning properly, make sure the api-key is correctly set in config. You can check this by running:
cat ~/.snapshell_config.json
- Permission Denied: If you encounter a "permission denied" error, try running the command with
sudo
or ensure you have the necessary file permissions. - Clearing History Not Working: If the history isn’t clearing, you might need to manually reset the SQLite database file used by SnapShell:
rm ~/.snapshell/system_info.db
If you encounter other issues, feel free to open an issue in the GitHub repository or contact us.
License
SnapShell is licensed under the MIT License. For more details, see the LICENSE file.
Contact
For any questions, issues, or feature requests, please reach out to:
Krishnatejaswi S
shentharkrishnatejaswi@gmail.com
Contributors
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file snapshell-1.1.0.tar.gz
.
File metadata
- Download URL: snapshell-1.1.0.tar.gz
- Upload date:
- Size: 23.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4cef1b6f83bdc89e9d75ffd937abe5ec23717123578e99ef75fa2dbebae02397 |
|
MD5 | de3c25b296ce690a2d7153ec36f46189 |
|
BLAKE2b-256 | d65bbab80ee522097dbd99046619baea27d2337c4409c4aaafb1058e853f8643 |
File details
Details for the file snapshell-1.1.0-py3-none-any.whl
.
File metadata
- Download URL: snapshell-1.1.0-py3-none-any.whl
- Upload date:
- Size: 24.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e33ca781bce18eb5c9534248d5e3f4048dfd6c6dc129f7cfde406def0c37cc06 |
|
MD5 | ef73c4c183aa8b4a9d7e9b46ee83fe06 |
|
BLAKE2b-256 | 750dd25967bd535c8b6581d9055f43fa83f388d0b1afd38cdd8fe3dda00508e7 |