2014-02-03 19:23:00 +00:00
|
|
|
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
|
2013-06-12 15:59:58 +00:00
|
|
|
|
2013-01-04 18:42:20 +00:00
|
|
|
class Link < ApplicationModel
|
2015-04-27 13:42:53 +00:00
|
|
|
belongs_to :link_type, class_name: 'Link::Type'
|
|
|
|
belongs_to :link_object, class_name: 'Link::Object'
|
2012-04-10 14:06:46 +00:00
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
@map = {
|
|
|
|
'normal' => 'normal',
|
|
|
|
'parent' => 'child',
|
|
|
|
'child' => 'parent',
|
|
|
|
}
|
2012-07-15 22:12:06 +00:00
|
|
|
|
|
|
|
=begin
|
2012-08-20 13:21:15 +00:00
|
|
|
|
2012-11-07 23:47:05 +00:00
|
|
|
links = Link.list(
|
2012-08-21 10:28:41 +00:00
|
|
|
:link_object => 'Ticket',
|
|
|
|
:link_object_value => 1
|
2012-08-20 13:21:15 +00:00
|
|
|
)
|
2013-06-12 15:59:58 +00:00
|
|
|
|
2012-07-15 22:12:06 +00:00
|
|
|
=end
|
|
|
|
|
2012-08-21 10:28:41 +00:00
|
|
|
def self.list(data)
|
2015-05-07 12:10:38 +00:00
|
|
|
linkobject = link_object_get( name: data[:link_object] )
|
2012-08-21 10:28:41 +00:00
|
|
|
return if !linkobject
|
2012-08-23 22:08:27 +00:00
|
|
|
items = []
|
|
|
|
|
|
|
|
# get links for one site
|
2012-08-21 10:28:41 +00:00
|
|
|
list = Link.where(
|
|
|
|
'link_object_source_id = ? AND link_object_source_value = ?', linkobject.id, data[:link_object_value]
|
|
|
|
)
|
|
|
|
|
|
|
|
list.each { |item|
|
|
|
|
link = {}
|
2012-08-23 22:08:27 +00:00
|
|
|
link['link_type'] = @map[ Link::Type.find( item.link_type_id ).name ]
|
2012-08-21 10:28:41 +00:00
|
|
|
link['link_object'] = Link::Object.find( item.link_object_target_id ).name
|
|
|
|
link['link_object_value'] = item.link_object_target_value
|
|
|
|
items.push link
|
|
|
|
}
|
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
# get links for the other site
|
2012-08-21 10:28:41 +00:00
|
|
|
list = Link.where(
|
|
|
|
'link_object_target_id = ? AND link_object_target_value = ?', linkobject.id, data[:link_object_value]
|
|
|
|
)
|
|
|
|
list.each { |item|
|
|
|
|
link = {}
|
|
|
|
link['link_type'] = Link::Type.find( item.link_type_id ).name
|
|
|
|
link['link_object'] = Link::Object.find( item.link_object_source_id ).name
|
|
|
|
link['link_object_value'] = item.link_object_source_value
|
|
|
|
items.push link
|
|
|
|
}
|
|
|
|
|
2015-04-30 17:20:27 +00:00
|
|
|
items
|
2012-08-21 10:28:41 +00:00
|
|
|
end
|
2012-07-15 22:12:06 +00:00
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
=begin
|
2012-07-15 22:12:06 +00:00
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
Link.add(
|
|
|
|
:link_type => 'normal',
|
|
|
|
:link_object_source => 'Ticket',
|
|
|
|
:link_object_source_value => 6,
|
|
|
|
:link_object_target => 'Ticket',
|
|
|
|
:link_object_target_value => 31
|
|
|
|
)
|
|
|
|
|
|
|
|
Link.add(
|
|
|
|
:link_types_id => 12,
|
|
|
|
:link_object_source_id => 1,
|
|
|
|
:link_object_source_value => 1,
|
|
|
|
:link_object_target_id => 1,
|
|
|
|
:link_object_target_value => 1
|
2013-06-12 15:59:58 +00:00
|
|
|
)
|
2012-08-23 22:08:27 +00:00
|
|
|
|
|
|
|
=end
|
2012-08-20 13:21:15 +00:00
|
|
|
|
|
|
|
def self.add(data)
|
2012-07-15 22:12:06 +00:00
|
|
|
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_type)
|
2015-05-07 12:10:38 +00:00
|
|
|
linktype = link_type_get( name: data[:link_type] )
|
2012-08-21 10:28:41 +00:00
|
|
|
data[:link_type_id] = linktype.id
|
|
|
|
data.delete( :link_type )
|
|
|
|
end
|
|
|
|
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_object_source)
|
2015-05-07 12:10:38 +00:00
|
|
|
linkobject = link_object_get( name: data[:link_object_source] )
|
2012-08-21 10:28:41 +00:00
|
|
|
data[:link_object_source_id] = linkobject.id
|
2012-08-20 13:21:15 +00:00
|
|
|
data.delete( :link_object_source )
|
2012-07-15 22:12:06 +00:00
|
|
|
end
|
2012-08-21 10:28:41 +00:00
|
|
|
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_object_target)
|
2015-05-07 12:10:38 +00:00
|
|
|
linkobject = link_object_get( name: data[:link_object_target] )
|
2012-08-21 10:28:41 +00:00
|
|
|
data[:link_object_target_id] = linkobject.id
|
2012-08-20 13:21:15 +00:00
|
|
|
data.delete( :link_object_target )
|
|
|
|
end
|
|
|
|
|
|
|
|
Link.create(data)
|
|
|
|
end
|
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
=begin
|
2012-08-20 13:21:15 +00:00
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
Link.remove(
|
|
|
|
:link_type => 'normal',
|
|
|
|
:link_object_source => 'Ticket',
|
|
|
|
:link_object_source_value => 6,
|
|
|
|
:link_object_target => 'Ticket',
|
|
|
|
:link_object_target_value => 31
|
2013-06-12 15:59:58 +00:00
|
|
|
)
|
2012-08-23 22:08:27 +00:00
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.remove(data)
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_object_source)
|
2015-05-07 12:10:38 +00:00
|
|
|
linkobject = link_object_get( name: data[:link_object_source] )
|
2012-08-23 22:08:27 +00:00
|
|
|
data[:link_object_source_id] = linkobject.id
|
|
|
|
end
|
|
|
|
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_object_target)
|
2015-05-07 12:10:38 +00:00
|
|
|
linkobject = link_object_get( name: data[:link_object_target] )
|
2012-08-23 22:08:27 +00:00
|
|
|
data[:link_object_target_id] = linkobject.id
|
|
|
|
end
|
2012-08-20 13:21:15 +00:00
|
|
|
|
2012-08-23 22:08:27 +00:00
|
|
|
# from one site
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_type)
|
2015-05-07 12:10:38 +00:00
|
|
|
linktype = link_type_get( name: data[:link_type] )
|
2012-08-23 22:08:27 +00:00
|
|
|
data[:link_type_id] = linktype.id
|
|
|
|
end
|
|
|
|
links = Link.where(
|
2015-04-27 13:42:53 +00:00
|
|
|
link_type_id: data[:link_type_id],
|
|
|
|
link_object_source_id: data[:link_object_source_id],
|
|
|
|
link_object_source_value: data[:link_object_source_value],
|
|
|
|
link_object_target_id: data[:link_object_target_id],
|
|
|
|
link_object_target_value: data[:link_object_target_value]
|
2012-08-23 22:08:27 +00:00
|
|
|
)
|
2015-05-07 10:25:16 +00:00
|
|
|
links.each(&:destroy)
|
2012-08-23 22:08:27 +00:00
|
|
|
|
|
|
|
# from the other site
|
2015-04-30 17:34:33 +00:00
|
|
|
if data.key?(:link_type)
|
2015-05-07 12:10:38 +00:00
|
|
|
linktype = link_type_get( name: @map[ data[:link_type] ] )
|
2012-08-23 22:08:27 +00:00
|
|
|
data[:link_type_id] = linktype.id
|
|
|
|
end
|
|
|
|
links = Link.where(
|
2015-04-27 13:42:53 +00:00
|
|
|
link_type_id: data[:link_type_id],
|
|
|
|
link_object_target_id: data[:link_object_source_id],
|
|
|
|
link_object_target_value: data[:link_object_source_value],
|
|
|
|
link_object_source_id: data[:link_object_target_id],
|
|
|
|
link_object_source_value: data[:link_object_target_value]
|
2012-08-23 22:08:27 +00:00
|
|
|
)
|
2015-05-07 10:25:16 +00:00
|
|
|
links.each(&:destroy)
|
2012-08-20 13:21:15 +00:00
|
|
|
end
|
2012-07-15 22:12:06 +00:00
|
|
|
|
2013-06-12 15:59:58 +00:00
|
|
|
def self.link_type_get(data)
|
2015-05-07 10:15:40 +00:00
|
|
|
linktype = Link::Type.find_by( name: data[:name] )
|
2013-06-12 15:59:58 +00:00
|
|
|
if !linktype
|
|
|
|
linktype = Link::Type.create(
|
2015-04-27 13:42:53 +00:00
|
|
|
name: data[:name]
|
2013-06-12 15:59:58 +00:00
|
|
|
)
|
2012-08-21 10:28:41 +00:00
|
|
|
end
|
2015-04-30 17:20:27 +00:00
|
|
|
linktype
|
2013-06-12 15:59:58 +00:00
|
|
|
end
|
2012-08-21 10:28:41 +00:00
|
|
|
|
2013-06-12 15:59:58 +00:00
|
|
|
def self.link_object_get(data)
|
2015-05-07 10:15:40 +00:00
|
|
|
linkobject = Link::Object.find_by( name: data[:name] )
|
2013-06-12 15:59:58 +00:00
|
|
|
if !linkobject
|
|
|
|
linkobject = Link::Object.create(
|
2015-04-27 13:42:53 +00:00
|
|
|
name: data[:name]
|
2013-06-12 15:59:58 +00:00
|
|
|
)
|
2012-08-21 10:28:41 +00:00
|
|
|
end
|
2015-04-30 17:20:27 +00:00
|
|
|
linkobject
|
2013-06-12 15:59:58 +00:00
|
|
|
end
|
2012-08-21 10:28:41 +00:00
|
|
|
|
2012-07-15 22:12:06 +00:00
|
|
|
end
|
|
|
|
|
2013-01-04 18:42:20 +00:00
|
|
|
class Link::Type < ApplicationModel
|
2015-04-27 13:42:53 +00:00
|
|
|
validates :name, presence: true
|
2012-04-10 14:06:46 +00:00
|
|
|
end
|
2012-07-15 22:12:06 +00:00
|
|
|
|
2013-01-04 18:42:20 +00:00
|
|
|
class Link::Object < ApplicationModel
|
2015-04-27 13:42:53 +00:00
|
|
|
validates :name, presence: true
|
2013-06-12 15:59:58 +00:00
|
|
|
end
|