mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	* update github.com/alecthomas/chroma v0.8.0 -> v0.8.1 * github.com/blevesearch/bleve v1.0.10 -> v1.0.12 * editorconfig-core-go v2.1.1 -> v2.3.7 * github.com/gliderlabs/ssh v0.2.2 -> v0.3.1 * migrate editorconfig.ParseBytes to Parse * github.com/shurcooL/vfsgen to 0d455de96546 * github.com/go-git/go-git/v5 v5.1.0 -> v5.2.0 * github.com/google/uuid v1.1.1 -> v1.1.2 * github.com/huandu/xstrings v1.3.0 -> v1.3.2 * github.com/klauspost/compress v1.10.11 -> v1.11.1 * github.com/markbates/goth v1.61.2 -> v1.65.0 * github.com/mattn/go-sqlite3 v1.14.0 -> v1.14.4 * github.com/mholt/archiver v3.3.0 -> v3.3.2 * github.com/microcosm-cc/bluemonday 4f7140c49acb -> v1.0.4 * github.com/minio/minio-go v7.0.4 -> v7.0.5 * github.com/olivere/elastic v7.0.9 -> v7.0.20 * github.com/urfave/cli v1.20.0 -> v1.22.4 * github.com/prometheus/client_golang v1.1.0 -> v1.8.0 * github.com/xanzy/go-gitlab v0.37.0 -> v0.38.1 * mvdan.cc/xurls v2.1.0 -> v2.2.0 Co-authored-by: Lauris BH <lauris@nix.lv>
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| // Copyright 2012-present Oliver Eilhard. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-license.
 | |
| // See http://olivere.mit-license.org/license.txt for details.
 | |
| 
 | |
| package elastic
 | |
| 
 | |
| // PinnedQuery is a query that promotes selected documents to rank higher than those matching a given query.
 | |
| //
 | |
| // For more details, see:
 | |
| // https://www.elastic.co/guide/en/elasticsearch/reference/7.8/query-dsl-pinned-query.html
 | |
| type PinnedQuery struct {
 | |
| 	ids     []string
 | |
| 	organic Query
 | |
| }
 | |
| 
 | |
| // NewPinnedQuery creates and initializes a new pinned query.
 | |
| func NewPinnedQuery() *PinnedQuery {
 | |
| 	return &PinnedQuery{}
 | |
| }
 | |
| 
 | |
| // Ids sets an array of document IDs listed in the order they are to appear in results.
 | |
| func (q *PinnedQuery) Ids(ids ...string) *PinnedQuery {
 | |
| 	q.ids = ids
 | |
| 	return q
 | |
| }
 | |
| 
 | |
| // Organic sets a choice of query used to rank documents which will be ranked below the "pinned" document ids.
 | |
| func (q *PinnedQuery) Organic(query Query) *PinnedQuery {
 | |
| 	q.organic = query
 | |
| 	return q
 | |
| }
 | |
| 
 | |
| // Source returns the JSON serializable content for this query.
 | |
| func (q *PinnedQuery) Source() (interface{}, error) {
 | |
| 	// {
 | |
| 	// 	  "pinned": {
 | |
| 	// 	  	"ids": [ "1", "4", "100" ],
 | |
| 	// 	  	"organic": {
 | |
| 	// 		  "match": {
 | |
| 	// 		    "description": "iphone"
 | |
| 	// 		  }
 | |
| 	// 		}
 | |
| 	//    }
 | |
| 	// }
 | |
| 
 | |
| 	query := make(map[string]interface{})
 | |
| 	params := make(map[string]interface{})
 | |
| 	query["pinned"] = params
 | |
| 	if len(q.ids) > 0 {
 | |
| 		params["ids"] = q.ids
 | |
| 	}
 | |
| 	if q.organic != nil {
 | |
| 		src, err := q.organic.Source()
 | |
| 		if err != nil {
 | |
| 			return nil, err
 | |
| 		}
 | |
| 		params["organic"] = src
 | |
| 	}
 | |
| 
 | |
| 	return query, nil
 | |
| }
 |