feat: exchance keys with client

This commit is contained in:
2025-04-27 15:37:36 +02:00
parent 529dad17cf
commit aa82b32397

View File

@ -2,6 +2,8 @@ package client
import ( import (
"encoding/json" "encoding/json"
"fmt"
"io"
"maps" "maps"
"net" "net"
@ -9,13 +11,11 @@ import (
) )
type Client struct { type Client struct {
Duplex *hsp.PacketDuplex
Headers map[string]string Headers map[string]string
} }
func NewClient(headers map[string]string) *Client { func NewClient(headers map[string]string) *Client {
return &Client{ return &Client{
Duplex: nil,
Headers: headers, Headers: headers,
} }
} }
@ -34,17 +34,44 @@ func (c *Client) BuildHeaders(address *hsp.Adddress, df *hsp.DataFormat) map[str
} }
func (c *Client) SingleHit(addr *hsp.Adddress, pkt *hsp.Packet) (*hsp.Packet, error) { func (c *Client) SingleHit(addr *hsp.Adddress, pkt *hsp.Packet) (*hsp.Packet, error) {
conn, err := net.Dial("tcp", addr.String()) rawConn, err := net.Dial("tcp", addr.String())
if err != nil { if err != nil {
return nil, err return nil, err
} }
c.Duplex = hsp.NewPacketDuplex(conn) defer rawConn.Close()
if _, err := c.Duplex.WritePacket(pkt); err != nil {
keys, err := hsp.GenerateKeyPair()
if err != nil {
return nil, err return nil, err
} }
return c.Duplex.ReadPacket() n, err := rawConn.Write(keys.Public[:])
if err != nil {
return nil, err
}
if n != 32 {
return nil, fmt.Errorf("failed to send 32 bytes of key (%d sent instead)", n)
}
serverKey := make([]byte, 32)
if _, err := io.ReadFull(rawConn, serverKey); err != nil {
return nil, err
}
sharedKey, err := hsp.DeriveSharedKey(keys.Private, [32]byte(serverKey))
if err != nil {
return nil, err
}
conn := hsp.NewConnection(rawConn, keys, sharedKey)
if _, err := conn.Write(pkt); err != nil {
return nil, err
}
return conn.Read()
} }
func (c *Client) SendText(address, text string) (*hsp.Response, error) { func (c *Client) SendText(address, text string) (*hsp.Response, error) {