2024-12-25 11:40:57 +00:00
|
|
|
# Pssecret
|
2022-06-09 22:08:36 +00:00
|
|
|
|
2022-06-12 12:45:42 +00:00
|
|
|
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
|
|
|
|
|
2024-12-25 11:40:57 +00:00
|
|
|
Pssecret is self-hosted service to share secrets (like passwords) with somebody
|
2022-06-09 22:08:36 +00:00
|
|
|
over the network, but don't want them to appear in chats, unencrypted e-mails, etc.
|
|
|
|
|
|
|
|
This service tries to be as anonymous as possible. The only personal information that will be stored
|
2022-06-12 10:50:48 +00:00
|
|
|
on a server will be IP address of the client that made request to the server.
|
|
|
|
|
|
|
|
Service is built with Python, FastAPI and is using Redis for data storage.
|
2022-06-12 12:44:27 +00:00
|
|
|
|
2022-06-12 21:56:09 +00:00
|
|
|
## Installation
|
|
|
|
|
|
|
|
### Requirements
|
|
|
|
|
2022-12-17 08:37:41 +00:00
|
|
|
- Python 3.11+
|
2022-06-12 21:56:09 +00:00
|
|
|
- Redis
|
|
|
|
- Python development libraries (optional, only needed for `hiredis` module installation)
|
|
|
|
|
|
|
|
### How to install
|
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
The recommended installation method is with the [pipx](https://pipx.pypa.io/latest/)
|
2022-06-12 21:56:09 +00:00
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
```console
|
|
|
|
$ pipx install pssecret
|
2022-06-12 21:56:09 +00:00
|
|
|
```
|
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
For faster performance, install application with [hiredis](https://github.com/redis/hiredis) support.
|
2022-06-12 21:56:09 +00:00
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
```console
|
|
|
|
$ pipx install pssecret[hiredis]
|
|
|
|
```
|
2022-06-12 21:56:09 +00:00
|
|
|
|
2024-12-25 11:40:57 +00:00
|
|
|
### Running Pssecret server
|
2022-06-12 22:03:13 +00:00
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
Make sure you have the Redis service running.
|
|
|
|
|
2024-12-25 11:40:57 +00:00
|
|
|
After installation is done, you can start pssecret with `pssecret` command.
|
2022-06-12 22:03:13 +00:00
|
|
|
The web server will be started with `uvicorn` ASGI web server.
|
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
```console
|
2024-12-25 11:40:57 +00:00
|
|
|
$ pssecret
|
2022-06-12 22:03:13 +00:00
|
|
|
```
|
2022-06-12 21:56:09 +00:00
|
|
|
|
2022-12-17 08:53:50 +00:00
|
|
|
### Configuration
|
|
|
|
|
2024-12-25 11:40:57 +00:00
|
|
|
Configuration is done through config file. By default, path is `/etc/pssecret/pssecret.toml`.
|
|
|
|
You can override this by setting environment variable `PSSECRET_CONF_FILE` value to actual file
|
2022-12-17 08:53:50 +00:00
|
|
|
location, i.e.:
|
|
|
|
|
2024-12-25 17:35:01 +00:00
|
|
|
```console
|
2024-12-25 11:40:57 +00:00
|
|
|
$ PSSECRET_CONF_FILE=/home/user/.conf/pssecret.toml pssecret
|
2022-12-17 08:53:50 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
You can find all available configuration options in the example file, located
|
2024-12-25 11:40:57 +00:00
|
|
|
at [conf/pssecret.toml.example](conf/pssecret.toml.example) under Git root.
|