Materia is a simple and fast cloud storage
Go to file
L-Nafaryus 93189789f2
improve documentation and fix build stages
fix: broken imports in vue components
fix: broken import of optional documentation module
2024-09-28 01:48:38 +05:00
docs improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
src/materia improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
tests tune openapi 2024-08-30 23:28:58 +05:00
workspaces/frontend improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
.gitignore new: documentation 2024-09-06 11:13:25 +05:00
alembic.ini rename materia_server -> materia, serve spa via backend + assets 2024-07-31 16:37:04 +05:00
flake.lock update dependencies 2024-08-03 01:01:01 +05:00
flake.nix improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
LICENSE base project setup 2024-05-07 16:49:30 +05:00
mkdocs.yml improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
pdm.lock improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
pdm.toml improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
pyproject.toml improve documentation and fix build stages 2024-09-28 01:48:38 +05:00
README.md improve documentation and fix build stages 2024-09-28 01:48:38 +05:00

Materia

Materia

nix-flake bonfire-cachix

Materia is a simple and fast cloud storage

Documentation: https://storage.elnafo.ru/docs

Source: https://vcs.elnafo.ru/L-Nafaryus/materia

Materia is a modern and high-performance cloud storage (thanks to FastAPI and Vue) built with REST in mind.

/// warning

This project is still in development. You can test it but at your own risk.

You can also create an issue.

///

Example

Standalone backend server

/// warning

The project is currently unstable for packaging due to the complex setup. So the best way is to use the sources. It also uses a specific development environment via Nix. Tools like Podman can easily be replaced with Docker, so be careful.

///

First of all you need to prepare working instances of Postgres (database) and Redis (broker). There are many ways, you can choose any.

  • Postgres:
nix build .#postgresql-devel
podman load < result
podman run -p 54320:5432 --name database -dt postgresql:latest
  • Redis:
nix build .#redis-devel
podman load < result
podman run -p 63790:6379 --name cache -dt redis:latest
  • Development environment:
nix develop
pdm install --dev
eval $(pdm venv activate)
  • Running tests (pytest):
pytest
  • Running server:
MATERIA_DATABASE__PORT=54320 MATERIA_CACHE__PORT=63790 materia start
  • Generating configuration and starting with it:
materia config export --path ./config.toml
materia start --config config.toml 

Standalone frontend server

The frontend does not include a client by default. It must be generated from the OpenAPI specification which in turn must be generated from the current state of the FastAPI application. After that you can safely run the Vite server or build the entire Vue project.

nix develop
pdm install --dev
eval $(pdm venv activate)

materia export openapi --path workspaces/frontend/openapi.json

cd workspaces/frontend
npm install 
npm run openapi
  • Running frontend server:
npm run dev 

In development mode, the server is configured to the address and port of the backend server.

Design

At the current stage, the PDM package manager is used, since it is the only one that copes well with the concept of a monorepository. At the output, two Python packages should be built - materia (backend server) and materia-frontend (which wraps a built version of the NPM package materia-frontend-vue). Documentation (optional) and the frontend are served through the backend server.

The target platform of the project is NixOS. This also indirectly affects the approach to choosing tools for developing the current project and the support priority. And only secondly, packaging components for registries such as pypi and others. Support for the rest is a matter of time.

Build

All build steps are wrapped in PDM pre-build scripts, so in a typical case you only need PDM and NodeJS.

  • materia:
nix develop 
pdm build --skip ":all"
  • materia with documentation:
nix develop 
pdm install --prod --no-default --group docs
pdm build
  • materia-frontend:
nix develop 
pdm install --prod
cd workspaces/frontend
pdm build

License

materia is licensed under the terms of the MIT License.