Diogenes is an inventory web application designed to help you manage and keep track of your possessions at home. It is completely self-hosted, and no data is collected from users. You have the flexibility to easily migrate your data using the API, which is detailed in the Open API documentation provided by the backend server.
This app is intended to assist you in cataloging everything you own, helping you avoid the clutter often associated with Diogenes Syndrome.
The application goal is to provide a faster and more user-friendly alternative to managing your belongings compared to a plain Excel spreadsheet.
To minimize time consumed it is possible to make use of Gemini AI
to automatically detect the items you add with an image.
- Pull the project or download the
docker-compose.yaml
and.example.env
. - Create a copy of the
example.env
into a.env
file with your own passwords (NOTE: Make sure theTOKEN_SECRET
is at least 32 characters long). - Add a certificate or create a self signed one for local network. Put them inside
ssl/cert.pem
andssl/cert.key
:
openssl req -new -x509 -days 365 -noenc -out ssl/cert.pem -keyout ssl/cert.key
- Start the containers with
docker-compose up -d
- The latest images can be found in the diogenes and diogenes-ng
-
The default user is username:
test1
, password:test1
. -
It can be modified by generating a new bcrypt hash which can be generated from a site like https://bcrypt-generator.com/:
-
First copy the hash and username to the following command into a new file named
token.tmp
. (Make sure to copy it after{bcrypt}
).
UPDATE public.users SET username='test1', password_hash='{bcrypt}$2a$12$8VhADH4b.DnQqSxPa/3BeOxgyl9lD2IT7NrynrZjBACTdJdny1ZNG', active=true WHERE id=1;
- Copy and execute the update in the container and then delete the file
docker cp token.tmp diogenes-db:/tmp
docker exec diogenes-db sh -c "psql diogenes_db -U <YOUR_POSTGRES_USER> -f /tmp/token.tmp"
docker exec -it diogenes-db rm /tmp/token.tmp
- To add an extra user change the command in the file to insert into and map the role in the table user_roles to the id of the new user.
INSERT INTO public.users
(username, password_hash, active)
VALUES('test1', '{bcrypt}$2a$12$8VhADH4b.DnQqSxPa/3BeOxgyl9lD2IT7NrynrZjBACTdJdny1ZNG', true);
INSERT INTO public.user_roles
(user_id, role_id)
VALUES(<ID_OF_THE_USER>, 1);
This project was generated using as base start spring:
https://start.spring.io/#!type=maven-project&language=java&platformVersion=3.0.4&packaging=jar&jvmVersion=17&groupId=io.nck&artifactId=diogenes&name=diogenes&description=Demo%20project%20for%20Spring%20Boot&packageName=io.nck.diogenes&dependencies=web]
-
Download maven
apache-maven-3.9.1
and add it to the path. -
Configure the
JAVA_HOME
pointing to the folder of the JDK17.- In windows with a ENVIRONMENT_VARIABLE (Can be added from path menu).
- In UNIX exporting with
export JAVA_HOME
.
-
Add you gemini api key to your
diogenes/.vscode/launch.json
:{ "configurations": [ { ... "env": { "GEMINI_API_KEY": "<your_key>" } } ] }
- Execute
cd diogenes & .\mvnw test
.
- Execute
cd diogenes && mvn test jacoco:report
. - The report will be generated in
diogenes\target\site\jacoco\index.html
.
- First build the image with
cd diogenes && ./mvnw install
. - Build the container with
cd .. && docker build -f docker/Dockerfile -t nck974/diogenes:0.2.0 .
- Generate a token in
https://hub.docker.com
and login withdocker login -u <user>
. Paste the generated token as password. - Push the generated container with
docker push nck974/diogenes:0.2.0
. - Create the
latest
tag and push it:
docker tag nck974/diogenes:0.2.0 nck974/diogenes:latest
docker push nck974/diogenes:latest
- Run the image with docker compose to pass the environment variables of the database.
To run the app in development mode just access the folder diogenes-ng
and start the app with ng serve
.
- Build the container with
docker build -f docker/Dockerfile.angular -t nck974/diogenes-ng:0.0.10 .
- Generate a token in
https://hub.docker.com
and login withdocker login -u <user>
. Paste the generated token as password. - Push the generated container with
docker push nck974/diogenes-ng:0.0.10
. - Create the
latest
tag and push it:
docker tag nck974/diogenes-ng:0.0.10 nck974/diogenes-ng:latest
docker push nck974/diogenes-ng:latest
- Run the image with docker compose to pass the environment variables of the database.
- Install:
npm install -g npm-check-updates
- Then:
ncu -u
-
Backend and frontend can be served using a custom reverse proxy or just use the one provided in the image. To do so build it with:
-
Build the container with
docker build -f docker/Dockerfile.nginx -t nck974/diogenes-reverse-proxy:0.0.2 .
-
Generate a token in
https://hub.docker.com
and login withdocker login -u <user>
. Paste the generated token as password. -
Push the generated container with
docker push nck974/diogenes-reverse-proxy:0.0.2
. -
Create the
latest
tag and push it:
docker tag nck974/diogenes-reverse-proxy:0.0.2 nck974/diogenes-reverse-proxy:latest
docker push nck974/diogenes-reverse-proxy:latest
TOC generated from ecotrust-canada