ticket_first_solution.rb 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. class Report::TicketFirstSolution
  2. =begin
  3. result = Report::TicketFirstSolution.aggs(
  4. range_start: '2015-01-01T00:00:00Z',
  5. range_end: '2015-12-31T23:59:59Z',
  6. interval: 'month', # quarter, month, week, day, hour, minute, second
  7. selector: selector, # ticket selector to get only a collection of tickets
  8. )
  9. returns
  10. [4,5,1,5,0,51,5,56,7,4]
  11. =end
  12. def self.aggs(params)
  13. interval = params[:interval]
  14. if params[:interval] == 'week'
  15. interval = 'day'
  16. end
  17. result = []
  18. if params[:interval] == 'month'
  19. start = Date.parse(params[:range_start])
  20. stop_interval = 12
  21. elsif params[:interval] == 'week'
  22. start = Date.parse(params[:range_start])
  23. stop_interval = 7
  24. elsif params[:interval] == 'day'
  25. start = Date.parse(params[:range_start])
  26. stop_interval = 31
  27. elsif params[:interval] == 'hour'
  28. start = Time.zone.parse(params[:range_start])
  29. stop_interval = 24
  30. elsif params[:interval] == 'minute'
  31. start = Time.zone.parse(params[:range_start])
  32. stop_interval = 60
  33. end
  34. (1..stop_interval).each do |_counter|
  35. if params[:interval] == 'month'
  36. stop = start.next_month
  37. elsif params[:interval] == 'week'
  38. stop = start.next_day
  39. elsif params[:interval] == 'day'
  40. stop = start.next_day
  41. elsif params[:interval] == 'hour'
  42. stop = start + 1.hour
  43. elsif params[:interval] == 'minute'
  44. stop = start + 1.minute
  45. end
  46. without_merged_tickets = {
  47. 'ticket_state.name' => {
  48. 'operator' => 'is not',
  49. 'value' => 'merged'
  50. }
  51. }
  52. params[:selector].merge!(without_merged_tickets)
  53. query, bind_params, tables = Ticket.selector2sql(params[:selector])
  54. ticket_list = Ticket.select('tickets.id, tickets.close_at, tickets.created_at').where(
  55. 'tickets.close_at IS NOT NULL AND tickets.close_at >= ? AND tickets.close_at < ?',
  56. start,
  57. stop,
  58. ).where(query, *bind_params).joins(tables)
  59. count = 0
  60. ticket_list.each do |ticket|
  61. closed_at = ticket.close_at
  62. created_at = ticket.created_at
  63. if (closed_at - (60 * 15) ) < created_at
  64. count += 1
  65. end
  66. end
  67. result.push count
  68. start = stop
  69. end
  70. result
  71. end
  72. =begin
  73. result = Report::TicketFirstSolution.items(
  74. range_start: '2015-01-01T00:00:00Z',
  75. range_end: '2015-12-31T23:59:59Z',
  76. selector: selector, # ticket selector to get only a collection of tickets
  77. )
  78. returns
  79. {
  80. count: 123,
  81. ticket_ids: [4,5,1,5,0,51,5,56,7,4],
  82. assets: assets,
  83. }
  84. =end
  85. def self.items(params)
  86. without_merged_tickets = {
  87. 'ticket_state.name' => {
  88. 'operator' => 'is not',
  89. 'value' => 'merged'
  90. }
  91. }
  92. selector = params[:selector].merge!(without_merged_tickets)
  93. query, bind_params, tables = Ticket.selector2sql(selector)
  94. ticket_list = Ticket.select('tickets.id, tickets.close_at, tickets.created_at').where(
  95. 'tickets.close_at IS NOT NULL AND tickets.close_at >= ? AND tickets.close_at < ?',
  96. params[:range_start],
  97. params[:range_end],
  98. ).where(query, *bind_params).joins(tables).order(close_at: :asc)
  99. count = 0
  100. assets = {}
  101. ticket_ids = []
  102. ticket_list.each do |ticket|
  103. closed_at = ticket.close_at
  104. created_at = ticket.created_at
  105. if (closed_at - (60 * 15) ) < created_at
  106. count += 1
  107. ticket_ids.push ticket.id
  108. end
  109. ticket_full = Ticket.find(ticket.id)
  110. assets = ticket_full.assets(assets)
  111. end
  112. {
  113. count: count,
  114. ticket_ids: ticket_ids,
  115. assets: assets,
  116. }
  117. end
  118. end