ticket_first_solution.rb 3.5 KB

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