ソースを参照

Add base of rpc handshake

tags/0.9
9seconds 7年前
コミット
5f54a235d2
2個のファイルの変更83行の追加2行の削除
  1. 2
    2
      mtproto/wrappers/crypt.go
  2. 81
    0
      telegram/middle.go

+ 2
- 2
mtproto/wrappers/crypt.go ファイルの表示

@@ -23,8 +23,8 @@ const (
23 23
 var emptyIP = [4]byte{0x00, 0x00, 0x00, 0x00}
24 24
 
25 25
 func NewMiddleProxyCipherRWC(conn wrappers.ReadWriteCloserWithAddr, req *rpc.RPCNonceRequest,
26
-	resp *rpc.RPCNonceResponse, client *net.TCPAddr, remote *net.TCPAddr,
27
-	secret []byte) wrappers.ReadWriteCloserWithAddr {
26
+	resp *rpc.RPCNonceResponse, client *net.TCPAddr, secret []byte) wrappers.ReadWriteCloserWithAddr {
27
+	remote := conn.Addr()
28 28
 	encryptor := newCBCCipher(CipherPurposeClient, req, resp, client, remote, secret)
29 29
 	decryptor := newCBCCipher(CipherPurposeServer, req, resp, client, remote, secret)
30 30
 

+ 81
- 0
telegram/middle.go ファイルの表示

@@ -1,6 +1,7 @@
1 1
 package telegram
2 2
 
3 3
 import (
4
+	"io/ioutil"
4 5
 	"net"
5 6
 	"net/http"
6 7
 	"sync"
@@ -9,7 +10,10 @@ import (
9 10
 
10 11
 	"github.com/9seconds/mtg/config"
11 12
 	"github.com/9seconds/mtg/mtproto"
13
+	"github.com/9seconds/mtg/mtproto/rpc"
14
+	mtwrappers "github.com/9seconds/mtg/mtproto/wrappers"
12 15
 	"github.com/9seconds/mtg/wrappers"
16
+	"github.com/juju/errors"
13 17
 )
14 18
 
15 19
 type middleTelegram struct {
@@ -39,5 +43,82 @@ func NewMiddleTelegram(conf *config.Config, logger *zap.SugaredLogger) Telegram
39 43
 }
40 44
 
41 45
 func (t *middleTelegram) Init(connOpts *mtproto.ConnectionOpts, conn wrappers.ReadWriteCloserWithAddr) (wrappers.ReadWriteCloserWithAddr, error) {
46
+	rpcNonceConn := mtwrappers.NewFrameRWC(conn, rpc.RPCNonceSeqNo)
47
+
48
+	rpcNonceReq, err := t.sendRPCNonceRequest(rpcNonceConn)
49
+	if err != nil {
50
+		return nil, err
51
+	}
52
+	rpcNonceResp, err := t.receiveRPCNonceResponse(rpcNonceConn, rpcNonceReq)
53
+	if err != nil {
54
+		return nil, err
55
+	}
56
+
57
+	secureConn := mtwrappers.NewFrameRWC(conn, rpc.RPCHandshakeSeqNo)
58
+	secureConn = mtwrappers.NewMiddleProxyCipherRWC(conn, rpcNonceReq,
59
+		rpcNonceResp, connOpts.ClientAddr, t.proxySecret)
60
+
61
+	rpcHandshakeReq, err := t.sendRPCHandshakeRequest(secureConn)
62
+	if err != nil {
63
+		return nil, err
64
+	}
65
+	_, err = t.receiveRPCHandshakeResponse(secureConn, rpcHandshakeReq)
66
+	if err != nil {
67
+		return nil, err
68
+	}
69
+
42 70
 	return nil, nil
43 71
 }
72
+
73
+func (t *middleTelegram) sendRPCNonceRequest(conn wrappers.ReadWriteCloserWithAddr) (*rpc.RPCNonceRequest, error) {
74
+	rpcNonceReq, err := rpc.NewRPCNonceRequest(t.proxySecret)
75
+	if err != nil {
76
+		return nil, errors.Annotate(err, "Cannot create RPC nonce request")
77
+	}
78
+	if _, err = conn.Write(rpcNonceReq.Bytes()); err != nil {
79
+		return nil, errors.Annotate(err, "Cannot send RPC nonce request")
80
+	}
81
+
82
+	return rpcNonceReq, nil
83
+}
84
+
85
+func (t *middleTelegram) receiveRPCNonceResponse(conn wrappers.ReadWriteCloserWithAddr, req *rpc.RPCNonceRequest) (*rpc.RPCNonceResponse, error) {
86
+	ans, err := ioutil.ReadAll(conn)
87
+	if err != nil {
88
+		return nil, errors.Annotate(err, "Cannot read RPC nonce response")
89
+	}
90
+	rpcNonceResp, err := rpc.NewRPCNonceResponse(ans)
91
+	if err != nil {
92
+		return nil, errors.Annotate(err, "Cannot initialize RPC nonce response")
93
+	}
94
+	if err = rpcNonceResp.Valid(req); err != nil {
95
+		return nil, errors.Annotate(err, "Invalid RPC nonce response")
96
+	}
97
+
98
+	return rpcNonceResp, nil
99
+}
100
+
101
+func (t *middleTelegram) sendRPCHandshakeRequest(conn wrappers.ReadWriteCloserWithAddr) (*rpc.RPCHandshakeRequest, error) {
102
+	req := rpc.NewRPCHandshakeRequest()
103
+	if _, err := conn.Write(req.Bytes()); err != nil {
104
+		return nil, errors.Annotate(err, "Cannot send RPC handshake request")
105
+	}
106
+
107
+	return req, nil
108
+}
109
+
110
+func (t *middleTelegram) receiveRPCHandshakeResponse(conn wrappers.ReadWriteCloserWithAddr, req *rpc.RPCHandshakeRequest) (*rpc.RPCHandshakeResponse, error) {
111
+	ans, err := ioutil.ReadAll(conn)
112
+	if err != nil {
113
+		return nil, errors.Annotate(err, "Cannot read RPC handshake response")
114
+	}
115
+	rpcHandshakeResp, err := rpc.NewRPCHandshakeResponse(ans)
116
+	if err != nil {
117
+		return nil, errors.Annotate(err, "Cannot initialize RPC handshake response")
118
+	}
119
+	if err = rpcHandshakeResp.Valid(req); err != nil {
120
+		return nil, errors.Annotate(err, "Invalid RPC handshake response")
121
+	}
122
+
123
+	return rpcHandshakeResp, nil
124
+}

読み込み中…
キャンセル
保存