konbini

command module
v0.2.7 Latest Latest
Warning

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

Go to latest
Published: Sep 28, 2024 License: GPL-3.0 Imports: 11 Imported by: 0

README

Konbini

A service to manage secrets for your awesome projects. You can use any software like curl or bruno to access the service because its like any other REST API.

Try Mi CLI, the official CLI for Konbini.

Feel free to fork/clone this repository and host the service on your own server. Read the documentation for more help.

This service does not really do any encryption on secrets since it won't be storing/generating any type of crypto keys. This ensures that if a breach were to happen, no secret stored in the database, are leaked and vulnerable to be decrypted.

As of now, the service does not encrypt any of the user information that is collected during sign-up, which include email and name. There are no enforcement to use a real name, so it is preferred for users to input a nickname that teammates or other parties can recognize. The purpose of getting a name is to be able to address that user via emails, such as verification codes or for teammates to know who did what.

Table of Content

Self-host Konbini

To self-host Konbini on your private machine, you can build a Docker image by cloning this repository or forking it to modify/extend its features for your needs.

If you do not wish to use Docker, you can always just build a binary and run it.

You will also need to get yourself a Resend API key to send emails.

Finally, make sure to have a usable PostgreSQL database.

Here is a list of environment variables and their usage that you will need:

# The connection string for the PostgreSQL database.
DB_URL=
# The port the server will listen to. If you are using a Docker image, make sure
# port forwarding points to this PORT for the Docker port.
PORT=
# This variable can have two possible values "production" or "development".
APP_ENV=
# The name of the database.
DB_NAME=
# Resend API key to send emails.
RESEND_API_KEY=
# This is used to fill email templates so that the BE knows its own URL.
# For example: https://my.konbini.com
SERVER_URL=
# Currently not used, so it can be left empty.
# This can be used to encrypt data in the database.
PGP_SYM_KEY=
# The hashing algorithm for passwords.
PASS_ENCRYPT_ALGO=
# The do not reply email address used by the service.
DONOTREPLY_EMAIL=
# Make sure it is a secure string that will be used for access tokens.
JWT_ACCESS_TOKEN_SECRET=
# Make sure it is a secure string that will be used for refresh tokens.
JWT_REFRESH_TOKEN_SECRET=
# This is just a string that identifies the type of jwt for access tokens.
JWT_ACCESS_TOKEN_TYPE=
# This is just a string that identifies the type of jwt for refresh tokens.
JWT_REFRESH_TOKEN_TYPE=
# A name to put in the issuer field for jwt.
JWT_ISSUER=

Development

This section highlights pre-requisites and how to get started for development.

Pre-requisites
Get Started

After meeting all the pre-requisites, we can now start the development environment.

The Konbini PostgreSQL database runs on a docker container which makes it easy to just start/stop.

Use the following make commands to initialize databas, run migrations and start development server. Read the Makefile for more commands.

make init-dev-db
make up
make dev
Testing

To run all tests just use the command make run-tests. This command will do the following:

  • Start a temporary testing database using docker.
  • Run all tests.
  • Stop/Remove temporary testing database.

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
templ: version: v0.2.778
templ: version: v0.2.778
All the error codes can be found here: https://www.postgresql.org/docs/current/errcodes-appendix.html
All the error codes can be found here: https://www.postgresql.org/docs/current/errcodes-appendix.html
templ: version: v0.2.778
templ: version: v0.2.778

Jump to

Keyboard shortcuts

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