projects.go 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package service
  2. import (
  3. "fmt"
  4. "sfbase/core"
  5. "sfbase/elastic"
  6. "sfbase/global"
  7. "sfis/db"
  8. "strconv"
  9. "strings"
  10. )
  11. var (
  12. pjt_count = 100
  13. pjt_field = `"_id","area","city","bidamount","firsttime","projectname","s_winner","buyer","buyerclass"`
  14. pjt_sort = `{"firsttime":-1}`
  15. query = `{"query": {"bool": {"must":[%s],"should":[%s],"minimum_should_match": 1}}}`
  16. query_string = `{"constant_score": {"boost": 2,"query": {"match_phrase": {"projectname.pname": {"analyzer": "my_ngram","query": "%s","slop": 6}}}}},{"multi_match": {"query": "%s","fields": ["projectname.pname"],"analyzer": "ik","minimum_should_match": "100%%"}}`
  17. query_winner = `{"term": {"s_winner": "%s"}}`
  18. SR = strings.Replace
  19. HL = `"highlight": {"pre_tags": [""],"post_tags": [""],"fields": {%s}}`
  20. highlightStr = `%s: {"fragment_size": %d,"number_of_fragments": 1}`
  21. )
  22. func ProjectListData(projectName, winner, time string) (data *map[string]interface{}) {
  23. global.Logger.Info("projectName " + projectName)
  24. global.Logger.Info("winner " + winner)
  25. global.Logger.Info("time " + time)
  26. pjt_name := strings.TrimSpace(projectName)
  27. pjt_len := len([]rune(pjt_name))
  28. data = &map[string]interface{}{}
  29. qstr := ""
  30. if pjt_len >= 4 && winner == "" {
  31. qstr = fmt.Sprintf(query, "", fmt.Sprintf(query_string, pjt_name, pjt_name))
  32. } else if pjt_len >= 4 && winner != "" {
  33. qstr = fmt.Sprintf(query, fmt.Sprintf(query_winner, winner), fmt.Sprintf(query_string, pjt_name, pjt_name))
  34. } else if winner != "" {
  35. qstr = fmt.Sprintf(query, fmt.Sprintf(query_winner, winner), "")
  36. } else {
  37. return
  38. }
  39. INDEX := core.GetStringConf("es.project.index")
  40. TYPE := core.GetStringConf("es.project.itype")
  41. Es := db.GetEs()
  42. global.Logger.Info("INDEX " + INDEX)
  43. global.Logger.Info("TYPE " + TYPE)
  44. repl := GetAllByNgram(Es, INDEX, TYPE, qstr, "", pjt_sort, pjt_field, 0, pjt_count, 0, false)
  45. if repl != nil && len(*repl) > 0 {
  46. (*data)["data"] = repl
  47. }
  48. return
  49. }
  50. func GetAllByNgram(Es *elastic.Elastic, index, itype, qstr, findfields, order, fields string, start, limit, count int, highlight bool) *[]map[string]interface{} {
  51. if qstr != "" {
  52. if highlight {
  53. ws := []string{}
  54. for _, w := range strings.Split(findfields, ",") {
  55. ws = append(ws, fmt.Sprintf(highlightStr, w, count))
  56. }
  57. qstr = qstr[:len(qstr)-1] + `,` + fmt.Sprintf(HL, strings.Join(ws, ",")) + `}`
  58. }
  59. if len(fields) > 0 {
  60. qstr = qstr[:len(qstr)-1] + `,"_source":[` + fields + "]}"
  61. }
  62. if len(order) > 0 {
  63. qstr = qstr[:len(qstr)-1] + `,"sort":[` + SR(SR(SR(SR(order, ",", "},{", -1), " ", "", -1), ":-1", `:"desc"`, -1), ":1", `:"asc"`, -1) + `]}`
  64. }
  65. if start > -1 {
  66. qstr = qstr[:len(qstr)-1] + `,"from":` + strconv.Itoa(start) + `,"size":` + strconv.Itoa(limit) + "}"
  67. }
  68. global.Logger.Info("GetAllByNgram:" + qstr)
  69. return Es.Get(index, itype, qstr)
  70. } else {
  71. return nil
  72. }
  73. }