search.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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, 0, numberOfSegments)
  51. tmResults.TMName = TMFriendlyName
  52. for _, result := range tempResults.ConcResult {
  53. segment := Segment{result.TMEntry.SourceSegment, result.TMEntry.TargetSegment}
  54. segment.clean()
  55. tmResults.Segments = append(tmResults.Segments, segment)
  56. }
  57. return tmResults
  58. }
  59. type searchQuery struct {
  60. SearchExpression []string
  61. }
  62. func getSearchJSON(text string) []byte {
  63. query := searchQuery{}
  64. query.SearchExpression = append(query.SearchExpression, text)
  65. queryJSON, err := json.Marshal(query)
  66. if err != nil {
  67. log.Printf("Error marshalling query: %v", err)
  68. return []byte{}
  69. }
  70. return queryJSON
  71. }
  72. // Search for given phrase in given TMs.
  73. func (app *Application) Search(TMs []TM, text string) SearchResults {
  74. searchJSON := getSearchJSON(text)
  75. tmURL := app.BaseURL + "tms/"
  76. var finalResults SearchResults
  77. finalResults.SearchPhrase = text
  78. for _, tm := range TMs {
  79. getTM := tmURL + tm.TMGuid
  80. concordanceURL := getTM + "/concordance"
  81. requestURL := concordanceURL + app.AuthString
  82. resp, err := postQuery(requestURL, searchJSON)
  83. if err != nil {
  84. log.Println(err)
  85. return finalResults
  86. }
  87. defer resp.Body.Close()
  88. if resp.StatusCode == 401 {
  89. time.Sleep(app.Delay)
  90. status, err := app.login()
  91. if !status || err != nil {
  92. log.Printf("Couldn't log in: %s", err)
  93. return finalResults
  94. }
  95. return app.Search(TMs, text)
  96. }
  97. var tempResults ResultsFromServer
  98. jsonDecoder(resp.Body, &tempResults)
  99. if tempResults.TotalConcResult > 0 {
  100. tmResults := getCleanedResults(tempResults, tm.FriendlyName)
  101. finalResults.Results = append(finalResults.Results, tmResults)
  102. finalResults.TotalResults += len(tmResults.Segments)
  103. }
  104. }
  105. return finalResults
  106. }