For English see translator https://translate.yandex.ru/?lang=ru-en or https://translate.google.com/?sl=ru&tl=en&op=translate
Требует .NET 7.0
Программа предназначена для работы под Linux, т.к. использует часть путей Linux (/dev/random), некоторые функции библиотеки libc и sh-скрипты для сборки
Не уверен, что доведу проект до конца. Пока для пользователя здесь нет ничего интересного. Приходите в конце 2026 года, возможно, я допишу, а может быть и нет. Основной репозиторий: VinKekFish.
Если вам интересно принять участие в тестировани шифрованного 512 битным ключом логического диска, напишите в issues. Диск шифруется со скоростью примерно 7 кбайт в секунду, чтение примерно 2 мбайт в секунду. К сожалению, ускорить запись не получается :( .
Это проект небольшого криптографического приложения с ключом 4096 битов симметричного шифрования (для платформы .NET 7.0, только под Linux). Основной шифр - самодельный VinKekFish стойкостью от 4096 до 45056 битов, построенный как губка на основе комбинации keccak и Threefish. Также в проекте используется keccak 512 битов в самодельной схеме шифрования и специальная каскадная губка из keccak, стойкостью от 2 килобитов до 88 килобитов. Так как шифр не проходил криптоанализ, стойкость не гарантируется. Так что на ваш страх и риск.
Реализация на C#.
Пока для пользователя здесь нет ничего интересного. Приходите в конце 2026 года, возможно, я допишу. В настоящий момент времени разработан сервис для сбора энтропии. Но, пока, всё находится в предварительной стадии.
Keccak версии 512 битов (максимальная длина из возможных)
Сам примитив
https://github.com/VinKekFish/VinKekFish/blob/main/src/main/3%20cryptoprime/keccak/KeccakPrime.cs
функция getHash512 - это пример, как рассчитать хеш (обратите внимание, этот хеш отличается от sha-3; в тестах есть расчёт и sha3)
https://github.com/VinKekFish/VinKekFish/blob/main/src/main/5%20main-crypto/keccak/keccak-20200918/keccak-base-20200918.cs
генератор псевдослучайных чисел (очень медленно работает; не протестирован)
https://github.com/VinKekFish/VinKekFish/blob/master/vinkekfish/keccak/keccak-20200918/Keccak_PRNG_20201128.cs
Threefish версии 1024 битов (тоже максимальная длина; реализовано только на шифрование). Осторожно, в реализации вручную нужно вычислить третий tweak (tweak1 ^ tweak2) и передать его в массиве твиков, а также вручную вычислить расширение ключа (класс threefish_unsafe как раз это делает).
Класс для подготовки ключей и твиков
Примеры использования смотрите в тестах в проекте main_tests. https://github.com/VinKekFish/VinKekFish/blob/main/src/tests/src/main/cryptoprime/keccak/tests/tests.cs https://github.com/VinKekFish/VinKekFish/tree/main/src/tests/src/main/cryptoprime/ThreeFish/tests
Описание примитива (пока не закончено)
Генератор псевдослучайных чисел и таблиц перестановок до 64*1024 элементов (пока не протестирован) Там же псевдослучайный (криптостойкий, естественно) перестановщик байтов в массиве любой длины.