Skip to main content

Библиотека упрошённой генерации чисел для протокола Diffie_Hellman =)

Project description

Diffie - Hellman Python/C++ libray

Описание: Это библиотека для генерирования чисел для использования криптографического протокола Diffie-Hellman. Испольуется C++ для максимальной (которой мне удалось достичь) скорости генерации p - больших простых чисел. Используется python wrapper (обёртка) чтобы использовать функции из .dll (для Windows) или из .so (для Linux). я не нашёл другого способа как можно из питона использовать C++ функции =).

Обзор функций из utils.h и utils.cpp

1. generate_p_g_a

  • Описание: Генерирует параметры ( p ) (простое число), ( g ) (основание) и ( a ) (приватное число).
  • Реализация:
    • Проверяет размер бит (от 512 до 8192).
    • Ограничение было введено для безопасности, минимально 512 для тестов и проверок, в реальных задачах, минимум 1024 а лучше 2048 бит.
    • Использует кэш для ускорения генерации ( p ), если число для данного размера уже сгенерировано.
    • Устанавливает ( g ) как 2.
    • Случайно генерирует ( a ) в диапазоне от ( 1 ) до ( p-1 ).
  • В Python-врапере:
    • Функция обёрнута как generate_p_g.
    • Возвращаются только ( p ) и ( g ). ( a ) освобождается.

2. generate_b

  • Описание: Генерирует приватное число ( b ) или ( a ), как выводную цифру назовёте.
  • Реализация:
    • Принимает ( p ) и ( g ) как входные данные.
    • Генерирует ( b ) или ( a ) в диапазоне от ( 1 ) до ( p-1 ).
  • В Python-врапере:
    • Переименована в generate_a_or_b.
    • Универсальная функция для генерации либо ( a ), либо ( b ).

3. generate_A

  • Описание: Генерирует ( A ) на основе ( p ), ( g ) и ( a ), где ( A = g^a \mod p ), может аналогично генерировать ( B ), просто формула станет: ( B = g^b \mod p )
  • Реализация:
    • Использует модульное экспоненциальное вычисление с помощью OpenSSL.
  • В Python-врапере:
    • Переименована в generate_A_or_B.
    • Универсальная функция для вычисления ( A ) или ( B ).

4. generate_shared_key

  • Описание: Генерирует общий ключ ( K ), используя ( A ), ( b ), ( p ), ( g ): ( K = A^b \mod p ), может также использовать и ( B ) с ( a ), также формула: ( K = B^a \mod p )
  • Реализация:
    • Вычисляет общий ключ на основе предоставленных данных.
  • В Python-врапере:
    • Общий ключ сразу передаётся в hash_shared_key для хэширования.
    • Возвращается хэшированный ключ.

5. hash_shared_key

  • Описание: Хэширует общий ключ с помощью SHA-256.
  • Реализация:
    • Преобразует ключ в строку 16-ричного формата.
  • В Python-врапере:
    • Вызов производится из generate_shared_key.

6. free_memory

  • Описание: Освобождает выделенную память для строк.
  • Реализация:
    • Использует OPENSSL_free для предотвращения утечек памяти.
  • В Python-врапере:
    • Используется для освобождения памяти после вызова каждой функции.

Дополнительные возможности Python-врапера

  1. Автоматическая загрузка библиотеки:

    • Определяет необходимую версию библиотеки DLL/SO на основе архитектуры и операционной системы.
    • Поддерживаются Windows (x86, x64) и Linux (x86, x64, ARMv7, ARM64).
  2. Переименование функций:

    • generate_bgenerate_a_or_b.
    • generate_Agenerate_A_or_B.
    • Это сделано для повышения универсальности функций.
  3. Автоматическое хэширование ключа:

    • Логика изменена: теперь общий ключ сразу хэшируется в generate_shared_key.
  4. Управление памятью:

    • Все строки, выделенные в C++, освобождаются с помощью free_memory, чтобы избежать утечек памяти.

Использование/Примеры

  1. Генерация параметров ( p ) и ( g )
from diffie_hellman_lib.wrapper import generate_p_g

# Генерация параметров с использованием 2048-битного ключа
p, g = generate_p_g(2048)
print(f"Generated p: {p}")
print(f"Generated g: {g}")

Результат: Выводит значения ( p ) и ( g ), сгенерированные для криптографических операций.


  1. Генерация приватного числа ( a ) или ( b )
from diffie_hellman_lib.wrapper import generate_a_or_b

# Пример значений p и g
p = 23  # Пример числа p
g = 5   # Пример числа g

# Генерация приватного числа a или b
private_value = generate_a_or_b(p, g)
print(f"Generated private value: {private_value}")

Возвращает случайное приватное число, используемое для генерации ключей.


  1. Генерация значения ( A ) или ( B )
from diffie_hellman_lib.wrapper import generate_A_or_B

# Пример значений
p = 23
g = 5
a = 6  # Приватное число

# Генерация A или B
public_value = generate_A_or_B(p, g, a)
print(f"Generated public value: {public_value}")

Результат: Возвращает значение ( A ) или ( B ).


  1. Генерация общего ключа ( K )
from diffie_hellman_lib.wrapper import generate_shared_key

# Пример значений
A = 8
p = 23
g = 5
b = 15

# Генерация общего ключа
shared_key = generate_shared_key(A, p, g, b)
print(f"Generated shared key (hashed): {shared_key}")

Результат: Возвращает общий ключ, который автоматически хэшируется с использованием SHA-256.


  1. Хэширование ключа
from diffie_hellman_lib.wrapper import hash_shared_key

# Пример общего ключа
shared_key = "123456"

# Хэширование общего ключа
hashed_key = hash_shared_key(shared_key)
print(f"Hashed key: {hashed_key}")

Результат: Возвращает SHA-256-хэш переданного общего ключа.


Пример полного использования

Логика Alice (первой стороны):

from diffie_hellman_lib import wrapper

p, g = wrapper.generate_p_g(1024) # получаем p и g, p размером 1024 бит. (рекомендуемо 2048)

a = wrapper.generate_a_or_b(p, g) # генерируем собственный секретный ключ
A = wrapper.generate_A_or_B(p, g, a) # генерируем свой публичный ключ

# логика отправки p, g, A Bob-у (Второй стороне) и логика получения B От Bob-а (Второй стороны) например через https или сокеты...

shared_key = wrapper.generate_shared_key(B, p, g, a) # Получаем общий секретный ключ
print(shared_key) # выводим полученный ключ

Логика Bob (второй стороны):

from diffie_hellman_lib import wrapper

# Логика получения от Alice чисел p, g, A...

b = wrapper.generate_a_or_b(p, g) # Генерируем свой секретный ключ
B = wrapper.generate_A_or_B(p, g, b) # генерируем свой публичный ключ

# Логика отправки B (публичного ключа), Alice (первой стороне) например через https или сокеты...

shared_key = wrapper.generate_shared_key(A, p, g, b) # Получаем  общий секретный ключ
print(shared_key) # выводим общий секретный ключ

Таким вот образом можно обменятся ключами шифрования между двумя сторонами по не зашифрованному каналу.

Лицензия

MIT

Авторы

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

diffiehellmanlib-1.5.2.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

diffiehellmanlib-1.5.2-py3-none-any.whl (5.0 kB view details)

Uploaded Python 3

File details

Details for the file diffiehellmanlib-1.5.2.tar.gz.

File metadata

  • Download URL: diffiehellmanlib-1.5.2.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for diffiehellmanlib-1.5.2.tar.gz
Algorithm Hash digest
SHA256 59115511899b49f6dd147a7b87b989432ca65f4d099b7a8a3dcb8f199097a480
MD5 bc9670e5da29859d2b05d081998e61f3
BLAKE2b-256 08ecc4004a5f8f9b34fd2bf7b2dc7327f217d720ca2b3bae4158101daf14100c

See more details on using hashes here.

File details

Details for the file diffiehellmanlib-1.5.2-py3-none-any.whl.

File metadata

File hashes

Hashes for diffiehellmanlib-1.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 c350204ad149ea623e8b8baaad08d9f1fbf569a81e36ab88162d35cfdb1ba350
MD5 0c7b6b4e6e3a2a7a3da165fab7e4375a
BLAKE2b-256 5d42afa4a72e4cc372d9c59edbb59f84992c3f33a8d1258556d2112e5e498dc9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page