Skip to content
This repository has been archived by the owner on Oct 11, 2024. It is now read-only.
/ companion Public archive

VSCode coding companion for software teams 🦆 Turn your team insights into a portable plug-and-play context for code generation. Alternative to GitHub Copilot & OpenAI GPT powered by OSS LLMs (Phi 3, Llama 3, CodeQwen, Mistral, etc.), made with ❤️ using FastAPI & Ollama.

License

Notifications You must be signed in to change notification settings

quack-ai/companion

Repository files navigation

Quack - API for contribution assistance

VSCode extensionBackend APIFrontend dashboardDocumentation

CI Status ruff Test coverage percentage

GitHub release (latest by date) Docker image License

Twitter

Quick Tour

Running/stopping the service

You can run the API containers using this command:

make run

You can now navigate to http://localhost:8050/docs to interact with the API (or do it through HTTP requests) and explore the documentation.

API Swagger screenshot

In order to stop the service, run:

make stop

How is the database organized

The back-end core feature is to interact with the metadata tables. For the service to be useful for codebase analysis, multiple tables/object types are introduced and described as follows:

Access-related tables

  • Users: stores the hashed credentials and access level for users & devices.

Core worklow tables

  • Repository: metadata of installed repositories.
  • Guideline: metadata of curated guidelines.

UML diagram

Installation

Prerequisites

The project was designed so that everything runs with Docker orchestration (standalone virtual environment), so you won't need to install any additional libraries.

Configuration

In order to run the project, you will need to specific some information, which can be done using a .env file. This file will have to hold the following information:

  • SUPERADMIN_GH_PAT: the GitHub token of the initial admin access (Generate a new token on GitHub, with no extra permissions = read-only)
  • SUPERADMIN_PWD*: the password of the initial admin access
  • GH_OAUTH_ID: the Client ID of the GitHub Oauth app (Create an OAuth app on GitHub, pointing to your Quack dashboard w/ callback URL)
  • GH_OAUTH_SECRET: the secret of the GitHub Oauth app (Generate a new client secret on the created OAuth app)
  • POSTGRES_DB*: a name for the PostgreSQL database that will be created
  • POSTGRES_USER*: a login for the PostgreSQL database
  • POSTGRES_PASSWORD*: a password for the PostgreSQL database
  • OPENAI_API_KEY: your API key for Open AI (Create new secret key on OpenAI)

* marks the values where you can pick what you want.

Optionally, the following information can be added:

  • SECRET_KEY*: if set, tokens can be reused between sessions. All instances sharing the same secret key can use the same token.
  • SENTRY_DSN: the DSN for your Sentry project, which monitors back-end errors and report them back.
  • SERVER_NAME*: the server tag that will be used to report events to Sentry.
  • POSTHOG_KEY: the project API key for PostHog PostHog.
  • SLACK_API_TOKEN: the App key for your Slack bot (Create New App on Slack, go to OAuth & Permissions and generate a bot User OAuth Token).
  • SLACK_CHANNEL: the Slack channel where your bot will post events (defaults to #general, you have to invite the App to your channel).
  • SUPPORT_EMAIL: the email used for support of your API.
  • DEBUG: if set to false, silence debug logs.

So your .env file should look like something similar to .env.example The file should be placed in the folder of your ./docker-compose.yml.

Contributing

Any sort of contribution is greatly appreciated!

You can find a short guide in CONTRIBUTING to help grow this project! And if you're interested, you can join us on

Copying & distribution

Copyright (C) 2023-2024, Quack AI.

This program is licensed under the Apache License 2.0. See LICENSE or go to https://www.apache.org/licenses/LICENSE-2.0 for full license details.

FOSSA Status

About

VSCode coding companion for software teams 🦆 Turn your team insights into a portable plug-and-play context for code generation. Alternative to GitHub Copilot & OpenAI GPT powered by OSS LLMs (Phi 3, Llama 3, CodeQwen, Mistral, etc.), made with ❤️ using FastAPI & Ollama.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Languages