zzi.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2000-2018, 达梦数据库有限公司.
  3. * All rights reserved.
  4. */
  5. package security
  6. import (
  7. "crypto/tls"
  8. "errors"
  9. "flag"
  10. "net"
  11. "os"
  12. "sync"
  13. )
  14. var dmHome = flag.String("DM_HOME", "", "Where DMDB installed")
  15. var flagLock = sync.Mutex{}
  16. func NewTLSFromTCP(conn net.Conn, sslCertPath string, sslKeyPath string, user string) (*tls.Conn, error) {
  17. if sslCertPath == "" && sslKeyPath == "" {
  18. // 为什么从os.getEnv改为flag? 参照JDBC,它通过System.getProperty()获取命令中的-DDM_HOME=值
  19. // flag非协程安全,内部存在并发写map的操作
  20. func () {
  21. flagLock.Lock()
  22. defer flagLock.Unlock()
  23. flag.Parse()
  24. }()
  25. separator := string(os.PathSeparator)
  26. if *dmHome != "" {
  27. sslCertPath = *dmHome + separator + "bin" + separator + "client_ssl" + separator +
  28. user + separator + "client-cert.pem"
  29. sslKeyPath = *dmHome + separator + "bin" + separator + "client_ssl" + separator +
  30. user + separator + "client-key.pem"
  31. } else {
  32. return nil, errors.New("sslCertPath and sslKeyPath can not be empty!")
  33. }
  34. }
  35. cer, err := tls.LoadX509KeyPair(sslCertPath, sslKeyPath)
  36. if err != nil {
  37. return nil, err
  38. }
  39. conf := &tls.Config{
  40. InsecureSkipVerify: true,
  41. Certificates: []tls.Certificate{cer},
  42. }
  43. tlsConn := tls.Client(conn, conf)
  44. if err := tlsConn.Handshake(); err != nil {
  45. return nil, err
  46. }
  47. return tlsConn, nil
  48. }