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

Uploaded Source

File details

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

File metadata

  • Download URL: diffiehellmanlib-3.0a0.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.0a0.tar.gz
Algorithm Hash digest
SHA256 d7eef7fb5e2e98d9a4a28ab5e066bdcd33066c37a1d4e75d21ca602708abc874
MD5 79d3f68eda74a488742498a30031f7eb
BLAKE2b-256 d2219b625eb8f2dc6f7fb87d41a57a2b7c0e772b882597d539fa0f1a17881aac

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