123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- class Report::TicketFirstSolution
- =begin
- result = Report::TicketFirstSolution.aggs(
- range_start: Time.zone.parse('2015-01-01T00:00:00Z'),
- range_end: Time.zone.parse('2015-12-31T23:59:59Z'),
- interval: 'month', # quarter, month, week, day, hour, minute, second
- selector: selector, # ticket selector to get only a collection of tickets
- )
- returns
- [4,5,1,5,0,51,5,56,7,4]
- =end
- def self.aggs(params_origin)
- params = params_origin.dup
- interval = params[:interval]
- if params[:interval] == 'week'
- interval = 'day'
- end
- result = []
- if params[:interval] == 'month'
- stop_interval = 12
- elsif params[:interval] == 'week'
- stop_interval = 7
- elsif params[:interval] == 'day'
- stop_interval = 31
- elsif params[:interval] == 'hour'
- stop_interval = 24
- elsif params[:interval] == 'minute'
- stop_interval = 60
- end
- (1..stop_interval).each do |_counter|
- if params[:interval] == 'month'
- params[:range_end] = params[:range_start].next_month
- elsif params[:interval] == 'week'
- params[:range_end] = params[:range_start].next_day
- elsif params[:interval] == 'day'
- params[:range_end] = params[:range_start].next_day
- elsif params[:interval] == 'hour'
- params[:range_end] = params[:range_start] + 1.hour
- elsif params[:interval] == 'minute'
- params[:range_end] = params[:range_start] + 1.minute
- end
- without_merged_tickets = {
- 'ticket_state.name' => {
- 'operator' => 'is not',
- 'value' => 'merged'
- }
- }
- params[:selector].merge!(without_merged_tickets)
- query, bind_params, tables = Ticket.selector2sql(params[:selector])
- ticket_list = Ticket.select('tickets.id, tickets.close_at, tickets.created_at').where(
- 'tickets.close_at IS NOT NULL AND tickets.close_at >= ? AND tickets.close_at < ?',
- params[:range_start],
- params[:range_end],
- ).where(query, *bind_params).joins(tables)
- count = 0
- ticket_list.each do |ticket|
- closed_at = ticket.close_at
- created_at = ticket.created_at
- if (closed_at - (60 * 15) ) < created_at
- count += 1
- end
- end
- result.push count
- params[:range_start] = params[:range_end]
- end
- result
- end
- =begin
- result = Report::TicketFirstSolution.items(
- range_start: Time.zone.parse('2015-01-01T00:00:00Z'),
- range_end: Time.zone.parse('2015-12-31T23:59:59Z'),
- selector: selector, # ticket selector to get only a collection of tickets
- timezone: 'Europe/Berlin',
- )
- returns
- {
- count: 123,
- ticket_ids: [4,5,1,5,0,51,5,56,7,4],
- assets: assets,
- }
- =end
- def self.items(params)
- without_merged_tickets = {
- 'ticket_state.name' => {
- 'operator' => 'is not',
- 'value' => 'merged'
- }
- }
- selector = params[:selector].merge!(without_merged_tickets)
- query, bind_params, tables = Ticket.selector2sql(selector)
- ticket_list = Ticket.select('tickets.id, tickets.close_at, tickets.created_at').where(
- 'tickets.close_at IS NOT NULL AND tickets.close_at >= ? AND tickets.close_at < ?',
- params[:range_start],
- params[:range_end],
- ).where(query, *bind_params).joins(tables).order(close_at: :asc)
- count = 0
- assets = {}
- ticket_ids = []
- ticket_list.each do |ticket|
- closed_at = ticket.close_at
- created_at = ticket.created_at
- if (closed_at - (60 * 15) ) < created_at
- count += 1
- ticket_ids.push ticket.id
- end
- ticket_full = Ticket.find(ticket.id)
- assets = ticket_full.assets(assets)
- end
- {
- count: count,
- ticket_ids: ticket_ids,
- assets: assets,
- }
- end
- end
|