Skip to content

Commit

Permalink
fix(#92): Add MySQL SSL support
Browse files Browse the repository at this point in the history
Changes:
- Added parameters (SSLCA, SSLCert, SSLKey) to support MySQL SSL connections.
- Implemented TLS configuration in mysql_connect.go.
- Extended connection struct to include SSL parameters in jobs_init.go and conf.go.
  • Loading branch information
randreev1321 committed Oct 9, 2024
1 parent b0c4c34 commit 56700f6
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 1 deletion.
3 changes: 3 additions & 0 deletions ctx/conf.go
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,9 @@ type sourceConnectConf struct {
Socket string `conf:"socket"`
DBUser string `conf:"db_user"`
DBPassword string `conf:"db_password"`
SSLCA string `conf:"ssl_ca"`
SSLCert string `conf:"ssl_cert"`
SSLKey string `conf:"ssl_key"`
MySQLAuthFile string `conf:"mysql_auth_file"`
PsqlSSLMode string `conf:"psql_ssl_mode" conf_extraopts:"default=require"`
PsqlSSlRootCert string `conf:"psql_ssl_root_cert"`
Expand Down
6 changes: 6 additions & 0 deletions ctx/jobs_init.go
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,9 @@ func jobsInit(o jobsOpts) ([]interfaces.Job, error) {
Host: src.Connect.DBHost,
Port: src.Connect.DBPort,
Socket: src.Connect.Socket,
SSLCA: src.Connect.SSLCA,
SSLCert: src.Connect.SSLCert,
SSLKey: src.Connect.SSLKey,
},
Name: src.Name,
TargetDBs: src.TargetDBs,
Expand Down Expand Up @@ -230,6 +233,9 @@ func jobsInit(o jobsOpts) ([]interfaces.Job, error) {
Host: src.Connect.DBHost,
Port: src.Connect.DBPort,
Socket: src.Connect.Socket,
SSLCA: src.Connect.SSLCA,
SSLCert: src.Connect.SSLCert,
SSLKey: src.Connect.SSLKey,
},
Name: src.Name,
TargetDBs: src.TargetDBs,
Expand Down
61 changes: 60 additions & 1 deletion ds/mysql_connect/mysql_connect.go
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@
package mysql_connect

import (
"crypto/tls"
"crypto/x509"
"fmt"

"github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
"gopkg.in/ini.v1"
"os"
)

type Params struct {
Expand All @@ -15,9 +17,13 @@ type Params struct {
Host string // Network host
Port string // Network port
Socket string // Socket path
SSLCA string
SSLCert string
SSLKey string
}

func GetConnectAndCnfFile(conn Params, sectionName string) (*sqlx.DB, *ini.File, error) {
var withTls bool

dumpAuthCfg := ini.Empty()
_ = dumpAuthCfg.NewSections(sectionName)
Expand Down Expand Up @@ -53,6 +59,18 @@ func GetConnectAndCnfFile(conn Params, sectionName string) (*sqlx.DB, *ini.File,
conn.Port = port
_, _ = dumpAuthCfg.Section(sectionName).NewKey("port", port)
}
if ca := s.Key("ssl-ca").MustString(""); ca != "" {
conn.SSLCA = ca
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-ca", ca)
}
if cert := s.Key("ssl-cert").MustString(""); cert != "" {
conn.SSLCert = cert
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-cert", cert)
}
if key := s.Key("ssl-key").MustString(""); key != "" {
conn.SSLKey = key
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-key", key)
}
break
}
} else {
Expand All @@ -71,6 +89,44 @@ func GetConnectAndCnfFile(conn Params, sectionName string) (*sqlx.DB, *ini.File,
if conn.Port != "" {
_, _ = dumpAuthCfg.Section(sectionName).NewKey("port", conn.Port)
}
if conn.SSLCA != "" {
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-ca", conn.SSLCA)
}
if conn.SSLCert != "" {
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-cert", conn.SSLCert)
}
if conn.SSLKey != "" {
_, _ = dumpAuthCfg.Section(sectionName).NewKey("ssl-key", conn.SSLKey)
}
}

if conn.SSLCert != "" && conn.SSLKey != "" {
var caCertPool *x509.CertPool

if conn.SSLCA != "" {
caCertPool = x509.NewCertPool()
caCert, err := os.ReadFile(conn.SSLCA)
if err != nil {
return nil, dumpAuthCfg, err
}
if ok := caCertPool.AppendCertsFromPEM(caCert); !ok {
return nil, dumpAuthCfg, fmt.Errorf("failed to append ca certs")
}
//insecure = false
}
cert, err := tls.LoadX509KeyPair(conn.SSLCert, conn.SSLKey)
if err != nil {
return nil, dumpAuthCfg, err
}

if err = mysql.RegisterTLSConfig("custom", &tls.Config{
RootCAs: caCertPool,
Certificates: []tls.Certificate{cert},
InsecureSkipVerify: true,
}); err != nil {
return nil, dumpAuthCfg, err
}
withTls = true
}

cfg := mysql.NewConfig()
Expand All @@ -83,6 +139,9 @@ func GetConnectAndCnfFile(conn Params, sectionName string) (*sqlx.DB, *ini.File,
cfg.Net = "tcp"
cfg.Addr = fmt.Sprintf("%s:%s", conn.Host, conn.Port)
}
if withTls {
cfg.TLSConfig = "custom"
}

db, err := sqlx.Connect("mysql", cfg.FormatDSN())

Expand Down

0 comments on commit 56700f6

Please sign in to comment.