ical_tickets_controller.rb 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. # Copyright (C) 2012-2015 Zammad Foundation, http://zammad-foundation.org/
  2. require 'icalendar'
  3. class IcalTicketsController < ApplicationController
  4. before_filter { authentication_check_action_token 'iCal' }
  5. # @path [GET] /ical/tickets_all/:action_token
  6. #
  7. # @summary Returns an iCal file with all tickets (open, new, pending, esclation) as events.
  8. #
  9. # @parameter action_token(required) [String] The action_token identifying the requested User privileged for 'iCal' action.
  10. #
  11. # @response_message 200 [String] iCal file ready to import in calendar applications.
  12. # @response_message 500 Permission denied.
  13. def all
  14. new_open_events_data = new_open_events_data_get
  15. pending_events_data = pending_events_data_get
  16. escalation_events_data = escalation_events_data_get
  17. events_data = new_open_events_data + pending_events_data + escalation_events_data
  18. events_data_to_ical( events_data )
  19. end
  20. # @path [GET] /ical/tickets_new_open/:action_token
  21. #
  22. # @summary Returns an iCal file with all new and open tickets as events.
  23. #
  24. # @parameter action_token(required) [String] The action_token identifying the requested User privileged for 'iCal' action.
  25. #
  26. # @response_message 200 [String] iCal file ready to import in calendar applications.
  27. # @response_message 500 Permission denied.
  28. def new_open
  29. events_data = new_open_events_data_get
  30. events_data_to_ical( events_data )
  31. end
  32. # @path [GET] /ical/tickets_pending/:action_token
  33. #
  34. # @summary Returns an iCal file with all pending tickets as events.
  35. #
  36. # @parameter action_token(required) [String] The action_token identifying the requested User privileged for 'iCal' action.
  37. #
  38. # @response_message 200 [String] iCal file ready to import in calendar applications.
  39. # @response_message 500 Permission denied.
  40. def pending
  41. events_data = pending_events_data_get
  42. events_data_to_ical( events_data )
  43. end
  44. # @path [GET] /ical/ticket_escalation/:action_token
  45. #
  46. # @summary Returns an iCal file with all escalation times for tickets as events.
  47. #
  48. # @parameter action_token(required) [String] The action_token identifying the requested User privileged for 'iCal' action.
  49. #
  50. # @response_message 200 [String] iCal file ready to import in calendar applications.
  51. # @response_message 500 Permission denied.
  52. def escalation
  53. events_data = escalation_events_data_get
  54. events_data_to_ical( events_data )
  55. end
  56. private
  57. def new_open_events_data_get
  58. condition = {
  59. 'tickets.owner_id' => current_user.id,
  60. 'tickets.state_id' => Ticket::State.where(
  61. :state_type_id => Ticket::StateType.where(
  62. :name => [
  63. 'new',
  64. 'open',
  65. ],
  66. ),
  67. ),
  68. }
  69. tickets = Ticket.search(
  70. :current_user => current_user,
  71. :condition => condition,
  72. )
  73. events_data = []
  74. tickets.each do |ticket|
  75. event_data = {}
  76. event_data[:dtstart] = Icalendar::Values::Date.new( Date.today )
  77. event_data[:dtend] = Icalendar::Values::Date.new( Date.today )
  78. event_data[:summary] = "#{ ticket.state.name } ticket: '#{ ticket.title }'"
  79. event_data[:description] = "T##{ ticket.number }"
  80. events_data.push event_data
  81. end
  82. return events_data
  83. end
  84. def pending_events_data_get
  85. condition = {
  86. 'tickets.owner_id' => current_user.id,
  87. 'tickets.state_id' => Ticket::State.where(
  88. :state_type_id => Ticket::StateType.where(
  89. :name => [
  90. 'pending reminder',
  91. 'pending action',
  92. ],
  93. ),
  94. ),
  95. }
  96. tickets = Ticket.search(
  97. :current_user => current_user,
  98. :condition => condition,
  99. )
  100. events_data = []
  101. tickets.each do |ticket|
  102. event_data = {}
  103. event_data[:dtstart] = Icalendar::Values::DateTime.new( ticket.pending_time )
  104. event_data[:dtend] = Icalendar::Values::DateTime.new( ticket.pending_time )
  105. event_data[:summary] = "#{ ticket.state.name } ticket: '#{ ticket.title }'"
  106. event_data[:description] = "T##{ ticket.number }"
  107. events_data.push event_data
  108. end
  109. return events_data
  110. end
  111. def escalation_events_data_get
  112. condition = [
  113. 'tickets.escalation_time IS NOT NULL',
  114. 'tickets.owner_id = ?', current_user.id
  115. ]
  116. tickets = Ticket.search(
  117. :current_user => current_user,
  118. :condition => condition,
  119. )
  120. events_data = []
  121. tickets.each do |ticket|
  122. event_data = {}
  123. event_data[:dtstart] = Icalendar::Values::DateTime.new( ticket.escalation_time )
  124. event_data[:dtend] = Icalendar::Values::DateTime.new( ticket.escalation_time )
  125. event_data[:summary] = "ticket escalation: '#{ ticket.title }'"
  126. event_data[:description] = "T##{ ticket.number }"
  127. events_data.push event_data
  128. end
  129. return events_data
  130. end
  131. def events_data_to_ical(events_data)
  132. cal = Icalendar::Calendar.new
  133. events_data.each do |event_data|
  134. cal.event do |e|
  135. e.dtstart = event_data[:dtstart]
  136. e.dtend = event_data[:dtend]
  137. e.summary = event_data[:summary]
  138. e.description = event_data[:description]
  139. e.ip_class = "PRIVATE"
  140. end
  141. end
  142. send_data(
  143. cal.to_ical,
  144. :filename => 'new_open.ical',
  145. :type => 'text/plain',
  146. :disposition => 'inline'
  147. )
  148. end
  149. end