go-tls

command module
v0.0.0-...-4ea3ae0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 26, 2022 License: MIT Imports: 2 Imported by: 0

README

TLS Experiment

Minimal TLS 1.2 Client Handshake implementation in Go. The project was implemented for academic purpose.

Support

  • The project can be easily extended with more cipher suites. At the moment it has support only for TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384.
  • Each TLS structure can be visualized in JSON format.

Workflow

  1. Creates Client Hello
  2. Receives and parses Server Hello, Server Certificate, Server Key Exchange, Server Hello Done
  3. Generates and sends Client Key Exchange
  4. Calculates Client Encryption Keys
  5. Sends Client Change Cipher Spec, Client Handshake Finished
  6. Receives and parses Server Change Cipher Spec, Server Handshake Finished
  7. Encrypts a raw HTTP request and sends Client Application Data
  8. Receives Server Application Data
  9. Decrypts the HTTP response

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
Package tls partially implements TLS 1.2, as specified in RFC 5246, and TLS 1.3, as specified in RFC 8446.
Package tls partially implements TLS 1.2, as specified in RFC 5246, and TLS 1.3, as specified in RFC 8446.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL