analytic.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package analytic
  2. import (
  3. "encoding/json"
  4. "net/http"
  5. "strings"
  6. "time"
  7. "imuslab.com/zoraxy/mod/database"
  8. "imuslab.com/zoraxy/mod/statistic"
  9. "imuslab.com/zoraxy/mod/utils"
  10. )
  11. type DataLoader struct {
  12. Database *database.Database
  13. StatisticCollector *statistic.Collector
  14. }
  15. // Create a new data loader for loading statistic from database
  16. func NewDataLoader(db *database.Database, sc *statistic.Collector) *DataLoader {
  17. return &DataLoader{
  18. Database: db,
  19. StatisticCollector: sc,
  20. }
  21. }
  22. func (d *DataLoader) HandleSummaryList(w http.ResponseWriter, r *http.Request) {
  23. entries, err := d.Database.ListTable("stats")
  24. if err != nil {
  25. utils.SendErrorResponse(w, "unable to load data from database")
  26. return
  27. }
  28. entryDates := []string{}
  29. for _, keypairs := range entries {
  30. entryDates = append(entryDates, string(keypairs[0]))
  31. }
  32. js, _ := json.MarshalIndent(entryDates, "", " ")
  33. utils.SendJSONResponse(w, string(js))
  34. }
  35. func (d *DataLoader) HandleLoadTargetDaySummary(w http.ResponseWriter, r *http.Request) {
  36. day, err := utils.GetPara(r, "id")
  37. if err != nil {
  38. utils.SendErrorResponse(w, "id cannot be empty")
  39. return
  40. }
  41. if strings.Contains(day, "-") {
  42. //Must be underscore
  43. day = strings.ReplaceAll(day, "-", "_")
  44. }
  45. if !statistic.IsBeforeToday(day) {
  46. utils.SendErrorResponse(w, "given date is in the future")
  47. return
  48. }
  49. var targetDailySummary statistic.DailySummaryExport
  50. if day == time.Now().Format("2006_01_02") {
  51. targetDailySummary = *d.StatisticCollector.GetExportSummary()
  52. } else {
  53. //Not today data
  54. err = d.Database.Read("stats", day, &targetDailySummary)
  55. if err != nil {
  56. utils.SendErrorResponse(w, "target day data not found")
  57. return
  58. }
  59. }
  60. js, _ := json.Marshal(targetDailySummary)
  61. utils.SendJSONResponse(w, string(js))
  62. }
  63. func (d *DataLoader) HandleLoadTargetRangeSummary(w http.ResponseWriter, r *http.Request) {
  64. //Get the start date from POST para
  65. start, err := utils.GetPara(r, "start")
  66. if err != nil {
  67. utils.SendErrorResponse(w, "start date cannot be empty")
  68. return
  69. }
  70. if strings.Contains(start, "-") {
  71. //Must be underscore
  72. start = strings.ReplaceAll(start, "-", "_")
  73. }
  74. //Get end date from POST para
  75. end, err := utils.GetPara(r, "end")
  76. if err != nil {
  77. utils.SendErrorResponse(w, "emd date cannot be empty")
  78. return
  79. }
  80. if strings.Contains(end, "-") {
  81. //Must be underscore
  82. end = strings.ReplaceAll(end, "-", "_")
  83. }
  84. //Generate all the dates in between the range
  85. keys, err := generateDateRange(start, end)
  86. if err != nil {
  87. utils.SendErrorResponse(w, err.Error())
  88. return
  89. }
  90. //Load all the data from database
  91. dailySummaries := []*statistic.DailySummaryExport{}
  92. for _, key := range keys {
  93. thisStat := statistic.DailySummaryExport{}
  94. err = d.Database.Read("stats", key, &thisStat)
  95. if err == nil {
  96. dailySummaries = append(dailySummaries, &thisStat)
  97. }
  98. }
  99. //Merge the summaries into one
  100. mergedSummary := mergeDailySummaryExports(dailySummaries)
  101. js, _ := json.Marshal(struct {
  102. Summary *statistic.DailySummaryExport
  103. Records []*statistic.DailySummaryExport
  104. }{
  105. Summary: mergedSummary,
  106. Records: dailySummaries,
  107. })
  108. utils.SendJSONResponse(w, string(js))
  109. }