gollama

command module
v0.1.10 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 19, 2024 License: MIT Imports: 13 Imported by: 0

README ΒΆ

πŸ€– Gollama: Ollama in your terminal, Your Offline AI Copilot πŸ¦™

Gollama is a delightful tool that brings Ollama, your offline conversational AI companion, directly into your terminal. It provides a fun and interactive way to generate responses from various models without needing internet connectivity. Whether you're brainstorming ideas, exploring creative writing, or just looking for inspiration, Gollama is here to assist you.

Gollama

🌟 Features

  • Interactive Interface: Enjoy a seamless user experience with intuitive interface powered by Bubble Tea.
  • Customizable Prompts: Tailor your prompts to get precisely the responses you need.
  • Multiple Models: Choose from a variety of models to generate responses that suit your requirements.
  • Visual Feedback: Stay engaged with visual cues like spinners and formatted output.

πŸš€ Getting Started

Prerequisites
  • Go installed on your system.
  • Ollama installed on your system or a gollama API server accessible from your machine. (Default: http://localhost:11434) Read more about customizing the base URL here.
  • At least one model installed on your Ollama server. You can install models using the ollama pull <model-name> command. To find a list of all available models, check the Ollama Library. You can also use the ollama list command to list all locally installed models.
Installation

You can install Gollama using one of the following methods:

Download the latest release

Grab the latest release from the releases page and extract the archive to a location of your choice.

Install using Go

You can also install Gollama using the go install command:

go install github.com/gaurav-gosain/gollama@latest
Run using Docker

You can pull the latest docker image from the GitHub Docker Container Registry and run it using the following command:

docker run --net=host -it --rm ghcr.io/gaurav-gosain/gollama:latest

You can also run Gollama locally using docker:

  1. Clone the repository:

    git clone https://github.com/Gaurav-Gosain/gollama.git
    
  2. Navigate to the project directory:

    cd gollama
    
  3. Build the docker image:

    [!NOTE] The following command will build the docker image with the tag gollama. You can replace gollama with any tag of your choice.

    docker build -t gollama .
    
  4. Run the docker image:

    docker run --net=host -it gollama
    
Build from source

If you prefer to build from source, follow these steps:

  1. Clone the repository:

    git clone https://github.com/Gaurav-Gosain/gollama.git
    
  2. Navigate to the project directory:

    cd gollama
    
  3. Build the executable:

    go build
    
Usage
  1. Run the executable:

    gollama
    

    or

    /path/to/gollama
    
  2. Follow the on-screen instructions to interact with Gollama.

Options
  • --help: Display the help message.
  • --base-url: Specify a custom base URL for the Ollama server.
  • --prompt: Specify a custom prompt for generating responses.
  • --model: Choose a specific model for response generation.

    List of available Ollama models can be found using the ollama list command.

  • --raw: Enable raw output mode for unformatted responses.

[!NOTE] The following options for multimodal models are also available, but are experimental and may not work as expected


[!WARNING] The responses for multimodal LLMs are slower than the normal models (also depends on the size of the attached image)


  • --attach-image: Allow attaching an image to the prompt.

    This option is automatically set to true if an image path is provided.

  • --image: Path to the image file to attach (png/jpg/jpeg).
> gollama --help
Usage of gollama:
  -attach-image
        Allow attaching an image (automatically set to true if an image path is provided)
  -base-url string
        Base URL for the API server (default "http://localhost:11434")
  -image string
        Path to the image file to attach (png/jpg/jpeg)
  -model string
        Model to use for generation
  -prompt string
        Prompt to use for generation
  -raw
        Enable raw output

πŸ“– Examples

Interactive Mode

Interactive Mode

Piped Mode

[!NOTE] Piping into Gollama automatically turns on --raw output mode.

echo "Once upon a time" | ./gollama --model="llama2" --prompt="prompt goes here"
./gollama --model="llama2" --prompt="prompt goes here" < input.txt
CLI Mode with Image

[!TIP] Different combinations of flags can be used as per your requirements.

./gollama --model="llava:latest" \
 --prompt="prompt goes here" \
 --image="path/to/image.png" --raw
TUI Mode with Image
./gollama --attach-image

πŸ“¦ Dependencies

Gollama relies on the following third-party packages:

  • bubbletea: A library for building terminal applications using the Model-Update-View pattern.
  • glamour: A markdown rendering library for the terminal.
  • huh: A library for building terminal-based forms and surveys.
  • lipgloss: A library for styling text output in the terminal.

πŸ—ΊοΈ Roadmap

  • Implement piped mode for automated usage.
  • Add support for extracting codeblocks from the generated responses.
  • Add ability to copy responses/codeblocks to clipboard.
  • GitHub Actions for automated releases.
  • Add support for downloading models directly from Ollama using the rest API.

🀝 Contribution

Contributions are welcome! Whether you want to add new features, fix bugs, or improve documentation, feel free to open a pull request.

Star History

Star History Chart

GitHub Language Count GitHub Top Language Repo Size GitHub Issues GitHub Closed Issues GitHub Pull Requests GitHub Closed Pull Requests GitHub Contributors GitHub Last Commit GitHub Commit Activity (Week)

πŸ“œ License

This project is licensed under the MIT License - see the LICENSE file for details.

Documentation ΒΆ

The Go Gopher

There is no documentation for this package.

Directories ΒΆ

Path Synopsis
internal
api

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL