diff options
Diffstat (limited to 'vendor/github.com/go-sql-driver')
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/AUTHORS | 2 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/CHANGELOG.md | 31 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/README.md | 28 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/connection.go | 9 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/driver.go | 22 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/dsn.go | 45 | ||||
| -rw-r--r-- | vendor/github.com/go-sql-driver/mysql/packets.go | 8 | 
7 files changed, 97 insertions, 48 deletions
| diff --git a/vendor/github.com/go-sql-driver/mysql/AUTHORS b/vendor/github.com/go-sql-driver/mysql/AUTHORS index 3774919..466ac86 100644 --- a/vendor/github.com/go-sql-driver/mysql/AUTHORS +++ b/vendor/github.com/go-sql-driver/mysql/AUTHORS @@ -31,6 +31,7 @@ Julien Lefevre <julien.lefevr at gmail.com>  Julien Schmidt <go-sql-driver at julienschmidt.com>  Kamil Dziedzic <kamil at klecza.pl>  Kevin Malachowski <kevin at chowski.com> +Lennart Rudolph <lrudolph at hmc.edu>  Leonardo YongUk Kim <dalinaum at gmail.com>  Luca Looz <luca.looz92 at gmail.com>  Lucas Liu <extrafliu at gmail.com> @@ -44,6 +45,7 @@ Stan Putrya <root.vagner at gmail.com>  Stanley Gunawan <gunawan.stanley at gmail.com>  Xiaobing Jiang <s7v7nislands at gmail.com>  Xiuming Chen <cc at cxm.cc> +Zhenye Xie <xiezhenye at gmail.com>  # Organizations diff --git a/vendor/github.com/go-sql-driver/mysql/CHANGELOG.md b/vendor/github.com/go-sql-driver/mysql/CHANGELOG.md index 381d918..617ad80 100644 --- a/vendor/github.com/go-sql-driver/mysql/CHANGELOG.md +++ b/vendor/github.com/go-sql-driver/mysql/CHANGELOG.md @@ -3,16 +3,30 @@  Changes:   - Go 1.1 is no longer supported - - Use decimals field from MySQL to format time types (#249) + - Use decimals fields in MySQL to format time types (#249)   - Buffer optimizations (#269)   - TLS ServerName defaults to the host (#283) + - Refactoring (#400, #410, #437) + - Adjusted documentation for second generation CloudSQL (#485) -Bugfixes: +New Features:   - Enable microsecond resolution on TIME, DATETIME and TIMESTAMP (#249) + - Support for returning table alias on Columns() (#289, #359, #382) + - Placeholder interpolation, can be actived with the DSN parameter `interpolateParams=true` (#309, #318, #490) + - Support for uint64 parameters with high bit set (#332, #345) + - Cleartext authentication plugin support (#327) + - Exported ParseDSN function and the Config struct (#403, #419, #429) + - Read / Write timeouts (#401) + - Support for JSON field type (#414) + - Support for multi-statements and multi-results (#411, #431) + - DSN parameter to set the driver-side max_allowed_packet value manually (#489) + +Bugfixes: +   - Fixed handling of queries without columns and rows (#255)   - Fixed a panic when SetKeepAlive() failed (#298) - - Support receiving ERR packet while reading rows (#321) + - Handle ERR packets while reading rows (#321)   - Fixed reading NULL length-encoded integers in MySQL 5.6+ (#349)   - Fixed absolute paths support in LOAD LOCAL DATA INFILE (#356)   - Actually zero out bytes in handshake response (#378) @@ -20,13 +34,10 @@ Bugfixes:   - Fixed tests with MySQL 5.7.9+ (#380)   - QueryUnescape TLS config names (#397)   - Fixed "broken pipe" error by writing to closed socket (#390) - -New Features: - - Support for returning table alias on Columns() (#289, #359, #382) - - Placeholder interpolation, can be actived with the DSN parameter `interpolateParams=true` (#309, #318) - - Support for uint64 parameters with high bit set (#332, #345) - - Cleartext authentication plugin support (#327) - + - Fixed LOAD LOCAL DATA INFILE buffering (#424) + - Fixed parsing of floats into float64 when placeholders are used (#434) + - Fixed DSN tests with Go 1.7+ (#459) + - Handle ERR packets while waiting for EOF (#473)  ## Version 1.2 (2014-06-03) diff --git a/vendor/github.com/go-sql-driver/mysql/README.md b/vendor/github.com/go-sql-driver/mysql/README.md index c64aae2..a110cf1 100644 --- a/vendor/github.com/go-sql-driver/mysql/README.md +++ b/vendor/github.com/go-sql-driver/mysql/README.md @@ -221,6 +221,14 @@ Note that this sets the location for time.Time values but does not change MySQL'  Please keep in mind, that param values must be [url.QueryEscape](http://golang.org/pkg/net/url/#QueryEscape)'ed. Alternatively you can manually replace the `/` with `%2F`. For example `US/Pacific` would be `loc=US%2FPacific`. +##### `maxAllowedPacket` +``` +Type:          decimal number +Default:       0 +``` + +Max packet size allowed in bytes. Use `maxAllowedPacket=0` to automatically fetch the `max_allowed_packet` variable from server. +  ##### `multiStatements`  ``` @@ -233,7 +241,6 @@ Allow multiple statements in one query. While this allows batch queries, it also  When `multiStatements` is used, `?` parameters must only be used in the first statement. -  ##### `parseTime`  ``` @@ -254,7 +261,6 @@ Default:        0  I/O read timeout. The value must be a decimal number with an unit suffix ( *"ms"*, *"s"*, *"m"*, *"h"* ), such as *"30s"*, *"0.5m"* or *"1m30s"*. -  ##### `strict`  ``` @@ -263,10 +269,11 @@ Valid Values:   true, false  Default:        false  ``` -`strict=true` enables the strict mode in which MySQL warnings are treated as errors. +`strict=true` enables a driver-side strict mode in which MySQL warnings are treated as errors. This mode should not be used in production as it may lead to data corruption in certain situations. -By default MySQL also treats notes as warnings. Use [`sql_notes=false`](http://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_sql_notes) to ignore notes. See the [examples](#examples) for an DSN example. +A server-side strict mode, which is safe for production use, can be set via the [`sql_mode`](https://dev.mysql.com/doc/refman/5.7/en/sql-mode.html) system variable. +By default MySQL also treats notes as warnings. Use [`sql_notes=false`](http://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_sql_notes) to ignore notes.  ##### `timeout` @@ -277,7 +284,6 @@ Default:        OS default  *Driver* side connection timeout. The value must be a decimal number with an unit suffix ( *"ms"*, *"s"*, *"m"*, *"h"* ), such as *"30s"*, *"0.5m"* or *"1m30s"*. To set a server side timeout, use the parameter [`wait_timeout`](http://dev.mysql.com/doc/refman/5.6/en/server-system-variables.html#sysvar_wait_timeout). -  ##### `tls`  ``` @@ -288,7 +294,6 @@ Default:        false  `tls=true` enables TLS / SSL encrypted connection to the server. Use `skip-verify` if you want to use a self-signed or invalid certificate (server side). Use a custom value registered with [`mysql.RegisterTLSConfig`](http://godoc.org/github.com/go-sql-driver/mysql#RegisterTLSConfig). -  ##### `writeTimeout`  ``` @@ -322,9 +327,9 @@ root:pw@unix(/tmp/mysql.sock)/myDatabase?loc=Local  user:password@tcp(localhost:5555)/dbname?tls=skip-verify&autocommit=true  ``` -Use the [strict mode](#strict) but ignore notes: +Treat warnings as errors by setting the system variable [`sql_mode`](https://dev.mysql.com/doc/refman/5.7/en/sql-mode.html):  ``` -user:password@/dbname?strict=true&sql_notes=false +user:password@/dbname?sql_mode=TRADITIONAL  ```  TCP via IPv6: @@ -337,11 +342,16 @@ TCP on a remote host, e.g. Amazon RDS:  id:password@tcp(your-amazonaws-uri.com:3306)/dbname  ``` -Google Cloud SQL on App Engine: +Google Cloud SQL on App Engine (First Generation MySQL Server):  ```  user@cloudsql(project-id:instance-name)/dbname  ``` +Google Cloud SQL on App Engine (Second Generation MySQL Server): +``` +user@cloudsql(project-id:regionname:instance-name)/dbname +``` +  TCP using default port (3306) on localhost:  ```  user:password@tcp/dbname?charset=utf8mb4,utf8&sys_var=esc%40ped diff --git a/vendor/github.com/go-sql-driver/mysql/connection.go b/vendor/github.com/go-sql-driver/mysql/connection.go index c3899de..d82c728 100644 --- a/vendor/github.com/go-sql-driver/mysql/connection.go +++ b/vendor/github.com/go-sql-driver/mysql/connection.go @@ -22,7 +22,7 @@ type mysqlConn struct {  	affectedRows     uint64  	insertId         uint64  	cfg              *Config -	maxPacketAllowed int +	maxAllowedPacket int  	maxWriteSize     int  	writeTimeout     time.Duration  	flags            clientFlag @@ -135,6 +135,11 @@ func (mc *mysqlConn) Prepare(query string) (driver.Stmt, error) {  }  func (mc *mysqlConn) interpolateParams(query string, args []driver.Value) (string, error) { +	// Number of ? should be same to len(args) +	if strings.Count(query, "?") != len(args) { +		return "", driver.ErrSkip +	} +  	buf := mc.buf.takeCompleteBuffer()  	if buf == nil {  		// can not take the buffer. Something must be wrong with the connection @@ -241,7 +246,7 @@ func (mc *mysqlConn) interpolateParams(query string, args []driver.Value) (strin  			return "", driver.ErrSkip  		} -		if len(buf)+4 > mc.maxPacketAllowed { +		if len(buf)+4 > mc.maxAllowedPacket {  			return "", driver.ErrSkip  		}  	} diff --git a/vendor/github.com/go-sql-driver/mysql/driver.go b/vendor/github.com/go-sql-driver/mysql/driver.go index 899f955..562ddef 100644 --- a/vendor/github.com/go-sql-driver/mysql/driver.go +++ b/vendor/github.com/go-sql-driver/mysql/driver.go @@ -50,7 +50,7 @@ func (d MySQLDriver) Open(dsn string) (driver.Conn, error) {  	// New mysqlConn  	mc := &mysqlConn{ -		maxPacketAllowed: maxPacketSize, +		maxAllowedPacket: maxPacketSize,  		maxWriteSize:     maxPacketSize - 1,  	}  	mc.cfg, err = ParseDSN(dsn) @@ -109,15 +109,19 @@ func (d MySQLDriver) Open(dsn string) (driver.Conn, error) {  		return nil, err  	} -	// Get max allowed packet size -	maxap, err := mc.getSystemVar("max_allowed_packet") -	if err != nil { -		mc.Close() -		return nil, err +	if mc.cfg.MaxAllowedPacket > 0 { +		mc.maxAllowedPacket = mc.cfg.MaxAllowedPacket +	} else { +		// Get max allowed packet size +		maxap, err := mc.getSystemVar("max_allowed_packet") +		if err != nil { +			mc.Close() +			return nil, err +		} +		mc.maxAllowedPacket = stringToInt(maxap) - 1  	} -	mc.maxPacketAllowed = stringToInt(maxap) - 1 -	if mc.maxPacketAllowed < maxPacketSize { -		mc.maxWriteSize = mc.maxPacketAllowed +	if mc.maxAllowedPacket < maxPacketSize { +		mc.maxWriteSize = mc.maxAllowedPacket  	}  	// Handle DSN Params diff --git a/vendor/github.com/go-sql-driver/mysql/dsn.go b/vendor/github.com/go-sql-driver/mysql/dsn.go index 73138bc..896be9e 100644 --- a/vendor/github.com/go-sql-driver/mysql/dsn.go +++ b/vendor/github.com/go-sql-driver/mysql/dsn.go @@ -15,6 +15,7 @@ import (  	"fmt"  	"net"  	"net/url" +	"strconv"  	"strings"  	"time"  ) @@ -28,19 +29,20 @@ var (  // Config is a configuration parsed from a DSN string  type Config struct { -	User         string            // Username -	Passwd       string            // Password (requires User) -	Net          string            // Network type -	Addr         string            // Network address (requires Net) -	DBName       string            // Database name -	Params       map[string]string // Connection parameters -	Collation    string            // Connection collation -	Loc          *time.Location    // Location for time.Time values -	TLSConfig    string            // TLS configuration name -	tls          *tls.Config       // TLS configuration -	Timeout      time.Duration     // Dial timeout -	ReadTimeout  time.Duration     // I/O read timeout -	WriteTimeout time.Duration     // I/O write timeout +	User             string            // Username +	Passwd           string            // Password (requires User) +	Net              string            // Network type +	Addr             string            // Network address (requires Net) +	DBName           string            // Database name +	Params           map[string]string // Connection parameters +	Collation        string            // Connection collation +	Loc              *time.Location    // Location for time.Time values +	MaxAllowedPacket int               // Max packet size allowed +	TLSConfig        string            // TLS configuration name +	tls              *tls.Config       // TLS configuration +	Timeout          time.Duration     // Dial timeout +	ReadTimeout      time.Duration     // I/O read timeout +	WriteTimeout     time.Duration     // I/O write timeout  	AllowAllFiles           bool // Allow all files to be used with LOAD DATA LOCAL INFILE  	AllowCleartextPasswords bool // Allows the cleartext client side plugin @@ -222,6 +224,17 @@ func (cfg *Config) FormatDSN() string {  		buf.WriteString(cfg.WriteTimeout.String())  	} +	if cfg.MaxAllowedPacket > 0 { +		if hasParam { +			buf.WriteString("&maxAllowedPacket=") +		} else { +			hasParam = true +			buf.WriteString("?maxAllowedPacket=") +		} +		buf.WriteString(strconv.Itoa(cfg.MaxAllowedPacket)) + +	} +  	// other params  	if cfg.Params != nil {  		for param, value := range cfg.Params { @@ -496,7 +509,11 @@ func parseDSNParams(cfg *Config, params string) (err error) {  			if err != nil {  				return  			} - +		case "maxAllowedPacket": +			cfg.MaxAllowedPacket, err = strconv.Atoi(value) +			if err != nil { +				return +			}  		default:  			// lazy init  			if cfg.Params == nil { diff --git a/vendor/github.com/go-sql-driver/mysql/packets.go b/vendor/github.com/go-sql-driver/mysql/packets.go index 6025399..f06752b 100644 --- a/vendor/github.com/go-sql-driver/mysql/packets.go +++ b/vendor/github.com/go-sql-driver/mysql/packets.go @@ -80,7 +80,7 @@ func (mc *mysqlConn) readPacket() ([]byte, error) {  func (mc *mysqlConn) writePacket(data []byte) error {  	pktLen := len(data) - 4 -	if pktLen > mc.maxPacketAllowed { +	if pktLen > mc.maxAllowedPacket {  		return ErrPktTooLarge  	} @@ -786,7 +786,7 @@ func (stmt *mysqlStmt) readPrepareResultPacket() (uint16, error) {  // http://dev.mysql.com/doc/internals/en/com-stmt-send-long-data.html  func (stmt *mysqlStmt) writeCommandLongData(paramID int, arg []byte) error { -	maxLen := stmt.mc.maxPacketAllowed - 1 +	maxLen := stmt.mc.maxAllowedPacket - 1  	pktLen := maxLen  	// After the header (bytes 0-3) follows before the data: @@ -977,7 +977,7 @@ func (stmt *mysqlStmt) writeExecutePacket(args []driver.Value) error {  					paramTypes[i+i] = fieldTypeString  					paramTypes[i+i+1] = 0x00 -					if len(v) < mc.maxPacketAllowed-pos-len(paramValues)-(len(args)-(i+1))*64 { +					if len(v) < mc.maxAllowedPacket-pos-len(paramValues)-(len(args)-(i+1))*64 {  						paramValues = appendLengthEncodedInteger(paramValues,  							uint64(len(v)),  						) @@ -999,7 +999,7 @@ func (stmt *mysqlStmt) writeExecutePacket(args []driver.Value) error {  				paramTypes[i+i] = fieldTypeString  				paramTypes[i+i+1] = 0x00 -				if len(v) < mc.maxPacketAllowed-pos-len(paramValues)-(len(args)-(i+1))*64 { +				if len(v) < mc.maxAllowedPacket-pos-len(paramValues)-(len(args)-(i+1))*64 {  					paramValues = appendLengthEncodedInteger(paramValues,  						uint64(len(v)),  					) | 
