mirror of
https://gogs.blitter.com/RLabs/xs
synced 2024-08-14 10:26:42 +00:00
HMAC calc w/no xmit or verification, working..?
This commit is contained in:
parent
7c76e4d235
commit
744730ae23
3 changed files with 26 additions and 2 deletions
|
@ -128,7 +128,9 @@ func main() {
|
|||
_, err = conn.Write(rec.who)
|
||||
_, err = conn.Write(rec.cmd)
|
||||
_, err = conn.Write(rec.authCookie)
|
||||
|
||||
|
||||
conn.EnableHMAC()
|
||||
|
||||
//client reader (from server) goroutine
|
||||
wg.Add(1)
|
||||
go func() {
|
||||
|
|
|
@ -210,7 +210,9 @@ func main() {
|
|||
log.Println("[Bad cmdSpec.authCookie]")
|
||||
return err
|
||||
}
|
||||
|
||||
|
||||
conn.EnableHMAC()
|
||||
|
||||
log.Printf("[cmdSpec: op:%c who:%s cmd:%s auth:****]\n",
|
||||
rec.op[0], string(rec.who), string(rec.cmd))
|
||||
|
||||
|
|
20
hkexnet.go
20
hkexnet.go
|
@ -40,6 +40,8 @@ import (
|
|||
type Conn struct {
|
||||
c net.Conn // which also implements io.Reader, io.Writer, ...
|
||||
h *HerraduraKEx
|
||||
hmacOn bool // turned on once channel param negotiation is done
|
||||
byteCount int
|
||||
cipheropts uint32 // post-KEx cipher/hmac options
|
||||
opts uint32 // post-KEx protocol options (caller-defined)
|
||||
r cipher.Stream //read cipherStream
|
||||
|
@ -48,6 +50,10 @@ type Conn struct {
|
|||
wm hash.Hash
|
||||
}
|
||||
|
||||
func (c *Conn) EnableHMAC() {
|
||||
c.hmacOn = true
|
||||
}
|
||||
|
||||
// ConnOpts returns the cipher/hmac options value, which is sent to the
|
||||
// peer but is not itself part of the KEx.
|
||||
//
|
||||
|
@ -310,6 +316,13 @@ func (c Conn) Read(b []byte) (n int, err error) {
|
|||
rs := &cipher.StreamReader{S: c.r, R: db}
|
||||
n, err = rs.Read(b)
|
||||
log.Printf(" <-ptext:\r\n%s\r\n", hex.Dump(b[:n])) //EncodeToString(b[:n]))
|
||||
|
||||
if c.hmacOn {
|
||||
c.rm.Write(b[:n])
|
||||
c.byteCount += len(b[:n])
|
||||
fmt.Printf("(%x) HMAC:%x\r\n", c.byteCount, c.rm.Sum(nil))
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
|
@ -319,6 +332,13 @@ func (c Conn) Read(b []byte) (n int, err error) {
|
|||
func (c Conn) Write(b []byte) (n int, err error) {
|
||||
//log.Printf("[Encrypting...]\r\n")
|
||||
log.Printf(" :>ptext:\r\n%s\r\n", hex.Dump(b)) //EncodeToString(b))
|
||||
|
||||
if c.hmacOn {
|
||||
c.wm.Write(b)
|
||||
c.byteCount += len(b)
|
||||
fmt.Printf("(%x) HMAC:%x\r\n", c.byteCount, c.wm.Sum(nil))
|
||||
}
|
||||
|
||||
var wb bytes.Buffer
|
||||
// The StreamWriter acts like a pipe, forwarding whatever is
|
||||
// written to it through the cipher, encrypting as it goes
|
||||
|
|
Loading…
Reference in a new issue