Skip to main content

Simplified number generation library for the Diffie-Hellman protocol.

Project description

Diffie - Hellman Python/C++ Library

Описание

Эта библиотека реализует криптографический протокол Diffie-Hellman для безопасного обмена ключами через незащищённый канал. Она использует C++ для высокой скорости генерации больших простых чисел и Python-обёртку (wrapper) для упрощённой интеграции.

Основные возможности

  • Генерация параметров: простое число ( p ), основание ( g ), приватные ключи ( a, b ), публичные ключи ( A, B ).
  • Обмен ключами: функции для организации серверной и клиентской части через сокеты.
  • Поддержка хэширования: автоматическое хэширование общего ключа для безопасности.
  • Кроссплатформенность: поддержка Windows, Linux, и архитектур x86, x64, ARMv7, ARM64.

Установка

Для установки библиотеки используйте:

pip install diffiehellmanlib

Использование

Импорт библиотеки

from diffiehellmanlib import wrapper

Пример 1: Генерация параметров

Генерация ( p ) и ( g ):

p, g = wrapper.generate_p_g(2048)
print(f"Generated p: {p}, g: {g}")

Пример 2: Генерация публичного и приватного ключей

a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)
print(f"Private key (a): {a}, Public key (A): {A}")

Пример 3: Генерация общего ключа

После обмена ( A ) и ( B ):

shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")

Обмен ключами через сокеты

Функциональность доступна с версии 2.0

Библиотека предоставляет функции exchange_server и exchange_client для безопасного обмена ключами через сеть. В версии 3.0 проврка не хешей цифр, а подпись полностью сообщения через cryptography. Должно усилить безопасность.

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

Сервер

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_server("0.0.0.0", 5000, "127.0.0.1")
print(f"Shared key: {shared_key}")
  • IP: "0.0.0.0" позволяет принимать соединения на всех интерфейсах.
  • Порт: 5000 — порт для ожидания соединений.
  • Таргет IP: "127.0.0.1" — IP-адрес клиента, с которым разрешено соединение.

Клиент

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_client("127.0.0.1", 5000)
print(f"Shared key: {shared_key}")
  • Таргет IP сервера: "127.0.0.1".
  • Порт сервера: 5000.

Алгоритм работы

  1. Сервер
    • Генерирует ( p, g ), приватный ключ ( a ), и публичный ключ ( A ).
    • Отправляет их клиенту в формате JSON вместе с хэшами.
  2. Клиент
    • Проверяет корректность данных и генерирует ( b ), ( B ).
    • Отправляет публичный ключ ( B ) серверу.
  3. Общий ключ
    • Сервер и клиент рассчитывают общий ключ ( K ) с использованием своих приватных и чужих публичных ключей.

Формат сообщений

Сообщения передаются в формате JSON:

  • От сервера:
    {
        "error": false,
        "numbers": {"p": p, "g": g, "A": A},
        "hash": {"p": "hash_p", "g": "hash_g", "A": "hash_A"},
        "timeset": timeset
    }
    
  • От клиента:
    {
        "error": false,
        "numbers": {"B": B},
        "hashes": {"B": "hash_b"},
        "timeset": timeset
    }
    

Примеры полного использования (Ручной режим)

Alice (Серверная часть)

from diffiehellmanlib import wrapper

p, g = wrapper.generate_p_g(2048)
a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)

# Отправляем p, g, A Bob-у и получаем B
shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")

Bob (Клиентская часть)

from diffiehellmanlib import wrapper

# Получаем p, g, A от Alice
b = wrapper.generate_a_or_b(p, g)
B = wrapper.generate_A_or_B(p, g, b)

# Отправляем B Alice и рассчитываем общий ключ
shared_key = wrapper.generate_shared_key(A, p, g, b)
print(f"Shared key: {shared_key}")

Пример полного использования (Автоматический режим)

Alice (Серверная часть)

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_server(IP_alice, port, IP_bob)

print(f"Shared key: {shared_key}")

Bob (Клиентская часть)

from diffiehellmanlib.exchange import exchange

shared_key = exchange.exchange_client(IP_alice, port)

print(f"Shared key: {shared_key}")

Лицензия

MIT License


Авторы

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-3.0a1.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

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

diffiehellmanlib-3.0a1-py3-none-any.whl (4.9 MB view details)

Uploaded Python 3

File details

Details for the file diffiehellmanlib-3.0a1.tar.gz.

File metadata

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

File hashes

Hashes for diffiehellmanlib-3.0a1.tar.gz
Algorithm Hash digest
SHA256 e362142fa724e03cc1f6d0f51a75963658299c245a0ec3d6cff53462ef79a82f
MD5 022c2f55e01bd2eed632b2baf2620c5d
BLAKE2b-256 e8eb4dd166f2755716a63098886af093cbea960abde5c021c00d134ef945e79a

See more details on using hashes here.

File details

Details for the file diffiehellmanlib-3.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for diffiehellmanlib-3.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 68185ef96723e025037c0c9d8d70bdacc945ac747fe42bb07d2ba4ed3653db2e
MD5 25eb93ef0bc63e1c7229a1b1cd19efb4
BLAKE2b-256 2a8dc4f4895ca12f2c13560175eab79698b8e13acd83c5cf031ab938af63a5a7

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