2014-09-09 23:42:20 +00:00
|
|
|
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
|
|
|
|
|
|
|
|
class ObjectManager
|
|
|
|
|
|
|
|
=begin
|
|
|
|
|
2014-11-06 23:37:05 +00:00
|
|
|
list all backend managed object
|
2014-09-09 23:42:20 +00:00
|
|
|
|
|
|
|
ObjectManager.listObjects()
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.listObjects
|
2014-11-06 23:37:05 +00:00
|
|
|
['Ticket', 'TicketArticle', 'User', 'Organization', 'Group' ]
|
|
|
|
end
|
|
|
|
|
|
|
|
=begin
|
|
|
|
|
|
|
|
list all frontend managed object
|
|
|
|
|
|
|
|
ObjectManager.listFrontendObjects()
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.listFrontendObjects
|
|
|
|
['Ticket', 'User', 'Organization' ] #, 'Group' ]
|
2014-09-09 23:42:20 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
class ObjectManager::Attribute < ApplicationModel
|
|
|
|
self.table_name = 'object_manager_attributes'
|
2015-04-27 13:42:53 +00:00
|
|
|
belongs_to :object_lookup, class_name: 'ObjectLookup'
|
|
|
|
validates :name, presence: true
|
2014-09-09 23:42:20 +00:00
|
|
|
store :screens
|
|
|
|
store :data_option
|
|
|
|
|
2014-11-02 19:44:15 +00:00
|
|
|
=begin
|
|
|
|
|
|
|
|
list of all attributes
|
|
|
|
|
|
|
|
result = ObjectManager::Attribute.list_full
|
|
|
|
|
|
|
|
result = [
|
|
|
|
{
|
|
|
|
:name => 'some name',
|
|
|
|
:display => '...',
|
|
|
|
}.
|
|
|
|
],
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.list_full
|
|
|
|
result = ObjectManager::Attribute.all
|
|
|
|
attributes = []
|
|
|
|
assets = {}
|
|
|
|
result.each {|item|
|
|
|
|
attribute = item.attributes
|
|
|
|
attribute[:object] = ObjectLookup.by_id( item.object_lookup_id )
|
|
|
|
attribute.delete('object_lookup_id')
|
|
|
|
attributes.push attribute
|
|
|
|
}
|
|
|
|
attributes
|
|
|
|
end
|
2014-09-09 23:42:20 +00:00
|
|
|
|
|
|
|
=begin
|
|
|
|
|
2015-02-08 08:16:01 +00:00
|
|
|
add a new attribute entry for an object
|
2014-09-09 23:42:20 +00:00
|
|
|
|
|
|
|
ObjectManager::Attribute.add(
|
2015-01-04 12:49:04 +00:00
|
|
|
:object => 'Ticket',
|
|
|
|
:name => 'group_id',
|
|
|
|
:frontend => 'Group',
|
|
|
|
:data_type => 'select',
|
2014-09-09 23:42:20 +00:00
|
|
|
:data_option => {
|
2015-01-04 12:49:04 +00:00
|
|
|
:relation => 'Group',
|
2014-09-09 23:42:20 +00:00
|
|
|
:relation_condition => { :access => 'rw' },
|
2015-01-04 12:49:04 +00:00
|
|
|
:multiple => false,
|
|
|
|
:null => true,
|
|
|
|
:translate => false,
|
2014-09-09 23:42:20 +00:00
|
|
|
},
|
2015-01-04 12:49:04 +00:00
|
|
|
:editable => false,
|
|
|
|
:active => true,
|
|
|
|
:screens => {
|
2014-09-09 23:42:20 +00:00
|
|
|
:create => {
|
|
|
|
'-all-' => {
|
|
|
|
:required => true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
:edit => {
|
|
|
|
:Agent => {
|
|
|
|
:required => true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2015-01-04 12:49:04 +00:00
|
|
|
:pending_migration => false,
|
|
|
|
:position => 20,
|
|
|
|
:created_by_id => 1,
|
|
|
|
:updated_by_id => 1,
|
|
|
|
:created_at => '2014-06-04 10:00:00',
|
|
|
|
:updated_at => '2014-06-04 10:00:00',
|
2014-09-09 23:42:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.add(data)
|
|
|
|
|
|
|
|
# lookups
|
|
|
|
if data[:object]
|
|
|
|
data[:object_lookup_id] = ObjectLookup.by_name( data[:object] )
|
|
|
|
end
|
|
|
|
data.delete(:object)
|
|
|
|
|
|
|
|
# check newest entry - is needed
|
|
|
|
result = ObjectManager::Attribute.where(
|
2015-04-27 13:42:53 +00:00
|
|
|
object_lookup_id: data[:object_lookup_id],
|
|
|
|
name: data[:name],
|
2014-09-09 23:42:20 +00:00
|
|
|
).first
|
|
|
|
if result
|
|
|
|
# raise "ERROR: attribute #{data[:name]} for #{data[:object]} already exists"
|
|
|
|
return result.update_attributes(data)
|
|
|
|
end
|
|
|
|
|
|
|
|
# create history
|
|
|
|
ObjectManager::Attribute.create(data)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
=begin
|
|
|
|
|
2015-02-08 08:16:01 +00:00
|
|
|
get the attribute model based on object and name
|
|
|
|
|
|
|
|
attribute = ObjectManager::Attribute.get(
|
|
|
|
:object => 'Ticket',
|
|
|
|
:name => 'group_id',
|
|
|
|
)
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.get(data)
|
|
|
|
|
|
|
|
# lookups
|
|
|
|
if data[:object]
|
|
|
|
data[:object_lookup_id] = ObjectLookup.by_name( data[:object] )
|
|
|
|
end
|
|
|
|
|
|
|
|
ObjectManager::Attribute.where(
|
2015-04-27 13:42:53 +00:00
|
|
|
object_lookup_id: data[:object_lookup_id],
|
|
|
|
name: data[:name],
|
2015-02-08 08:16:01 +00:00
|
|
|
).first
|
|
|
|
end
|
|
|
|
|
|
|
|
=begin
|
|
|
|
|
2014-11-02 19:44:15 +00:00
|
|
|
get user based list of object attributes
|
2014-09-09 23:42:20 +00:00
|
|
|
|
|
|
|
attribute_list = ObjectManager::Attribute.by_object('Ticket', user)
|
|
|
|
|
|
|
|
returns:
|
|
|
|
|
|
|
|
[
|
|
|
|
{ :name => 'api_key', :display => 'API KEY', :tag => 'input', :null => true, :edit => true, :maxlength => 32 },
|
|
|
|
{ :name => 'api_ip_regexp', :display => 'API IP RegExp', :tag => 'input', :null => true, :edit => true },
|
|
|
|
{ :name => 'api_ip_max', :display => 'API IP Max', :tag => 'input', :null => true, :edit => true },
|
|
|
|
]
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.by_object(object, user)
|
|
|
|
|
|
|
|
# lookups
|
|
|
|
if object
|
|
|
|
object_lookup_id = ObjectLookup.by_name( object )
|
|
|
|
end
|
|
|
|
|
|
|
|
# get attributes in right order
|
|
|
|
result = ObjectManager::Attribute.where(
|
2015-04-27 13:42:53 +00:00
|
|
|
object_lookup_id: object_lookup_id,
|
|
|
|
active: true,
|
2014-09-09 23:42:20 +00:00
|
|
|
).order('position ASC')
|
|
|
|
attributes = []
|
|
|
|
result.each {|item|
|
|
|
|
data = {
|
2015-04-27 13:42:53 +00:00
|
|
|
name: item.name,
|
|
|
|
display: item.display,
|
|
|
|
tag: item.data_type,
|
2014-09-09 23:42:20 +00:00
|
|
|
#:null => item.null,
|
|
|
|
}
|
|
|
|
if item.screens
|
|
|
|
data[:screen] = {}
|
|
|
|
item.screens.each {|screen, roles_options |
|
|
|
|
data[:screen][screen] = {}
|
|
|
|
roles_options.each {|role, options|
|
|
|
|
if role == '-all-'
|
|
|
|
data[:screen][screen] = options
|
|
|
|
elsif user && user.is_role(role)
|
|
|
|
data[:screen][screen] = options
|
|
|
|
end
|
|
|
|
}
|
|
|
|
}
|
|
|
|
end
|
|
|
|
if item.data_option
|
2015-01-04 15:39:57 +00:00
|
|
|
data = data.merge( item.data_option.symbolize_keys )
|
2014-09-09 23:42:20 +00:00
|
|
|
end
|
|
|
|
attributes.push data
|
|
|
|
}
|
|
|
|
attributes
|
|
|
|
end
|
|
|
|
|
2015-01-04 12:49:04 +00:00
|
|
|
=begin
|
|
|
|
|
|
|
|
get user based list of object attributes as hash
|
|
|
|
|
|
|
|
attribute_list = ObjectManager::Attribute.by_object_as_hash('Ticket', user)
|
|
|
|
|
|
|
|
returns:
|
|
|
|
|
|
|
|
{
|
|
|
|
'api_key' => { :name => 'api_key', :display => 'API KEY', :tag => 'input', :null => true, :edit => true, :maxlength => 32 },
|
|
|
|
'api_ip_regexp' => { :name => 'api_ip_regexp', :display => 'API IP RegExp', :tag => 'input', :null => true, :edit => true },
|
|
|
|
'api_ip_max' => { :name => 'api_ip_max', :display => 'API IP Max', :tag => 'input', :null => true, :edit => true },
|
|
|
|
}
|
|
|
|
|
|
|
|
=end
|
|
|
|
|
|
|
|
def self.by_object_as_hash(object, user)
|
|
|
|
list = self.by_object(object, user)
|
|
|
|
hash = {}
|
|
|
|
list.each {|item|
|
|
|
|
hash[ item[:name] ] = item
|
|
|
|
}
|
|
|
|
hash
|
|
|
|
end
|
|
|
|
|
2014-09-09 23:42:20 +00:00
|
|
|
end
|