123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499 |
- class TicketsController < ApplicationController
- before_filter :authentication_check
- # GET /api/tickets
- def index
- @tickets = Ticket.all
- render :json => @tickets
- end
- # GET /api/tickets/1
- def show
- @ticket = Ticket.find( params[:id] )
- # permissin check
- return if !ticket_permission(@ticket)
- render :json => @ticket
- end
- # POST /api/tickets
- def create
- @ticket = Ticket.new( params[:ticket] )
- # check if article is given
- if !params[:article]
- render :json => 'article hash is missing', :status => :unprocessable_entity
- return
- end
- # create ticket
- if !@ticket.save
- render :json => @ticket.errors, :status => :unprocessable_entity
- return
- end
- # create tags if given
- if params[:tags] && !params[:tags].empty?
- tags = params[:tags].split /,/
- tags.each {|tag|
- Tag.tag_add(
- :object => 'Ticket',
- :o_id => @ticket.id,
- :item => tag,
- :created_by_id => current_user.id,
- )
- }
- end
- # create article if given
- if params[:article]
- form_id = params[:article][:form_id]
- params[:article].delete(:form_id)
- @article = Ticket::Article.new( params[:article] )
- @article.ticket_id = @ticket.id
- # find attachments in upload cache
- if form_id
- @article['attachments'] = Store.list(
- :object => 'UploadCache',
- :o_id => form_id,
- )
- end
- if !@article.save
- render :json => @article.errors, :status => :unprocessable_entity
- return
- end
- # remove attachments from upload cache
- if params[:form_id]
- Store.remove(
- :object => 'UploadCache',
- :o_id => form_id,
- )
- end
- end
- render :json => @ticket, :status => :created
- end
- # PUT /api/tickets/1
- def update
- @ticket = Ticket.find(params[:id])
- # permissin check
- return if !ticket_permission(@ticket)
- if @ticket.update_attributes( params[:ticket] )
- render :json => @ticket, :status => :ok
- else
- render :json => @ticket.errors, :status => :unprocessable_entity
- end
- end
- # DELETE /api/tickets/1
- def destroy
- @ticket = Ticket.find( params[:id] )
- # permissin check
- return if !ticket_permission(@ticket)
- @ticket.destroy
- head :ok
- end
- # GET /api/ticket_customer
- # GET /api/tickets_customer
- def ticket_customer
- # get closed/open states
- ticket_state_list_open = Ticket::State.where(
- :state_type_id => Ticket::StateType.where( :name => ['new','open', 'pending reminder', 'pending action'] )
- )
- ticket_state_list_closed = Ticket::State.where(
- :state_type_id => Ticket::StateType.where( :name => ['closed'] )
- )
- # get tickets
- tickets_open = Ticket.where(
- :customer_id => params[:customer_id],
- :ticket_state_id => ticket_state_list_open
- ).limit(15).order('created_at DESC')
- tickets_closed = Ticket.where(
- :customer_id => params[:customer_id],
- :ticket_state_id => ticket_state_list_closed
- ).limit(15).order('created_at DESC')
- # return result
- render :json => {
- :tickets => {
- :open => tickets_open,
- :closed => tickets_closed
- }
- # :users => users,
- }
- end
- # GET /api/ticket_history/1
- def ticket_history
- # get ticket data
- ticket = Ticket.find( params[:id] )
- # permissin check
- return if !ticket_permission( ticket )
- # get history of ticket
- history = History.list( 'Ticket', params[:id], 'Ticket::Article' )
- # get related users
- users = {}
- users[ ticket.owner_id ] = User.user_data_full( ticket.owner_id )
- users[ ticket.customer_id ] = User.user_data_full( ticket.customer_id )
- # get only needed data to send to browser
- history_list = []
- history.each do |item|
- users[ item[:created_by_id] ] = User.user_data_full( item[:created_by_id] )
- item_tmp = item.attributes
- if item['history_object'] == 'Ticket::Article'
- item_temp['type'] = 'Article ' + item['type'].to_s
- else
- item_tmp['type'] = 'Ticket ' + item['type'].to_s
- end
- item_tmp['history_type'] = item.history_type.name
- item_tmp['history_object'] = item.history_object.name
- if item.history_attribute
- item_tmp['history_attribute'] = item.history_attribute.name
- end
- item_tmp.delete( 'history_attribute_id' )
- item_tmp.delete( 'history_object_id' )
- item_tmp.delete( 'history_type_id' )
- item_tmp.delete( 'o_id' )
- item_tmp.delete( 'updated_at' )
- if item_tmp['id_to'] == nil && item_tmp['id_from'] == nil
- item_tmp.delete( 'id_to' )
- item_tmp.delete( 'id_from' )
- end
- if item_tmp['value_to'] == nil && item_tmp['value_from'] == nil
- item_tmp.delete( 'value_to' )
- item_tmp.delete( 'value_from' )
- end
- if item_tmp['related_history_object_id'] == nil
- item_tmp.delete( 'related_history_object_id' )
- end
- if item_tmp['related_o_id'] == nil
- item_tmp.delete( 'related_o_id' )
- end
- history_list.push item_tmp
- end
- # fetch meta relations
- history_objects = History::Object.all()
- history_types = History::Type.all()
- history_attributes = History::Attribute.all()
- # return result
- render :json => {
- :ticket => ticket,
- :users => users,
- :history => history_list,
- :history_objects => history_objects,
- :history_types => history_types,
- :history_attributes => history_attributes
- }
- end
- # GET /api/ticket_merge_list/1
- def ticket_merge_list
- # get closed/open states
- ticket_states = Ticket::State.where(
- :state_type_id => Ticket::StateType.where( :name => ['new','open', 'pending reminder', 'pending action', 'closed'] )
- )
- ticket = Ticket.find( params[:ticket_id] )
- ticket_list = Ticket.where( :customer_id => ticket.customer_id, :ticket_state_id => ticket_states )
- .where( 'id != ?', [ ticket.id ] )
- .order('created_at DESC')
- .limit(6)
- # get related users
- users = {}
- tickets = []
- ticket_list.each {|ticket|
- data = Ticket.lookup( :id => ticket.id )
- tickets.push data
- if !users[ data['owner_id'] ]
- users[ data['owner_id'] ] = User.user_data_full( data['owner_id'] )
- end
- if !users[ data['customer_id'] ]
- users[ data['customer_id'] ] = User.user_data_full( data['customer_id'] )
- end
- if !users[ data['created_by_id'] ]
- users[ data['created_by_id'] ] = User.user_data_full( data['created_by_id'] )
- end
- }
- recent_viewed = RecentView.list_fulldata( current_user, 8 )
- # return result
- render :json => {
- :customer => {
- :tickets => tickets,
- :users => users,
- },
- :recent => recent_viewed
- }
- end
- # GET /ticket_merge/1/1
- def ticket_merge
- # check master ticket
- ticket_master = Ticket.where( :number => params[:master_ticket_number] ).first
- if !ticket_master
- render :json => {
- :result => 'faild',
- :message => 'No such master ticket number!',
- }
- return
- end
- # permissin check
- return if !ticket_permission(ticket_master)
- # check slave ticket
- ticket_slave = Ticket.where( :id => params[:slave_ticket_id] ).first
- if !ticket_slave
- render :json => {
- :result => 'faild',
- :message => 'No such slave ticket!',
- }
- return
- end
- # permissin check
- return if !ticket_permission( ticket_slave )
- # check diffetent ticket ids
- if ticket_slave.id == ticket_master.id
- render :json => {
- :result => 'faild',
- :message => 'Can\'t merge ticket with it self!',
- }
- return
- end
-
- # merge ticket
- success = ticket_slave.merge_to(
- {
- :ticket_id => ticket_master.id,
- :created_by_id => current_user.id,
- }
- )
- # return result
- render :json => {
- :result => 'success',
- :master_ticket => ticket_master.attributes,
- :slave_ticket => ticket_slave.attributes,
- }
- end
- # GET /ticket_full/1
- def ticket_full
- # permission check
- ticket = Ticket.find( params[:id] )
- return if !ticket_permission( ticket )
- # get related users
- users = {}
- if !users[ticket.owner_id]
- users[ticket.owner_id] = User.user_data_full( ticket.owner_id )
- end
- if !users[ticket.customer_id]
- users[ticket.customer_id] = User.user_data_full( ticket.customer_id )
- end
- if !users[ticket.created_by_id]
- users[ticket.created_by_id] = User.user_data_full( ticket.created_by_id )
- end
- # log object as viewed
- if !params[:do_not_log] || params[:do_not_log].to_i == 0
- log_view( ticket )
- end
- # get signature
- signature = {}
- if ticket.group.signature
- signature = ticket.group.signature.attributes
- # replace tags
- signature['body'] = NotificationFactory.build(
- :locale => current_user.locale,
- :string => signature['body'],
- :objects => {
- :ticket => ticket,
- :user => current_user,
- }
- )
- end
- # get attributes to update
- attributes_to_change = Ticket.attributes_to_change( :user => current_user, :ticket => ticket )
- attributes_to_change[:owner_id].each { |user_id|
- if !users[user_id]
- users[user_id] = User.user_data_full( user_id )
- end
- }
- attributes_to_change[:group_id__owner_id].each {|group_id, user_ids|
- user_ids.each {|user_id|
- if !users[user_id]
- users[user_id] = User.user_data_full( user_id )
- end
- }
- }
- # get related articles
- ticket = ticket.attributes
- ticket[:article_ids] = []
- articles = Ticket::Article.where( :ticket_id => params[:id] )
- # get related users
- articles_used = []
- articles.each {|article|
- # ignore internal article if customer is requesting
- next if article.internal == true && is_role('Customer')
- article_tmp = article.attributes
- # load article ids
- ticket[:article_ids].push article_tmp['id']
-
- # add attachment list to article
- article_tmp['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
- # remember article
- articles_used.push article_tmp
- # load users
- if !users[article.created_by_id]
- users[article.created_by_id] = User.user_data_full( article.created_by_id )
- end
- }
- # return result
- render :json => {
- :ticket => ticket,
- :articles => articles_used,
- :signature => signature,
- :users => users,
- :edit_form => attributes_to_change,
- }
- end
- # GET /ticket_create/1
- def ticket_create
- # get attributes to update
- attributes_to_change = Ticket.attributes_to_change(
- :user => current_user,
- # :ticket_id => params[:ticket_id],
- # :article_id => params[:article_id]
- )
- users = {}
- attributes_to_change[:owner_id].each { |user_id|
- if !users[user_id]
- users[user_id] = User.user_data_full( user_id )
- end
- }
- attributes_to_change[:group_id__owner_id].each {|group_id, user_ids|
- user_ids.each {|user_id|
- if !users[user_id]
- users[user_id] = User.user_data_full( user_id )
- end
- }
- }
- # split data
- ticket = nil
- articles = nil
- if params[:ticket_id] && params[:article_id]
- ticket = Ticket.find( params[:ticket_id] )
- # get related users
- if !users[ticket.owner_id]
- users[ticket.owner_id] = User.user_data_full( ticket.owner_id )
- end
- if !users[ticket.customer_id]
- users[ticket.customer_id] = User.user_data_full( ticket.customer_id )
- end
- if !users[ticket.created_by_id]
- users[ticket.created_by_id] = User.user_data_full( ticket.created_by_id )
- end
- owner_ids = []
- ticket.agent_of_group.each { |user|
- owner_ids.push user.id
- if !users[user.id]
- users[user.id] = User.user_data_full( user.id )
- end
- }
- # get related articles
- ticket[:article_ids] = [ params[:article_id] ]
- article = Ticket::Article.find( params[:article_id] )
- # add attachment list to article
- article['attachments'] = Store.list( :object => 'Ticket::Article', :o_id => article.id )
- # load users
- if !users[article.created_by_id]
- users[article.created_by_id] = User.user_data_full( article.created_by_id )
- end
- end
- # return result
- render :json => {
- :ticket => ticket,
- :articles => [ article ],
- :users => users,
- :edit_form => attributes_to_change,
- }
- end
- # GET /api/tickets/search
- def search
-
- # build result list
- tickets = Ticket.search(
- :limit => params[:limit],
- :query => params[:term],
- :current_user => current_user,
- )
- users_data = {}
- ticket_result = []
- tickets.each do |ticket|
- ticket_result.push ticket.id
- users_data[ ticket['owner_id'] ] = User.user_data_full( ticket['owner_id'] )
- users_data[ ticket['customer_id'] ] = User.user_data_full( ticket['customer_id'] )
- users_data[ ticket['created_by_id'] ] = User.user_data_full( ticket['created_by_id'] )
- end
- # return result
- render :json => {
- :tickets => ticket_result,
- :users => users_data,
- }
- end
- end
|