trabajo-afectivo/app/controllers/tickets_controller.rb

568 lines
14 KiB
Ruby
Raw Normal View History

2014-02-03 19:24:49 +00:00
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
2012-04-10 14:06:46 +00:00
class TicketsController < ApplicationController
before_action :authentication_check
2012-04-10 14:06:46 +00:00
# GET /api/v1/tickets
2012-04-10 14:06:46 +00:00
def index
@tickets = Ticket.all
render json: @tickets
2012-04-10 14:06:46 +00:00
end
# GET /api/v1/tickets/1
2012-04-10 14:06:46 +00:00
def show
@ticket = Ticket.find( params[:id] )
2012-04-10 14:06:46 +00:00
2012-09-04 21:28:49 +00:00
# permissin check
return if !ticket_permission(@ticket)
render json: @ticket
2012-04-10 14:06:46 +00:00
end
# POST /api/v1/tickets
2012-04-10 14:06:46 +00:00
def create
2014-09-23 05:37:43 +00:00
ticket = Ticket.new( Ticket.param_validation( params[:ticket] ) )
2012-04-10 14:06:46 +00:00
# check if article is given
if !params[:article]
render json: 'article hash is missing', status: :unprocessable_entity
return
end
# create ticket
2014-09-23 05:37:43 +00:00
if !ticket.save
render json: ticket.errors, status: :unprocessable_entity
return
end
2012-10-02 05:46:08 +00:00
2012-11-18 11:06:55 +00:00
# create tags if given
if params[:tags] && !params[:tags].empty?
tags = params[:tags].split(/,/)
2012-11-18 11:06:55 +00:00
tags.each {|tag|
Tag.tag_add(
object: 'Ticket',
o_id: ticket.id,
item: tag,
created_by_id: current_user.id,
2012-11-18 11:06:55 +00:00
)
}
end
# create article if given
if params[:article]
2014-09-23 05:37:43 +00:00
article_create( ticket, params[:article] )
2012-04-10 14:06:46 +00:00
end
2012-04-16 12:56:04 +00:00
render json: ticket, status: :created
2012-04-10 14:06:46 +00:00
end
# PUT /api/v1/tickets/1
2012-04-10 14:06:46 +00:00
def update
2014-09-23 05:37:43 +00:00
ticket = Ticket.find(params[:id])
2012-04-10 14:06:46 +00:00
2012-09-04 21:28:49 +00:00
# permissin check
2014-09-23 05:37:43 +00:00
return if !ticket_permission(ticket)
if ticket.update_attributes( Ticket.param_validation( params[:ticket] ) )
2012-09-04 21:28:49 +00:00
2014-09-23 05:37:43 +00:00
if params[:article]
article_create( ticket, params[:article] )
end
2012-09-04 21:28:49 +00:00
render json: ticket, status: :ok
else
render json: ticket.errors, status: :unprocessable_entity
2012-04-10 14:06:46 +00:00
end
end
# DELETE /api/v1/tickets/1
2012-04-10 14:06:46 +00:00
def destroy
2014-09-23 05:37:43 +00:00
ticket = Ticket.find( params[:id] )
2012-09-04 21:28:49 +00:00
2015-02-15 09:23:55 +00:00
# permission check
2014-09-23 05:37:43 +00:00
return if !ticket_permission(ticket)
2012-09-04 21:28:49 +00:00
2014-09-23 05:37:43 +00:00
ticket.destroy
2012-04-10 14:06:46 +00:00
head :ok
2012-04-10 14:06:46 +00:00
end
# GET /api/v1/ticket_customer
# GET /api/v1/tickets_customer
def ticket_customer
2012-10-02 05:46:08 +00:00
# return result
result = Ticket::ScreenOptions.list_by_customer(
customer_id: params[:customer_id],
limit: 15,
)
render json: result
end
# GET /api/v1/ticket_history/1
def ticket_history
# get ticket data
2012-10-02 05:46:08 +00:00
ticket = Ticket.find( params[:id] )
# permissin check
2012-10-02 05:46:08 +00:00
return if !ticket_permission( ticket )
# get history of ticket
2013-09-29 16:40:42 +00:00
history = ticket.history_get(true)
# return result
render json: history
end
# GET /api/v1/ticket_related/1
def ticket_related
2012-10-18 19:23:05 +00:00
ticket = Ticket.find( params[:ticket_id] )
assets = ticket.assets({})
# open tickets by customer
2015-04-30 15:53:03 +00:00
group_ids = Group.select( 'groups.id' )
.joins(:users)
.where( 'groups_users.user_id = ?', current_user.id )
.where( 'groups.active = ?', true )
.map( &:id )
access_condition = [ 'group_id IN (?)', group_ids ]
2015-04-30 15:53:03 +00:00
ticket_lists = Ticket
.where(
customer_id: ticket.customer_id,
state_id: Ticket::State.by_category( 'open' )
)
.where(access_condition)
.where( 'id != ?', [ ticket.id ] )
.order('created_at DESC')
.limit(6)
2012-10-18 19:23:05 +00:00
# get related assets
2014-02-03 19:24:49 +00:00
ticket_ids_by_customer = []
2015-04-30 15:53:03 +00:00
ticket_lists.each {|ticket_list|
ticket_ids_by_customer.push ticket_list.id
assets = ticket_list.assets(assets)
2012-10-18 19:23:05 +00:00
}
ticket_ids_recent_viewed = []
2015-04-30 15:53:03 +00:00
recent_views = RecentView.list( current_user, 8, 'Ticket' )
recent_views.each {|recent_view|
next if recent_view['object'] != 'Ticket'
ticket_ids_recent_viewed.push recent_view['o_id']
recent_view_ticket = Ticket.find( recent_view['o_id'] )
assets = recent_view_ticket.assets(assets)
}
2012-10-18 19:23:05 +00:00
# return result
render json: {
assets: assets,
ticket_ids_by_customer: ticket_ids_by_customer,
ticket_ids_recent_viewed: ticket_ids_recent_viewed,
2012-10-18 19:23:05 +00:00
}
end
# GET /api/v1/ticket_merge/1/1
def ticket_merge
# check master ticket
ticket_master = Ticket.find_by(number: params[:master_ticket_number])
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.find_by(id: params[:slave_ticket_id] )
if !ticket_slave
render json: {
result: 'faild',
message: 'No such slave ticket!',
}
return
end
# permissin check
2012-10-02 05:46:08 +00:00
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
2015-04-30 15:53:03 +00:00
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 /api/v1/ticket_full/1
def ticket_full
# permission check
2012-10-02 05:46:08 +00:00
ticket = Ticket.find( params[:id] )
return if !ticket_permission(ticket)
2013-01-04 08:09:59 +00:00
# get attributes to update
attributes_to_change = Ticket::ScreenOptions.attributes_to_change(user: current_user, ticket: ticket)
2013-01-04 08:09:59 +00:00
2014-09-09 23:42:20 +00:00
# get related users
assets = attributes_to_change[:assets]
assets = ticket.assets(assets)
2013-01-04 08:09:59 +00:00
# get related articles
articles = Ticket::Article.where(ticket_id: params[:id])
# get related users
article_ids = []
articles.each {|article|
# ignore internal article if customer is requesting
next if article.internal == true && role?(Z_ROLENAME_CUSTOMER)
# load article ids
article_ids.push article.id
# load assets
assets = article.assets(assets)
}
# get links
links = Link.list(
link_object: 'Ticket',
link_object_value: ticket.id,
)
link_list = []
links.each { |item|
link_list.push item
if item['link_object'] == 'Ticket'
linked_ticket = Ticket.lookup( id: item['link_object_value'] )
2014-09-24 19:37:06 +00:00
assets = linked_ticket.assets(assets)
end
}
# get tags
tags = Tag.tag_list(
object: 'Ticket',
o_id: ticket.id,
)
# return result
render json: {
ticket_id: ticket.id,
ticket_article_ids: article_ids,
assets: assets,
links: link_list,
tags: tags,
form_meta: attributes_to_change[:form_meta],
}
end
# GET /api/v1/ticket_split
def ticket_split
# permission check
ticket = Ticket.find(params[:ticket_id])
return if !ticket_permission(ticket)
assets = ticket.assets({})
# get related articles
article = Ticket::Article.find(params[:article_id])
assets = article.assets(assets)
render json: {
assets: assets
}
end
# GET /api/v1/ticket_create
def ticket_create
2013-01-04 08:09:59 +00:00
# get attributes to update
attributes_to_change = Ticket::ScreenOptions.attributes_to_change(
user: current_user,
)
render json: attributes_to_change
end
# GET /api/v1/tickets/search
2012-11-14 01:05:53 +00:00
def search
2014-09-01 13:09:43 +00:00
# permit nested conditions
params.require(:condition).permit!
2012-11-14 01:05:53 +00:00
# build result list
2013-05-21 22:30:09 +00:00
tickets = Ticket.search(
limit: params[:limit],
query: params[:term],
condition: params[:condition],
current_user: current_user,
2013-05-21 22:30:09 +00:00
)
assets = {}
2013-05-21 22:30:09 +00:00
ticket_result = []
tickets.each do |ticket|
ticket_result.push ticket.id
assets = ticket.assets(assets)
2012-11-14 01:05:53 +00:00
end
# return result
render json: {
tickets: ticket_result,
tickets_count: tickets.count,
assets: assets,
2012-11-14 01:05:53 +00:00
}
end
2015-09-17 01:04:16 +00:00
# GET /api/v1/tickets/selector
def selector
return if deny_if_not_role(Z_ROLENAME_ADMIN)
ticket_count, tickets = Ticket.selectors(params[:condition], 6)
assets = {}
ticket_ids = []
if tickets
tickets.each do |ticket|
ticket_ids.push ticket.id
assets = ticket.assets(assets)
end
end
# return result
render json: {
ticket_ids: ticket_ids,
ticket_count: ticket_count || 0,
assets: assets,
}
end
2014-11-10 07:34:20 +00:00
# GET /api/v1/ticket_stats
2014-11-09 23:42:17 +00:00
def stats
2014-11-10 07:34:20 +00:00
if !params[:user_id] && !params[:organization_id]
fail 'Need user_id or organization_id as param'
2014-11-10 07:34:20 +00:00
end
2014-11-09 23:42:17 +00:00
# permissin check
#return if !ticket_permission(ticket)
# lookup open user tickets
2014-11-10 07:34:20 +00:00
limit = 100
assets = {}
access_condition = Ticket.access_condition( current_user )
2015-04-27 20:49:17 +00:00
now = Time.zone.now
2014-11-10 07:34:20 +00:00
user_tickets_open_ids = []
user_tickets_closed_ids = []
user_ticket_volume_by_year = []
if params[:user_id]
user = User.find( params[:user_id] )
condition = {
'ticket.state_id' => {
operator: 'is',
value: Ticket::State.by_category('open').map(&:id),
},
'ticket.customer_id' => {
operator: 'is',
value: user.id,
},
2014-11-10 07:34:20 +00:00
}
user_tickets_open = Ticket.search(
limit: limit,
condition: condition,
current_user: current_user,
2014-11-10 07:34:20 +00:00
)
user_tickets_open_ids = assets_of_tickets(user_tickets_open, assets)
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
# lookup closed user tickets
condition = {
'ticket.state_id' => {
operator: 'is',
value: Ticket::State.by_category('closed').map(&:id),
},
'ticket.customer_id' => {
operator: 'is',
value: user.id,
},
2014-11-10 07:34:20 +00:00
}
user_tickets_closed = Ticket.search(
limit: limit,
condition: condition,
current_user: current_user,
2014-11-10 07:34:20 +00:00
)
user_tickets_closed_ids = assets_of_tickets(user_tickets_closed, assets)
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
# generate stats by user
(0..11).each {|month_back|
2015-04-30 15:53:03 +00:00
date_to_check = now - month_back.month
2015-04-27 20:49:17 +00:00
date_start = "#{date_to_check.year}-#{date_to_check.month}-01 00:00:00"
2014-11-10 07:34:20 +00:00
date_end = "#{date_to_check.year}-#{date_to_check.month}-#{date_to_check.end_of_month.day} 00:00:00"
condition = {
'tickets.customer_id' => user.id,
}
# created
2015-04-30 15:53:03 +00:00
created = Ticket.where('created_at > ? AND created_at < ?', date_start, date_end )
.where(access_condition)
.where(condition)
.count
2014-11-10 07:34:20 +00:00
# closed
2015-04-30 15:53:03 +00:00
closed = Ticket.where('close_time > ? AND close_time < ?', date_start, date_end )
.where(access_condition)
.where(condition)
.count
2014-11-10 07:34:20 +00:00
data = {
month: date_to_check.month,
year: date_to_check.year,
text: Date::MONTHNAMES[date_to_check.month],
created: created,
closed: closed,
2014-11-10 07:34:20 +00:00
}
user_ticket_volume_by_year.push data
}
end
2014-11-09 23:42:17 +00:00
# lookup open org tickets
2014-11-10 07:34:20 +00:00
org_tickets_open_ids = []
org_tickets_closed_ids = []
org_ticket_volume_by_year = []
if params[:organization_id] && !params[:organization_id].empty?
2014-11-09 23:42:17 +00:00
condition = {
'ticket.state_id' => {
operator: 'is',
value: Ticket::State.by_category('open').map(&:id),
},
'ticket.organization_id' => {
operator: 'is',
value: params[:organization_id],
},
2014-11-09 23:42:17 +00:00
}
org_tickets_open = Ticket.search(
limit: limit,
condition: condition,
current_user: current_user,
2014-11-09 23:42:17 +00:00
)
org_tickets_open_ids = assets_of_tickets(org_tickets_open, assets)
2014-11-10 07:34:20 +00:00
# lookup closed org tickets
2014-11-09 23:42:17 +00:00
condition = {
'ticket.state_id' => {
operator: 'is',
value: Ticket::State.by_category('closed').map(&:id),
},
'ticket.organization_id' => {
operator: 'is',
value: params[:organization_id],
},
2014-11-09 23:42:17 +00:00
}
org_tickets_closed = Ticket.search(
limit: limit,
condition: condition,
current_user: current_user,
2014-11-09 23:42:17 +00:00
)
org_tickets_closed_ids = assets_of_tickets(org_tickets_closed, assets)
2014-11-10 07:34:20 +00:00
# generate stats by org
(0..11).each {|month_back|
2015-04-30 15:53:03 +00:00
date_to_check = now - month_back.month
2015-04-27 20:49:17 +00:00
date_start = "#{date_to_check.year}-#{date_to_check.month}-01 00:00:00"
2014-11-10 07:34:20 +00:00
date_end = "#{date_to_check.year}-#{date_to_check.month}-#{date_to_check.end_of_month.day} 00:00:00"
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
condition = {
'tickets.organization_id' => params[:organization_id],
}
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
# created
created = Ticket.where('created_at > ? AND created_at < ?', date_start, date_end ).where(condition).count
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
# closed
closed = Ticket.where('close_time > ? AND close_time < ?', date_start, date_end ).where(condition).count
2014-11-09 23:42:17 +00:00
2014-11-10 07:34:20 +00:00
data = {
month: date_to_check.month,
year: date_to_check.year,
text: Date::MONTHNAMES[date_to_check.month],
created: created,
closed: closed,
2014-11-10 07:34:20 +00:00
}
org_ticket_volume_by_year.push data
2014-11-09 23:42:17 +00:00
}
2014-11-10 07:34:20 +00:00
end
2014-11-09 23:42:17 +00:00
# return result
render json: {
user_tickets_open_ids: user_tickets_open_ids,
user_tickets_closed_ids: user_tickets_closed_ids,
org_tickets_open_ids: org_tickets_open_ids,
org_tickets_closed_ids: org_tickets_closed_ids,
user_ticket_volume_by_year: user_ticket_volume_by_year,
org_ticket_volume_by_year: org_ticket_volume_by_year,
assets: assets,
2014-11-09 23:42:17 +00:00
}
end
2014-09-23 05:37:43 +00:00
private
2014-11-09 23:42:17 +00:00
def assets_of_tickets(tickets, assets)
ticket_ids = []
tickets.each do |ticket|
ticket_ids.push ticket.id
assets = ticket.assets(assets)
end
2015-04-27 20:49:17 +00:00
ticket_ids
2014-11-09 23:42:17 +00:00
end
2014-09-23 05:37:43 +00:00
def article_create(ticket, params)
2014-11-09 23:42:17 +00:00
2014-09-23 05:37:43 +00:00
# create article if given
form_id = params[:form_id]
params.delete(:form_id)
article = Ticket::Article.new( Ticket::Article.param_validation( params ) )
article.ticket_id = ticket.id
# find attachments in upload cache
if form_id
article.attachments = Store.list(
object: 'UploadCache',
o_id: form_id,
2014-09-23 05:37:43 +00:00
)
end
if !article.save
render json: article.errors, status: :unprocessable_entity
2014-09-23 05:37:43 +00:00
return
end
# remove attachments from upload cache
2015-04-30 15:53:03 +00:00
return if !form_id
2015-04-30 15:53:03 +00:00
Store.remove(
object: 'UploadCache',
o_id: form_id,
)
2014-09-23 05:37:43 +00:00
end
2012-04-10 14:06:46 +00:00
end