-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathgrdp.go
92 lines (79 loc) · 1.89 KB
/
grdp.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
package grdp
import (
"errors"
"fmt"
"github.com/icodeface/grdp/core"
"github.com/icodeface/grdp/glog"
"github.com/icodeface/grdp/protocol/nla"
"github.com/icodeface/grdp/protocol/pdu"
"github.com/icodeface/grdp/protocol/sec"
"github.com/icodeface/grdp/protocol/t125"
"github.com/icodeface/grdp/protocol/tpkt"
"github.com/icodeface/grdp/protocol/x224"
"log"
"net"
"os"
"strings"
"sync"
"time"
)
type Client struct {
Host string // ip:port
tpkt *tpkt.TPKT
x224 *x224.X224
mcs *t125.MCSClient
sec *sec.Client
pdu *pdu.Client
}
func NewClient(host string, logLevel glog.LEVEL) *Client {
glog.SetLevel(logLevel)
logger := log.New(os.Stdout, "", 0)
glog.SetLogger(logger)
return &Client{
Host: host,
}
}
func (g *Client) Login(user, pwd string) error {
conn, err := net.DialTimeout("tcp", g.Host, 3*time.Second)
if err != nil {
return errors.New(fmt.Sprintf("[dial err] %v", err))
}
defer conn.Close()
domain := strings.Split(g.Host, ":")[0]
g.tpkt = tpkt.New(core.NewSocketLayer(conn, nla.NewNTLMv2(domain, user, pwd)))
g.x224 = x224.New(g.tpkt)
g.mcs = t125.NewMCSClient(g.x224)
g.sec = sec.NewClient(g.mcs)
g.pdu = pdu.NewClient(g.sec)
g.sec.SetUser(user)
g.sec.SetPwd(pwd)
g.sec.SetDomain(domain)
g.tpkt.SetFastPathListener(g.pdu)
g.pdu.SetFastPathSender(g.tpkt)
g.x224.SetRequestedProtocol(x224.PROTOCOL_SSL | x224.PROTOCOL_HYBRID)
err = g.x224.Connect()
if err != nil {
return errors.New(fmt.Sprintf("[x224 connect err] %v", err))
}
wg := &sync.WaitGroup{}
wg.Add(1)
g.pdu.On("error", func(e error) {
err = e
glog.Error(e)
wg.Done()
}).On("close", func() {
err = errors.New("close")
glog.Info("on close")
wg.Done()
}).On("success", func() {
err = nil
glog.Info("on success")
wg.Done()
}).On("ready", func() {
glog.Info("on ready")
}).On("update", func(rectangles []pdu.BitmapData) {
glog.Info("on update")
})
wg.Wait()
return err
}