Revision 5d28ad6e
Added by Marc Dequènes over 15 years ago
- ID 5d28ad6e4da6d7eb3927b9e632bb9ac618d64d41
bin/shadowwalker | ||
---|---|---|
field_info = args.shift
|
||
field_name, file_no = field_info.split("#")
|
||
|
||
unless item.has_attribute?(field_name)
|
||
unless item.has_field?(field_name)
|
||
STDERR.puts "No such field '#{field_name}' in object '#{obj_hdl}'."
|
||
exit 2
|
||
end
|
||
... | ... | |
exit 2
|
||
end
|
||
|
||
field_data = item.send(field_name)
|
||
field_data = [field_data] unless field_data.is_a?(Array)
|
||
field_data = item.send(field_name, true)
|
||
|
||
result_is_binary = false
|
||
if file_no == "?"
|
||
... | ... | |
|
||
case type
|
||
when nil
|
||
unless item.has_attribute?(field)
|
||
unless item.has_field?(field)
|
||
STDERR.puts "No such field '#{field}' in object '#{obj_hdl}'."
|
||
exit 2
|
||
end
|
||
... | ... | |
end
|
||
end
|
||
|
||
old_val = item.send(field)
|
||
old_val = [old_val] unless old_val.is_a? Array
|
||
old_val = item.send(field, true)
|
||
when 'rel'
|
||
unless item.relations.include?(field)
|
||
STDERR.puts "No such relation '#{field}' for object '#{obj_hdl}'."
|
||
... | ... | |
|
||
self.short_desc = "Delete an item"
|
||
self.usages_params = [
|
||
""
|
||
"<object> <item>"
|
||
]
|
||
end
|
||
|
||
... | ... | |
end
|
||
cmdparser.add_command(DelCommand.new)
|
||
|
||
class CreateCommand < Command
|
||
def initialize
|
||
super('create', false)
|
||
|
||
self.short_desc = "Create an item"
|
||
self.usages_params = [
|
||
"<object> <new_item> [<field>=<value>] ..."
|
||
]
|
||
end
|
||
|
||
def execute (args)
|
||
if args.size < 1
|
||
STDERR.puts "syntax error: no object name given"
|
||
exit 1
|
||
end
|
||
if args.size < 2
|
||
STDERR.puts "syntax error: no item name given"
|
||
exit 1
|
||
end
|
||
|
||
obj_hdl = args.shift
|
||
obj_klass = $ldapctl.find_klass(obj_hdl)
|
||
if obj_klass.nil?
|
||
STDERR.puts "No such object '#{obj_hdl}'."
|
||
exit 2
|
||
end
|
||
|
||
item_hdl = args.shift
|
||
item = obj_klass.new(item_hdl)
|
||
|
||
args.each do |param|
|
||
param =~ /^([a-zA-Z]+)=(.*)$/
|
||
key = $1
|
||
val = $2
|
||
|
||
if key.nil?
|
||
STDERR.puts "Syntax error in creation parameters: invalid field name"
|
||
exit 1
|
||
end
|
||
|
||
field = key
|
||
|
||
unless item.has_field?(field)
|
||
STDERR.puts "No such field '#{field}' in object '#{obj_hdl}'."
|
||
exit 2
|
||
end
|
||
|
||
attr_info = ActiveLdap::Base.schema.attribute(field)
|
||
if attr_info.read_only?
|
||
STDERR.puts "The field '#{field}' cannot be modified (read only), skipping."
|
||
next
|
||
end
|
||
|
||
if attr_info.binary?
|
||
unless File.exists?(val)
|
||
STDERR.puts "The field '#{field}' contains binary data, you must provide a filename instead of a direct value."
|
||
exit 2
|
||
end
|
||
|
||
begin
|
||
val = File.read(val)
|
||
rescue
|
||
STDERR.puts "The file for the binary field '#{field}' cannot be read: " + $!
|
||
exit 2
|
||
end
|
||
end
|
||
|
||
item.send(field + "=", val)
|
||
end
|
||
|
||
item.save!
|
||
end
|
||
end
|
||
cmdparser.add_command(CreateCommand.new)
|
||
|
||
|
||
begin
|
||
cmdparser.parse
|
Also available in: Unified diff
[evol] added a basic 'create' command, allowing to set fields with a single value to ensure required fields are not missing; btw ensure the objectClass attributetype is never considered as a field