xugu_sock_recv.go 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305
  1. package xugu
  2. import (
  3. "bufio"
  4. "encoding/binary"
  5. "errors"
  6. "fmt"
  7. "net"
  8. )
  9. func xgSockRecvCommand(pConn *xuguConn) {
  10. }
  11. func xgSockRecvData(conn net.Conn, buffer *[]byte) (int, error) {
  12. // 接收服务器的返回消息
  13. n, err := conn.Read(*buffer)
  14. if err != nil {
  15. fmt.Println("接收服务器消息错误Error reading from server:", err)
  16. return 0, err
  17. }
  18. return n, nil
  19. }
  20. // TODO : pConn.bkChar != 0x0 这一部分代码需要修改
  21. func rhRecv(pConn *xuguConn, buff []byte, dLen uint32) error {
  22. //old_len := dLen
  23. if pConn.bkChar != 0x0 {
  24. buff[0] = pConn.bkChar
  25. pConn.bkChar = 0x0
  26. //buff = buff[1:]
  27. dLen--
  28. }
  29. //接收加密登录信息
  30. if dLen != 0 {
  31. for dLen != 0 {
  32. if pConn.useSSL {
  33. buffer := make([]byte, 1024)
  34. n, err := pConn.conn.Read(buffer)
  35. if err != nil {
  36. return err
  37. } else {
  38. //xgCacheRecv(pConn, buffer, int32(n))
  39. }
  40. if n <= 0 {
  41. return errors.New("read error")
  42. }
  43. }
  44. }
  45. // DECRYPT(p_conn, buff, old_len); //解密缓冲
  46. }
  47. return nil
  48. }
  49. // 接收单个字符
  50. func rhRecvChar(pConn *xuguConn, valp *byte) (bool, error) {
  51. var ch [1]byte
  52. err := rhRecv(pConn, ch[:], 1)
  53. if err != nil {
  54. return false, err
  55. }
  56. fmt.Println("ch[] = ", ch[:])
  57. *valp = ch[0]
  58. return true, nil
  59. }
  60. //读取检查一个字符
  61. func rhRecvStr(pConn *xuguConn, valp *[]byte) (int, error) {
  62. var len uint32
  63. if err := rhRecvInt32(pConn, &len); err != nil {
  64. return -4, err
  65. }
  66. pBuff := make([]byte, len+1)
  67. if err := rhRecv(pConn, pBuff, len); err != nil {
  68. return -4, err
  69. }
  70. pBuff[len] = 0x0
  71. *valp = pBuff
  72. return 0, nil
  73. }
  74. func rhRecvInt32(pconn *xuguConn, i *uint32) error {
  75. var buff [4]byte
  76. err := rhRecv(pconn, buff[:], 4)
  77. if err != nil {
  78. return err
  79. }
  80. // 将大端字节序转换为主机字节序
  81. *i = binary.BigEndian.Uint32(buff[:])
  82. return nil
  83. }
  84. // // 从连接中接收字段信息,并将其存储在 Result 结构体中。
  85. // func recvFiledsInfo(pConn *xuguConn, pRes *Result) (int, error) {
  86. // var fieldNum uint32
  87. // //var pRet *FieldInfo
  88. // if err := rhRecvInt32(pConn, &fieldNum); err != nil {
  89. // return XG_NET_ERROR, err
  90. // }
  91. // if fieldNum > 4000 {
  92. // return XG_NET_ERROR, errors.New("fieldNum >4000")
  93. // }
  94. // pRes.FieldNum = fieldNum
  95. // pRet := make([]FieldInfo, fieldNum)
  96. // //接收字段详细信息
  97. // for n := uint32(0); n < fieldNum; n++ {
  98. // if ret, err := recvAttrDesItem(pConn, &pRet[n]); err != nil {
  99. // return ret, err
  100. // }
  101. // }
  102. // bytesN := (fieldNum*2 + 7) / 8
  103. // for n := uint32(0); n < fieldNum; n++ {
  104. // pRet[n].Offset = bytesN
  105. // bytesN += uint32(getSQLCType(pRet[n].TypeID))
  106. // }
  107. // // TODO : 这里需要重新修改
  108. // // 在c代码中这里还加上了 ROW_HEAD_SIZE
  109. // pRes.RowSize = bytesN + 24
  110. // pRes.ColInfos = pRet
  111. // return 0, nil
  112. // }
  113. // // 接收字段属性描述
  114. // func recvAttrDesItem(pConn *xuguConn, pItem *FieldInfo) (int, error) {
  115. // var nameLen uint32
  116. // var tabName []byte
  117. // var alias []byte
  118. // if err := rhRecvInt32(pConn, &nameLen); err != nil {
  119. // return XG_NET_ERROR, err
  120. // }
  121. // if nameLen > 1024 {
  122. // return XG_NET_ERROR, errors.New("nameLen >1024")
  123. // }
  124. // var name []byte
  125. // if err := rhRecv(pConn, name, nameLen); err != nil {
  126. // return XG_NET_ERROR, err
  127. // }
  128. // if ret := bytes.IndexByte(name, '%'); ret != -1 {
  129. // alias = name[ret+1:]
  130. // name = name[:ret-1]
  131. // }
  132. // if ret := bytes.IndexByte(name, '.'); ret != -1 {
  133. // //如果 return_schema_on 为真,那么这里将得到 schema_name.tab_name。
  134. // tabName = name[:ret-1]
  135. // name = name[ret+1:]
  136. // }
  137. // pItem.TabName = string(tabName)
  138. // pItem.Name = string(name)
  139. // pItem.Alias = string(alias)
  140. // if err := rhRecvInt32(pConn, &pItem.TypeID); err != nil {
  141. // return XG_NET_ERROR, err
  142. // }
  143. // if err := rhRecvInt32(pConn, &pItem.Modi); err != nil {
  144. // return XG_NET_ERROR, err
  145. // }
  146. // if err := rhRecvInt32(pConn, &pItem.Flags); err != nil {
  147. // return XG_NET_ERROR, err
  148. // }
  149. // pItem.CTypeID = uint32(getSQLCType(pItem.TypeID))
  150. // return 0, nil
  151. // }
  152. func readInt32(reader *bufio.Reader) (int, error) {
  153. var value int32
  154. err := binary.Read(reader, binary.BigEndian, &value)
  155. return int(value), err
  156. }
  157. func recvParamsInfo2(pConn *xuguConn, params *XGCSParam) (int, error) {
  158. var paramNum uint32
  159. var i_ord []uint32
  160. var i_type []uint32
  161. var i_prescale []uint32
  162. pNames := make([][]byte, paramNum)
  163. rhRecvInt32(pConn, &paramNum)
  164. params.ParamNum = paramNum
  165. for n := uint32(0); n < paramNum; n++ {
  166. // 读取名称
  167. rhRecvStr(pConn, &pNames[n])
  168. // 读取序号
  169. rhRecvInt32(pConn, &i_ord[n])
  170. // 读取类型
  171. rhRecvInt32(pConn, &i_type[n])
  172. // 读取预缩放值
  173. rhRecvInt32(pConn, &i_prescale[n])
  174. }
  175. params.VParamName = pNames
  176. params.VParamNo = i_ord
  177. params.VType = i_type
  178. params.VParamSize = i_prescale
  179. return 0, nil
  180. }
  181. //接收结果集
  182. //int recv_Query_Rs(Conn_Attrs* p_conn,Result** pp_res,int*field_num,int64* rowcount,int* effected_num)
  183. /* recv_Query_Rs :
  184. * p_conn conn inout
  185. * pp_res output
  186. */
  187. // func recvQueryRs(pConn *xuguConn, ppRes **Result) int {
  188. // ret := 0
  189. // pres := &Result{}
  190. // pres_H := &Result{}
  191. // for {
  192. // var ch byte
  193. // rhRecvChar(pConn, &ch)
  194. // switch ch {
  195. // case 'k':
  196. // if pres_H != nil {
  197. // *ppRes = pres_H
  198. // } else {
  199. // *ppRes = pres
  200. // }
  201. // return ret
  202. // case 'E', 'F':
  203. // var errStr []byte
  204. // rhRecvStr(pConn, &errStr)
  205. // fmt.Printf("[EC031]Error in recv result :%s \n", errStr)
  206. // pConn.errStr = errStr
  207. // ret = XG_ERROR
  208. // continue
  209. // case 'W', 'M':
  210. // var errStr []byte
  211. // rhRecvStr(pConn, &errStr)
  212. // fmt.Printf("[EC032]Server Warning in recv result :%s \n", errStr)
  213. // pConn.errStr = errStr
  214. // ret = XG_ERROR // cyj 是否有点错误
  215. // case 'I':
  216. // //var len uint32
  217. // // if !rhRecvInt32(pConn, &len) {
  218. // // }
  219. // case 'U', 'D':
  220. // case 'A':
  221. // if pres == nil {
  222. // pres := &Result{}
  223. // pres.Type = HT_RS
  224. // } else {
  225. // var prev = &Result{}
  226. // if pres_H != nil {
  227. // prev = pres_H
  228. // for prev.NextResult != nil {
  229. // prev = prev.NextResult
  230. // }
  231. // } else {
  232. // pres_H = pres
  233. // prev = pres_H
  234. // }
  235. // pres = &Result{}
  236. // pres.Type = HT_RS
  237. // prev.NextResult = pres
  238. // }
  239. // pres.SQLType = SQL_SELECT
  240. // pres.DbcFlob = pConn
  241. // // _, err := recvFiledsInfo(pConn, pres)
  242. // // if err != nil {
  243. // // return XG_SOCKET_ERROR,
  244. // // }
  245. // }
  246. // }
  247. // return 0
  248. // }
  249. // recv_record
  250. // func recvRecords20000(p_conn *Conn_Attrs, p_res *Result) int {
  251. // pRow := RhRow{}
  252. // // if p_res.PBlokmemls == nil{
  253. // // p_res.PBlokmemls =
  254. // // }
  255. // for i := 0; i < 20000; i++ {
  256. // //recvRecord(p_conn, p_res, &pRow)
  257. // }
  258. // }
  259. func recvRecord() {
  260. }