tickets_controller.rb 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520
  1. class TicketsController < ApplicationController
  2. before_filter :authentication_check
  3. # GET /tickets
  4. def index
  5. @tickets = Ticket.all
  6. render :json => @tickets
  7. end
  8. # GET /tickets/1
  9. def show
  10. @ticket = Ticket.find( params[:id] )
  11. # permissin check
  12. return if !ticket_permission(@ticket)
  13. render :json => @ticket
  14. end
  15. # POST /tickets
  16. def create
  17. @ticket = Ticket.new( params[:ticket] )
  18. @ticket.updated_by_id = current_user.id
  19. @ticket.created_by_id = current_user.id
  20. # check if article is given
  21. if !params[:article]
  22. render :json => 'article hash is missing', :status => :unprocessable_entity
  23. return
  24. end
  25. # create ticket
  26. if !@ticket.save
  27. render :json => @ticket.errors, :status => :unprocessable_entity
  28. return
  29. end
  30. # create tags if given
  31. if params[:tags] && !params[:tags].empty?
  32. tags = params[:tags].split /,/
  33. tags.each {|tag|
  34. Tag.tag_add(
  35. :object => 'Ticket',
  36. :o_id => @ticket.id,
  37. :item => tag,
  38. :created_by_id => current_user.id,
  39. )
  40. }
  41. end
  42. # create article if given
  43. if params[:article]
  44. @article = Ticket::Article.new(params[:article])
  45. @article.created_by_id = params[:article][:created_by_id] || current_user.id
  46. @article.updated_by_id = params[:article][:updated_by_id] || current_user.id
  47. @article.ticket_id = @ticket.id
  48. # find attachments in upload cache
  49. @article['attachments'] = Store.list(
  50. :object => 'UploadCache::TicketZoom::' + current_user.id.to_s,
  51. :o_id => @article.ticket_id
  52. )
  53. if !@article.save
  54. render :json => @article.errors, :status => :unprocessable_entity
  55. return
  56. end
  57. # remove attachments from upload cache
  58. Store.remove(
  59. :object => 'UploadCache::TicketZoom::' + current_user.id.to_s,
  60. :o_id => @article.ticket_id
  61. )
  62. end
  63. render :json => @ticket, :status => :created
  64. end
  65. # PUT /tickets/1
  66. def update
  67. @ticket = Ticket.find(params[:id])
  68. # permissin check
  69. return if !ticket_permission(@ticket)
  70. params[:ticket][:updated_by_id] = current_user.id
  71. if @ticket.update_attributes( params[:ticket] )
  72. render :json => @ticket, :status => :ok
  73. else
  74. render :json => @ticket.errors, :status => :unprocessable_entity
  75. end
  76. end
  77. # DELETE /tickets/1
  78. def destroy
  79. @ticket = Ticket.find( params[:id] )
  80. # permissin check
  81. return if !ticket_permission(@ticket)
  82. @ticket.destroy
  83. head :ok
  84. end
  85. # GET /ticket_customer
  86. # GET /tickets_customer
  87. def ticket_customer
  88. # get closed/open states
  89. ticket_state_list_open = Ticket::State.where(
  90. :ticket_state_type_id => Ticket::StateType.where( :name => ['new','open', 'pending reminder', 'pending action'] )
  91. )
  92. ticket_state_list_closed = Ticket::State.where(
  93. :ticket_state_type_id => Ticket::StateType.where( :name => ['closed'] )
  94. )
  95. # get tickets
  96. tickets_open = Ticket.where(
  97. :customer_id => params[:customer_id],
  98. :ticket_state_id => ticket_state_list_open
  99. ).limit(15).order('created_at DESC')
  100. tickets_closed = Ticket.where(
  101. :customer_id => params[:customer_id],
  102. :ticket_state_id => ticket_state_list_closed
  103. ).limit(15).order('created_at DESC')
  104. # tickets = Ticket.where(:customer_id => user_id).limit(15).order('created_at DESC')
  105. # ticket_items = []
  106. # tickets.each do |ticket|
  107. # style = ''
  108. # ticket_state_type = ticket.ticket_state.ticket_state_type.name
  109. # if ticket_state_type == 'closed' || ticket_state_type == 'merged'
  110. # style = 'text-decoration: line-through'
  111. # end
  112. # item = {
  113. # :url => '#ticket/zoom/' + ticket.id.to_s,
  114. # :name => 'T:' + ticket.number.to_s,
  115. # :title => ticket.title,
  116. # :style => style
  117. # }
  118. # ticket_items.push item
  119. # end
  120. # if ticket_items[0]
  121. # topic = {
  122. # :title => 'Tickets',
  123. # :items => ticket_items
  124. # }
  125. # user['links'].push topic
  126. # end
  127. # return result
  128. render :json => {
  129. :tickets => {
  130. :open => tickets_open,
  131. :closed => tickets_closed
  132. }
  133. # :users => users,
  134. }
  135. end
  136. # GET /ticket_history/1
  137. def ticket_history
  138. # get ticket data
  139. ticket = Ticket.find( params[:id] )
  140. # permissin check
  141. return if !ticket_permission( ticket )
  142. # get history of ticket
  143. history = History.history_list( 'Ticket', params[:id], 'Ticket::Article' )
  144. # get related users
  145. users = {}
  146. users[ ticket.owner_id ] = User.user_data_full( ticket.owner_id )
  147. users[ ticket.customer_id ] = User.user_data_full( ticket.customer_id )
  148. history.each do |item|
  149. users[ item['created_by_id'] ] = User.user_data_full( item['created_by_id'] )
  150. if item['history_object'] == 'Ticket::Article'
  151. item['type'] = 'Article ' + item['type'].to_s
  152. else
  153. item['type'] = 'Ticket ' + item['type'].to_s
  154. end
  155. end
  156. # fetch meta relations
  157. history_objects = History::Object.all()
  158. history_types = History::Type.all()
  159. history_attributes = History::Attribute.all()
  160. # return result
  161. render :json => {
  162. :ticket => ticket,
  163. :users => users,
  164. :history => history,
  165. :history_objects => history_objects,
  166. :history_types => history_types,
  167. :history_attributes => history_attributes
  168. }
  169. end
  170. # GET /ticket_merge_list/1
  171. def ticket_merge_list
  172. # get closed/open states
  173. ticket_states = Ticket::State.where(
  174. :ticket_state_type_id => Ticket::StateType.where( :name => ['new','open', 'pending reminder', 'pending action', 'closed'] )
  175. )
  176. ticket = Ticket.find( params[:ticket_id] )
  177. ticket_list = Ticket.where( :customer_id => ticket.customer_id, :ticket_state_id => ticket_states )
  178. .where( 'id != ?', [ ticket.id ] )
  179. .order('created_at DESC')
  180. .limit(6)
  181. # get related users
  182. users = {}
  183. tickets = []
  184. ticket_list.each {|ticket|
  185. data = Ticket.full_data(ticket.id)
  186. tickets.push data
  187. if !users[ data['owner_id'] ]
  188. users[ data['owner_id'] ] = User.user_data_full( data['owner_id'] )
  189. end
  190. if !users[ data['customer_id'] ]
  191. users[ data['customer_id'] ] = User.user_data_full( data['customer_id'] )
  192. end
  193. if !users[ data['created_by_id'] ]
  194. users[ data['created_by_id'] ] = User.user_data_full( data['created_by_id'] )
  195. end
  196. }
  197. recent_viewed = History.recent_viewed_fulldata( current_user, 8 )
  198. # return result
  199. render :json => {
  200. :customer => {
  201. :tickets => tickets,
  202. :users => users,
  203. },
  204. :recent => recent_viewed
  205. }
  206. end
  207. # GET /ticket_merge/1/1
  208. def ticket_merge
  209. # check master ticket
  210. ticket_master = Ticket.where( :number => params[:master_ticket_number] ).first
  211. if !ticket_master
  212. render :json => {
  213. :result => 'faild',
  214. :message => 'No such master ticket number!',
  215. }
  216. return
  217. end
  218. # permissin check
  219. return if !ticket_permission(ticket_master)
  220. # check slave ticket
  221. ticket_slave = Ticket.where( :id => params[:slave_ticket_id] ).first
  222. if !ticket_slave
  223. render :json => {
  224. :result => 'faild',
  225. :message => 'No such slave ticket!',
  226. }
  227. return
  228. end
  229. # permissin check
  230. return if !ticket_permission( ticket_slave )
  231. # check diffetent ticket ids
  232. if ticket_slave.id == ticket_master.id
  233. render :json => {
  234. :result => 'faild',
  235. :message => 'Can\'t merge ticket with it self!',
  236. }
  237. return
  238. end
  239. # merge ticket
  240. success = ticket_slave.merge_to(
  241. {
  242. :ticket_id => ticket_master.id,
  243. :created_by_id => current_user.id,
  244. }
  245. )
  246. # return result
  247. render :json => {
  248. :result => 'success',
  249. :master_ticket => ticket_master.attributes,
  250. :slave_ticket => ticket_slave.attributes,
  251. }
  252. end
  253. # GET /ticket_full/1
  254. def ticket_full
  255. # permission check
  256. ticket = Ticket.find( params[:id] )
  257. return if !ticket_permission( ticket )
  258. # get related users
  259. users = {}
  260. if !users[ticket.owner_id]
  261. users[ticket.owner_id] = User.user_data_full( ticket.owner_id )
  262. end
  263. if !users[ticket.customer_id]
  264. users[ticket.customer_id] = User.user_data_full( ticket.customer_id )
  265. end
  266. if !users[ticket.created_by_id]
  267. users[ticket.created_by_id] = User.user_data_full( ticket.created_by_id )
  268. end
  269. owner_ids = []
  270. ticket.agent_of_group.each { |user|
  271. owner_ids.push user.id
  272. if !users[user.id]
  273. users[user.id] = User.user_data_full( user.id )
  274. end
  275. }
  276. # log object as viewed
  277. log_view( ticket )
  278. # get signature
  279. signature = {}
  280. if ticket.group.signature
  281. signature = ticket.group.signature.attributes
  282. # replace tags
  283. signature['body'] = NotificationFactory.build(
  284. :string => signature['body'],
  285. :objects => {
  286. :ticket => ticket,
  287. :user => current_user,
  288. }
  289. )
  290. end
  291. # get related articles
  292. ticket = ticket.attributes
  293. ticket[:article_ids] = []
  294. articles = Ticket::Article.where( :ticket_id => params[:id] )
  295. # get related users
  296. articles_used = []
  297. articles.each {|article|
  298. # ignore internal article if customer is requesting
  299. next if article.internal == true && is_role('Customer')
  300. article_tmp = article.attributes
  301. # load article ids
  302. ticket[:article_ids].push article_tmp['id']
  303. # add attachment list to article
  304. article_tmp['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
  305. # remember article
  306. articles_used.push article_tmp
  307. # load users
  308. if !users[article.created_by_id]
  309. users[article.created_by_id] = User.user_data_full( article.created_by_id )
  310. end
  311. }
  312. # get groups
  313. group_ids = []
  314. Group.where( :active => true ).each { |group|
  315. group_ids.push group.id
  316. }
  317. agents = {}
  318. Ticket.agents.each { |user|
  319. agents[ user.id ] = 1
  320. }
  321. groups_users = {}
  322. group_ids.each {|group_id|
  323. groups_users[ group_id ] = []
  324. Group.find(group_id).users.each {|user|
  325. next if !agents[ user.id ]
  326. groups_users[ group_id ].push user.id
  327. if !users[user.id]
  328. users[user.id] = User.user_data_full( user.id )
  329. end
  330. }
  331. }
  332. # return result
  333. render :json => {
  334. :ticket => ticket,
  335. :articles => articles_used,
  336. :signature => signature,
  337. :users => users,
  338. :edit_form => {
  339. :group_id__owner_id => groups_users,
  340. :owner_id => owner_ids,
  341. }
  342. }
  343. end
  344. # GET /ticket_create/1
  345. def ticket_create
  346. # get attributes
  347. create_attributes = Ticket.create_attributes(
  348. :current_user_id => current_user.id,
  349. )
  350. # split data
  351. ticket = nil
  352. articles = nil
  353. users = {}
  354. if params[:ticket_id] && params[:article_id]
  355. ticket = Ticket.find( params[:ticket_id] )
  356. # get related users
  357. if !users[ticket.owner_id]
  358. users[ticket.owner_id] = User.user_data_full( ticket.owner_id )
  359. end
  360. if !users[ticket.customer_id]
  361. users[ticket.customer_id] = User.user_data_full( ticket.customer_id )
  362. end
  363. if !users[ticket.created_by_id]
  364. users[ticket.created_by_id] = User.user_data_full( ticket.created_by_id )
  365. end
  366. owner_ids = []
  367. ticket.agent_of_group.each { |user|
  368. owner_ids.push user.id
  369. if !users[user.id]
  370. users[user.id] = User.user_data_full( user.id )
  371. end
  372. }
  373. # get related articles
  374. ticket[:article_ids] = [ params[:article_id] ]
  375. article = Ticket::Article.find( params[:article_id] )
  376. # add attachment list to article
  377. article['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
  378. # load users
  379. if !users[article.created_by_id]
  380. users[article.created_by_id] = User.user_data_full( article.created_by_id )
  381. end
  382. end
  383. create_attributes[:owner_id].each {|user_id|
  384. if !users[user_id]
  385. users[user_id] = User.user_data_full( user_id )
  386. end
  387. }
  388. # return result
  389. render :json => {
  390. :ticket => ticket,
  391. :articles => [ article ],
  392. :users => users,
  393. :edit_form => create_attributes,
  394. }
  395. end
  396. # GET /api/tickets/search
  397. def search
  398. # get params
  399. query = params[:term]
  400. limit = params[:limit] || 15
  401. conditions = []
  402. if current_user.is_role('Agent')
  403. group_ids = Group.select( 'groups.id' ).joins(:users).
  404. where( 'groups_users.user_id = ?', current_user.id ).
  405. where( 'groups.active = ?', true ).
  406. map( &:id )
  407. conditions = [ 'group_id IN (?)', group_ids ]
  408. else
  409. if !current_user.organization || ( !current_user.organization.shared || current_user.organization.shared == false )
  410. conditions = [ 'customer_id = ?', current_user.id ]
  411. else
  412. conditions = [ '( customer_id = ? OR organization_id = ? )', current_user.id, current_user.organization.id ]
  413. end
  414. end
  415. # do query
  416. tickets_all = Ticket.select('DISTINCT(tickets.id)').
  417. where(conditions).
  418. where( '( title LIKE ? OR number LIKE ? OR ticket_articles.body LIKE ? OR ticket_articles.from LIKE ? OR ticket_articles.to LIKE ? OR ticket_articles.subject LIKE ?)', "%#{query}%", "%#{query}%", "%#{query}%", "%#{query}%", "%#{query}%", "%#{query}%" ).
  419. joins(:articles).
  420. limit(limit).
  421. order('tickets.created_at DESC')
  422. # build result list
  423. tickets = []
  424. users = {}
  425. tickets_all.each do |ticket|
  426. ticket_tmp = Ticket.full_data(ticket.id)
  427. tickets.push ticket_tmp
  428. users[ ticket['owner_id'] ] = User.user_data_full( ticket_tmp['owner_id'] )
  429. users[ ticket['customer_id'] ] = User.user_data_full( ticket_tmp['customer_id'] )
  430. users[ ticket['created_by_id'] ] = User.user_data_full( ticket_tmp['created_by_id'] )
  431. end
  432. # return result
  433. render :json => {
  434. :tickets => tickets,
  435. :users => users,
  436. }
  437. end
  438. end