tickets_controller.rb 14 KB

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