mirror of
https://github.com/amitbet/vncproxy.git
synced 2025-04-28 19:13:21 +00:00
72 lines
2.2 KiB
Go
72 lines
2.2 KiB
Go
package proxy
|
|
|
|
import (
|
|
"vncproxy/client"
|
|
"vncproxy/common"
|
|
"vncproxy/logger"
|
|
"vncproxy/server"
|
|
)
|
|
|
|
type ClientUpdater struct {
|
|
conn *client.ClientConn
|
|
}
|
|
|
|
// Consume recieves vnc-server-bound messages (Client messages) and updates the server part of the proxy
|
|
func (cc *ClientUpdater) Consume(seg *common.RfbSegment) error {
|
|
//logger.Debugf("ClientUpdater.Consume (vnc-server-bound): got segment type=%s bytes: %v", seg.SegmentType, seg.Bytes)
|
|
switch seg.SegmentType {
|
|
|
|
case common.SegmentFullyParsedClientMessage:
|
|
clientMsg := seg.Message.(common.ClientMessage)
|
|
logger.Debugf("ClientUpdater.Consume:(vnc-server-bound) got ClientMessage type=%s", clientMsg.Type())
|
|
switch clientMsg.Type() {
|
|
|
|
case common.SetPixelFormatMsgType:
|
|
// update pixel format
|
|
logger.Debugf("ClientUpdater.Consume: updating pixel format")
|
|
pixFmtMsg := clientMsg.(*server.SetPixelFormat)
|
|
cc.conn.PixelFormat = pixFmtMsg.PF
|
|
}
|
|
|
|
err := clientMsg.Write(cc.conn)
|
|
if err != nil {
|
|
logger.Errorf("ClientUpdater.Consume (vnc-server-bound, SegmentFullyParsedClientMessage): problem writing to port: %s", err)
|
|
}
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
type ServerUpdater struct {
|
|
conn *server.ServerConn
|
|
Name string
|
|
}
|
|
|
|
// Consume receives vnc-client-bound messages (Server messages) and updates the server part of the proxy
|
|
func (p *ServerUpdater) Consume(seg *common.RfbSegment) error {
|
|
|
|
logger.Debugf("ServerUpdater.Consume ("+p.Name+"): got segment type=%s bytes: %v", seg.SegmentType, seg.Bytes)
|
|
switch seg.SegmentType {
|
|
case common.SegmentMessageSeparator:
|
|
case common.SegmentRectSeparator:
|
|
case common.SegmentBytes:
|
|
// _, err := p.Writer.Write(seg.Bytes)
|
|
// if (err != nil) {
|
|
// logger.Errorf("WriteTo.Consume ("+p.Name+" SegmentBytes): problem writing to port: %s", err)
|
|
// }
|
|
// return err
|
|
case common.SegmentFullyParsedClientMessage:
|
|
|
|
// clientMsg := seg.Message.(common.ClientMessage)
|
|
// logger.Debugf("WriteTo.Consume ("+p.Name+"): got ClientMessage type=%s", clientMsg.Type())
|
|
// err := clientMsg.Write(p.Writer)
|
|
// if err != nil {
|
|
// logger.Errorf("WriteTo.Consume ("+p.Name+" SegmentFullyParsedClientMessage): problem writing to port: %s", err)
|
|
// }
|
|
// return err
|
|
default:
|
|
//return errors.New("WriteTo.Consume: undefined RfbSegment type")
|
|
}
|
|
return nil
|
|
}
|