mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 17:09:18 -04:00 
			
		
		
		
	* update github.com/blevesearch/bleve v2.0.2 -> v2.0.3 * github.com/denisenkom/go-mssqldb v0.9.0 -> v0.10.0 * github.com/editorconfig/editorconfig-core-go v2.4.1 -> v2.4.2 * github.com/go-chi/cors v1.1.1 -> v1.2.0 * github.com/go-git/go-billy v5.0.0 -> v5.1.0 * github.com/go-git/go-git v5.2.0 -> v5.3.0 * github.com/go-ldap/ldap v3.2.4 -> v3.3.0 * github.com/go-redis/redis v8.6.0 -> v8.8.2 * github.com/go-sql-driver/mysql v1.5.0 -> v1.6.0 * github.com/go-swagger/go-swagger v0.26.1 -> v0.27.0 * github.com/lib/pq v1.9.0 -> v1.10.1 * github.com/mattn/go-sqlite3 v1.14.6 -> v1.14.7 * github.com/go-testfixtures/testfixtures v3.5.0 -> v3.6.0 * github.com/issue9/identicon v1.0.1 -> v1.2.0 * github.com/klauspost/compress v1.11.8 -> v1.12.1 * github.com/mgechev/revive v1.0.3 -> v1.0.6 * github.com/microcosm-cc/bluemonday v1.0.7 -> v1.0.8 * github.com/niklasfasching/go-org v1.4.0 -> v1.5.0 * github.com/olivere/elastic v7.0.22 -> v7.0.24 * github.com/pelletier/go-toml v1.8.1 -> v1.9.0 * github.com/prometheus/client_golang v1.9.0 -> v1.10.0 * github.com/xanzy/go-gitlab v0.44.0 -> v0.48.0 * github.com/yuin/goldmark v1.3.3 -> v1.3.5 * github.com/6543/go-version v1.2.4 -> v1.3.1 * do github.com/lib/pq v1.10.0 -> v1.10.1 again ...
		
			
				
	
	
		
			175 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			175 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package pq
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"database/sql"
 | |
| 	"database/sql/driver"
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 	"io/ioutil"
 | |
| 	"sync/atomic"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // Implement the "QueryerContext" interface
 | |
| func (cn *conn) QueryContext(ctx context.Context, query string, args []driver.NamedValue) (driver.Rows, error) {
 | |
| 	list := make([]driver.Value, len(args))
 | |
| 	for i, nv := range args {
 | |
| 		list[i] = nv.Value
 | |
| 	}
 | |
| 	finish := cn.watchCancel(ctx)
 | |
| 	r, err := cn.query(query, list)
 | |
| 	if err != nil {
 | |
| 		if finish != nil {
 | |
| 			finish()
 | |
| 		}
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	r.finish = finish
 | |
| 	return r, nil
 | |
| }
 | |
| 
 | |
| // Implement the "ExecerContext" interface
 | |
| func (cn *conn) ExecContext(ctx context.Context, query string, args []driver.NamedValue) (driver.Result, error) {
 | |
| 	list := make([]driver.Value, len(args))
 | |
| 	for i, nv := range args {
 | |
| 		list[i] = nv.Value
 | |
| 	}
 | |
| 
 | |
| 	if finish := cn.watchCancel(ctx); finish != nil {
 | |
| 		defer finish()
 | |
| 	}
 | |
| 
 | |
| 	return cn.Exec(query, list)
 | |
| }
 | |
| 
 | |
| // Implement the "ConnBeginTx" interface
 | |
| func (cn *conn) BeginTx(ctx context.Context, opts driver.TxOptions) (driver.Tx, error) {
 | |
| 	var mode string
 | |
| 
 | |
| 	switch sql.IsolationLevel(opts.Isolation) {
 | |
| 	case sql.LevelDefault:
 | |
| 		// Don't touch mode: use the server's default
 | |
| 	case sql.LevelReadUncommitted:
 | |
| 		mode = " ISOLATION LEVEL READ UNCOMMITTED"
 | |
| 	case sql.LevelReadCommitted:
 | |
| 		mode = " ISOLATION LEVEL READ COMMITTED"
 | |
| 	case sql.LevelRepeatableRead:
 | |
| 		mode = " ISOLATION LEVEL REPEATABLE READ"
 | |
| 	case sql.LevelSerializable:
 | |
| 		mode = " ISOLATION LEVEL SERIALIZABLE"
 | |
| 	default:
 | |
| 		return nil, fmt.Errorf("pq: isolation level not supported: %d", opts.Isolation)
 | |
| 	}
 | |
| 
 | |
| 	if opts.ReadOnly {
 | |
| 		mode += " READ ONLY"
 | |
| 	} else {
 | |
| 		mode += " READ WRITE"
 | |
| 	}
 | |
| 
 | |
| 	tx, err := cn.begin(mode)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	cn.txnFinish = cn.watchCancel(ctx)
 | |
| 	return tx, nil
 | |
| }
 | |
| 
 | |
| func (cn *conn) Ping(ctx context.Context) error {
 | |
| 	if finish := cn.watchCancel(ctx); finish != nil {
 | |
| 		defer finish()
 | |
| 	}
 | |
| 	rows, err := cn.simpleQuery(";")
 | |
| 	if err != nil {
 | |
| 		return driver.ErrBadConn // https://golang.org/pkg/database/sql/driver/#Pinger
 | |
| 	}
 | |
| 	rows.Close()
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (cn *conn) watchCancel(ctx context.Context) func() {
 | |
| 	if done := ctx.Done(); done != nil {
 | |
| 		finished := make(chan struct{}, 1)
 | |
| 		go func() {
 | |
| 			select {
 | |
| 			case <-done:
 | |
| 				select {
 | |
| 				case finished <- struct{}{}:
 | |
| 				default:
 | |
| 					// We raced with the finish func, let the next query handle this with the
 | |
| 					// context.
 | |
| 					return
 | |
| 				}
 | |
| 
 | |
| 				// Set the connection state to bad so it does not get reused.
 | |
| 				cn.setBad()
 | |
| 
 | |
| 				// At this point the function level context is canceled,
 | |
| 				// so it must not be used for the additional network
 | |
| 				// request to cancel the query.
 | |
| 				// Create a new context to pass into the dial.
 | |
| 				ctxCancel, cancel := context.WithTimeout(context.Background(), time.Second*10)
 | |
| 				defer cancel()
 | |
| 
 | |
| 				_ = cn.cancel(ctxCancel)
 | |
| 			case <-finished:
 | |
| 			}
 | |
| 		}()
 | |
| 		return func() {
 | |
| 			select {
 | |
| 			case <-finished:
 | |
| 				cn.setBad()
 | |
| 				cn.Close()
 | |
| 			case finished <- struct{}{}:
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (cn *conn) cancel(ctx context.Context) error {
 | |
| 	// Create a new values map (copy). This makes sure the connection created
 | |
| 	// in this method cannot write to the same underlying data, which could
 | |
| 	// cause a concurrent map write panic. This is necessary because cancel
 | |
| 	// is called from a goroutine in watchCancel.
 | |
| 	o := make(values)
 | |
| 	for k, v := range cn.opts {
 | |
| 		o[k] = v
 | |
| 	}
 | |
| 
 | |
| 	c, err := dial(ctx, cn.dialer, o)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	defer c.Close()
 | |
| 
 | |
| 	{
 | |
| 		bad := &atomic.Value{}
 | |
| 		bad.Store(false)
 | |
| 		can := conn{
 | |
| 			c:   c,
 | |
| 			bad: bad,
 | |
| 		}
 | |
| 		err = can.ssl(o)
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 
 | |
| 		w := can.writeBuf(0)
 | |
| 		w.int32(80877102) // cancel request code
 | |
| 		w.int32(cn.processID)
 | |
| 		w.int32(cn.secretKey)
 | |
| 
 | |
| 		if err := can.sendStartupPacket(w); err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	// Read until EOF to ensure that the server received the cancel.
 | |
| 	{
 | |
| 		_, err := io.Copy(ioutil.Discard, c)
 | |
| 		return err
 | |
| 	}
 | |
| }
 |