search.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. package main
  2. import (
  3. "encoding/json"
  4. "log"
  5. "regexp"
  6. "time"
  7. )
  8. // Segment stores source and translated texts.
  9. type Segment struct {
  10. Source, Target string
  11. }
  12. func (s *Segment) clean() {
  13. re := regexp.MustCompile("</?seg>")
  14. s.Source = re.ReplaceAllString(s.Source, "")
  15. s.Target = re.ReplaceAllString(s.Target, "")
  16. }
  17. // CleanedResults stores processed results from given TM.
  18. type CleanedResults struct {
  19. TMName string
  20. Segments []Segment
  21. }
  22. // SearchResults stores processed results from all TMs.
  23. type SearchResults struct {
  24. SearchPhrase string
  25. Results []CleanedResults
  26. TotalResults int
  27. }
  28. // ResultsFromServer stores results as received from server.
  29. type ResultsFromServer struct {
  30. ConcResult []struct {
  31. ConcordanceTextRanges []struct {
  32. Length, Start int
  33. }
  34. ConcordanceTranslationRanges []string
  35. Length, StartPos int
  36. TMEntry struct {
  37. SourceSegment, TargetSegment string
  38. }
  39. }
  40. ConcTransResult, Errors []string
  41. TotalConcResult int
  42. }
  43. func getCleanedResults(tempResults ResultsFromServer, TMFriendlyName string) CleanedResults {
  44. var tmResults CleanedResults
  45. maxReturnedBySever := 64
  46. numberOfSegments := tempResults.TotalConcResult
  47. if numberOfSegments > maxReturnedBySever {
  48. numberOfSegments = maxReturnedBySever
  49. }
  50. tmResults.Segments = make([]Segment, numberOfSegments)
  51. tmResults.TMName = TMFriendlyName
  52. for index := 0; index < numberOfSegments; index++ {
  53. result := tempResults.ConcResult[index]
  54. segment := Segment{result.TMEntry.SourceSegment, result.TMEntry.TargetSegment}
  55. segment.clean()
  56. tmResults.Segments[index] = segment
  57. }
  58. return tmResults
  59. }
  60. type searchQuery struct {
  61. SearchExpression []string
  62. }
  63. func getSearchJSON(text string) []byte {
  64. query := searchQuery{}
  65. query.SearchExpression = append(query.SearchExpression, text)
  66. queryJSON, err := json.Marshal(query)
  67. if err != nil {
  68. log.Printf("Error marshalling query: %v", err)
  69. return []byte{}
  70. }
  71. return queryJSON
  72. }
  73. // Search for given phrase in given TMs.
  74. func (app *Application) Search(TMs []TM, text string) SearchResults {
  75. searchJSON := getSearchJSON(text)
  76. tmURL := app.BaseURL + "tms/"
  77. var finalResults SearchResults
  78. finalResults.SearchPhrase = text
  79. for _, tm := range TMs {
  80. getTM := tmURL + tm.TMGuid
  81. concordanceURL := getTM + "/concordance"
  82. requestURL := concordanceURL + app.AuthString
  83. resp, err := postQuery(requestURL, searchJSON)
  84. if err != nil {
  85. log.Println(err)
  86. return finalResults
  87. }
  88. defer resp.Body.Close()
  89. if resp.StatusCode == 401 {
  90. time.Sleep(app.Delay)
  91. status, err := app.login()
  92. if !status || err != nil {
  93. log.Printf("Couldn't log in: %s", err)
  94. return finalResults
  95. }
  96. return app.Search(TMs, text)
  97. }
  98. var tempResults ResultsFromServer
  99. jsonDecoder(resp.Body, &tempResults)
  100. if tempResults.TotalConcResult > 0 {
  101. tmResults := getCleanedResults(tempResults, tm.FriendlyName)
  102. finalResults.Results = append(finalResults.Results, tmResults)
  103. finalResults.TotalResults += len(tmResults.Segments)
  104. }
  105. }
  106. return finalResults
  107. }