Рейтинг:1

Несоответствие между документами PyNaCl и документами libsodium

флаг us

Итак, если мы посмотрим сюда, то увидим, что libsodium использует для этого три разных алгоритма, что звучит странно для меня, потому что ничто не указывает на то, что в этих конкретных функциях используется что-либо, кроме Curve25519 (поля конкретно принимают закрытый и открытый ключи, и ничего не указывает там это любая генерация ключей для XSalsa20):

https://doc.libsodium.org/public-key_cryptography/authenticated_encryption#algorithm-details

И если мы посмотрим здесь, то указано, что реализация этого python использует только Curve25519:

https://pynacl.readthedocs.io/en/latest/public/#algorithm


Что здесь происходит?

Рейтинг:2
флаг si

В документах python перечислены только алгоритмы с открытым ключом, а не все алгоритмы, которые он использует. Poly1305 и XSalsa20 не являются алгоритмами с открытым ключом и поэтому не включены в список. Документы PyNacl просто неполны, внутри используется libsodium.

Стоит отметить, что Curve25519 всегда используется только для обмена ключами (в X25519), а не непосредственно для шифрования. Ed25519 использует кривую, бирационально эквивалентную Curve25519, для подписей. Хотя можно использовать Curve25519 в системе шифрования Эль-Гамаля, что нестандартно и не очень хорошая идея.

Ответить или комментировать

Большинство людей не понимают, что склонность к познанию нового открывает путь к обучению и улучшает межличностные связи. В исследованиях Элисон, например, хотя люди могли точно вспомнить, сколько вопросов было задано в их разговорах, они не чувствовали интуитивно связи между вопросами и симпатиями. В четырех исследованиях, в которых участники сами участвовали в разговорах или читали стенограммы чужих разговоров, люди, как правило, не осознавали, что задаваемый вопрос повлияет — или повлиял — на уровень дружбы между собеседниками.