2024-12-18 18:44:23 +01:00
|
|
|
## A personal key value store
|
|
|
|
|
|
2025-11-03 09:15:27 +01:00
|
|
|
[](https://ci.codeberg.org/repos/15517)
|
|
|
|
|
[](https://codeberg.org/scip/anydb/blob/master/LICENSE)
|
|
|
|
|
[](https://goreportcard.com/report/codeberg.org/scip/anydb)
|
|
|
|
|
[](https://codeberg.org/scip/anydb/releases)
|
|
|
|
|
[](https://codeberg.org/scip/anydb/raw/branch/main/anydb.pod)
|
2024-12-18 18:44:23 +01:00
|
|
|
|
2025-02-10 15:39:40 +01:00
|
|
|
> [!CAUTION]
|
2025-02-18 15:23:03 +01:00
|
|
|
> Between version 0.1.0 and version 0.2.1 deletion of keys did not work. There
|
|
|
|
|
> is a unit test to check for this, but this unit test had a bug as well and
|
|
|
|
|
> didn't catch it. The bug and the test have been fixed. You are advised to
|
|
|
|
|
> upgrade to 0.2.1 and above.
|
|
|
|
|
|
|
|
|
|
> [!CAUTION]
|
2025-11-03 09:15:27 +01:00
|
|
|
> Version 0.1.3 introduced a [regression](https://codeberg.org/scip/anydb/issues/19),
|
2025-02-10 15:41:30 +01:00
|
|
|
> which caused the encryption feature not to work correctly anymore.
|
2025-02-10 15:39:40 +01:00
|
|
|
> If you are using anydb 0.1.3, you are urgently advised to
|
|
|
|
|
> upgrade to 0.2.0
|
|
|
|
|
|
2025-02-18 15:23:03 +01:00
|
|
|
|
2024-12-18 18:44:23 +01:00
|
|
|
Anydb is a simple to use commandline tool to store anything you'd
|
|
|
|
|
like, even binary files etc. It is a re-implementation of
|
|
|
|
|
[skate](https://github.com/charmbracelet/skate) for the following
|
|
|
|
|
reasons:
|
|
|
|
|
|
|
|
|
|
- it's just fun to do
|
|
|
|
|
- anydb uses [bbolt](https://github.com/etcd-io/bbolt) instead of
|
|
|
|
|
badger. bbolt has a stable file format, which doesn't change
|
|
|
|
|
anymore. The badger file format on the other hand changes very
|
|
|
|
|
often, which is not good for a tool intended to be used for many
|
|
|
|
|
years.
|
2024-12-19 10:37:21 +01:00
|
|
|
- more features:
|
2024-12-20 12:08:25 +01:00
|
|
|
- output table in list mode uses TAB separator
|
2024-12-19 10:37:21 +01:00
|
|
|
- better STDIN + pipe support
|
|
|
|
|
- supports JSON output
|
|
|
|
|
- supports more verbose tabular output
|
|
|
|
|
- filtering using regular expressions
|
|
|
|
|
- tagging
|
|
|
|
|
- filtering using tags
|
|
|
|
|
- encryption of entries
|
2024-12-20 11:53:09 +01:00
|
|
|
- templates for custom output for maximum flexibility
|
2024-12-20 23:25:19 +01:00
|
|
|
- includes a tiny web server, which serves a restful API
|
2024-12-18 18:44:23 +01:00
|
|
|
|
2024-12-22 21:12:16 +01:00
|
|
|
And I wrote a very similar [tool](https://www.daemon.de/projects/dbtool/) 24 years ago and wanted to do it again wit go.
|
|
|
|
|
|
2024-12-18 18:44:23 +01:00
|
|
|
**anydb** can do all the things you can do with skate:
|
|
|
|
|
|
2025-11-05 08:59:43 +01:00
|
|
|

|
2024-12-18 18:44:23 +01:00
|
|
|
|
|
|
|
|
However, there are more features than just that!
|
|
|
|
|
|
2025-11-05 08:59:43 +01:00
|
|
|

|
2024-12-18 18:44:23 +01:00
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
|
|
|
|
There are multiple ways to install **anydb**:
|
|
|
|
|
|
2025-11-03 09:15:27 +01:00
|
|
|
- Go to the [latest release page](https://codeberg.org/scip/anydb/releases),
|
2024-12-18 18:44:23 +01:00
|
|
|
locate the binary for your operating system and platform.
|
|
|
|
|
|
|
|
|
|
Download it and put it into some directory within your `$PATH` variable.
|
|
|
|
|
|
|
|
|
|
- The release page also contains a tarball for every supported platform. Unpack it
|
|
|
|
|
to some temporary directory, extract it and execute the following command inside:
|
2024-12-19 10:37:21 +01:00
|
|
|
```shell
|
2024-12-18 18:44:23 +01:00
|
|
|
sudo make install
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
- You can also install from source. Issue the following commands in your shell:
|
2024-12-19 10:37:21 +01:00
|
|
|
```shell
|
2025-11-03 09:15:27 +01:00
|
|
|
git clone https://codeberg.org/scip/anydb.git
|
2024-12-18 18:44:23 +01:00
|
|
|
cd anydb
|
|
|
|
|
make
|
|
|
|
|
sudo make install
|
|
|
|
|
```
|
|
|
|
|
|
2024-12-19 10:37:21 +01:00
|
|
|
- Or, if you have the GO toolkit installed, just install it like this:
|
|
|
|
|
```shell
|
2025-11-03 09:15:27 +01:00
|
|
|
go install codeberg.org/scip/anydb@latest
|
2024-12-19 10:37:21 +01:00
|
|
|
```
|
|
|
|
|
|
2024-12-18 18:44:23 +01:00
|
|
|
If you do not find a binary release for your platform, please don't
|
|
|
|
|
hesitate to ask me about it, I'll add it.
|
|
|
|
|
|
2024-12-19 11:30:35 +01:00
|
|
|
### Using the docker image
|
|
|
|
|
|
|
|
|
|
A pre-built docker image is available, which you can use to test the
|
|
|
|
|
app without installing it. To download:
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
docker pull ghcr.io/tlinden/anydb:latest
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
To execute anydb inside the image do something like this:
|
|
|
|
|
|
|
|
|
|
```shell
|
2024-12-20 12:20:53 +01:00
|
|
|
mkdir mydb
|
|
|
|
|
docker run -ti -v mydb:/db -u `id -u $USER` -e HOME=/db ghcr.io/tlinden/anydb:latest set foo bar
|
|
|
|
|
docker run -ti -v mydb:/db -u `id -u $USER` -e HOME=/db ghcr.io/tlinden/anydb:latest list -o wide
|
2024-12-19 11:30:35 +01:00
|
|
|
```
|
|
|
|
|
|
2024-12-20 12:20:53 +01:00
|
|
|
Here, we operate in a local directory `mydb`, which we'll use as HOME
|
|
|
|
|
inside the docker container. anydb will store its database in
|
|
|
|
|
`mydb/.config/anydb/default.db`.
|
|
|
|
|
|
2025-11-03 09:15:27 +01:00
|
|
|
A list of available images is [here](https://codeberg.org/scip/anydb/pkgs/container/anydb/versions?filters%5Bversion_type%5D=tagged)
|
2024-12-19 11:30:35 +01:00
|
|
|
|
|
|
|
|
|
2024-12-18 18:44:23 +01:00
|
|
|
## Documentation
|
|
|
|
|
|
|
|
|
|
The documentation is provided as a unix man-page. It will be
|
|
|
|
|
automatically installed if you install from source. However, you can
|
2025-11-03 09:15:27 +01:00
|
|
|
[read the man-page online](https://codeberg.org/scip/anydb/blob/master/anydb.pod)
|
2024-12-18 18:44:23 +01:00
|
|
|
|
|
|
|
|
Or if you cloned the repository you can read it this way (perl needs
|
|
|
|
|
to be installed though): `perldoc anydb.pod`.
|
|
|
|
|
|
|
|
|
|
If you have the binary installed, you can also read the man page with
|
|
|
|
|
this command:
|
|
|
|
|
|
|
|
|
|
anydb man
|
|
|
|
|
|
|
|
|
|
## Getting help
|
|
|
|
|
|
|
|
|
|
Although I'm happy to hear from anydb users in private email, that's the
|
|
|
|
|
best way for me to forget to do something.
|
|
|
|
|
|
|
|
|
|
In order to report a bug, unexpected behavior, feature requests or to
|
|
|
|
|
submit a patch, please open an issue on github:
|
2025-11-03 09:15:27 +01:00
|
|
|
https://codeberg.org/scip/anydb/issues.
|
2024-12-18 18:44:23 +01:00
|
|
|
|
|
|
|
|
## Copyright and license
|
|
|
|
|
|
|
|
|
|
This software is licensed under the GNU GENERAL PUBLIC LICENSE version 3.
|
|
|
|
|
|
|
|
|
|
## Authors
|
|
|
|
|
|
|
|
|
|
T.v.Dein <tom AT vondein DOT org>
|
|
|
|
|
|
|
|
|
|
## Project homepage
|
|
|
|
|
|
2025-11-03 09:15:27 +01:00
|
|
|
https://codeberg.org/scip/anydb
|
2024-12-18 18:44:23 +01:00
|
|
|
|
|
|
|
|
## Copyright and License
|
|
|
|
|
|
|
|
|
|
Licensed under the GNU GENERAL PUBLIC LICENSE version 3.
|
|
|
|
|
|
|
|
|
|
## Author
|
|
|
|
|
|
|
|
|
|
T.v.Dein <tom AT vondein DOT org>
|