Проект по курсу "Децентрализованные Системы" в НИУ ВШЭ
- Хранилище - файлы загружаются в ipfs, он выдает хеши на загруженные в него объекты.
- Высокодоступная отказоустойчивая база метаданных отвечает за хранение метаданных по загруженным в ipfs объектам. Эта база хранит хеши и вспомогательную инфу типа формат объекта (видео, аудио, пдф и т.д.), время загрузки, кто загрузил, размер объекта, ключевые слова, описание и т.д.
- Локальное SQLite хранилище + IPFS PubSub, которые дают возможность узнавать участникам о новых метаданных в IPFS, даже в случае если удаленная база метаданных недоступна.
- Клиент - программа, которая позволяет пользователю загрузить или найти какой-либо объект, загруженный в ipfs.
- Компонент, который кладет в ipfs объект и записывает в базу данных метаинфу. У компонента должен быть интерфейс типа /put или соответствующий публичный метод на питоне.
- Компонент - демон, который работает в фоновом режиме, опрашивает pubsub на наличие новых метаданных, и добавляет их в локальную SQLite, если такие имеются.
- База метаданных с репликацией. У базы (PostgreSQL) SQL интерфейс типа SELECT/INSERT INTO запрос.
- Часть CLI клиента, которая отвечает за запрос на загрузку в ipfs объекта, то есть обрабатывает инпут от клиента и формирует соответствующий payload в 1ую компоненту.
- Часть CLI клиента, отвечающая за перевод поискового запроса пользователя в запрос в базу метаданных и выдачу ему результатов (ссылок, по которым, он может из ipfs это все скачать)
# background daemon
python ./updater.py &
# upload
python ./main.py upload file_examples/sample.mp4 --format "notes" --tags "tag1,tag2,tag3"
# search
python ./main.py search --search "project" --type "notes"