index 0560933c190b087e269d36bba002a161b5164c69..d2296f0508774c8b1318e1892c6bda1228f7812a 100644 (file)
use Exporter;
@ISA = qw(Exporter);
my @functions = (
+ "create_passwd",
"create_xml_hash",
"get_content_from_xml_hash",
"add_content2xml_hash",
"get_limit_statement",
"get_orderby_statement",
"get_dns_domains",
+ "get_server_addresses",
"get_logged_in_users",
+ "import_events",
+ "del_doubles",
);
@EXPORT = @functions;
use strict;
use MIME::Base64;
use XML::Simple;
use Data::Dumper;
+use Net::DNS;
+
my $op_hash = {
'eq' => '=',
}
+sub create_passwd {
+ my $new_passwd = "";
+ for(my $i=0; $i<31; $i++) {
+ $new_passwd .= ("a".."z","A".."Z",0..9)[int(rand(62))]
+ }
+
+ return $new_passwd;
+}
+
+
+sub del_doubles {
+ my %all;
+ $all{$_}=0 for @_;
+ return (keys %all);
+}
#=== FUNCTION ================================================================
sub build_msg ($$$$) {
my ($header, $from, $to, $data) = @_;
+ # data is of form, i.e.
+ # %data= ('ip' => $address, 'mac' => $mac);
+
my $out_hash = &create_xml_hash($header, $from, $to);
while ( my ($key, $value) = each(%$data) ) {
my @xml_tags = keys %{$phrase};
my $tag = $xml_tags[0];
my $val = $phrase->{$tag}[0];
- push(@phrase_l, "$tag$operator'$val'");
+ # integer columns do not have to have single quotes besides the value
+ if ($tag eq "id") {
+ push(@phrase_l, "$tag$operator$val");
+ } else {
+ push(@phrase_l, "$tag$operator'$val'");
+ }
}
my $clause_str .= join(" $connector ", @phrase_l);
push(@clause_l, "($clause_str)");
}
+#############################################
+# moved from gosa-si-client: rettenbe, 16.05.2008
+# outcommented at gosa-si-client
+sub get_server_addresses {
+ my $domain= shift;
+ my @result;
+
+ my $error = 0;
+ my $res = Net::DNS::Resolver->new;
+ my $query = $res->send("_gosa-si._tcp.".$domain, "SRV");
+ my @hits;
+
+ if ($query) {
+ foreach my $rr ($query->answer) {
+ push(@hits, $rr->target.":".$rr->port);
+ }
+ }
+ else {
+ #warn "query failed: ", $res->errorstring, "\n";
+ $error++;
+ }
+
+ if( $error == 0 ) {
+ foreach my $hit (@hits) {
+ my ($hit_name, $hit_port) = split(/:/, $hit);
+ chomp($hit_name);
+ chomp($hit_port);
+
+ my $address_query = $res->send($hit_name);
+ if( 1 == length($address_query->answer) ) {
+ foreach my $rr ($address_query->answer) {
+ push(@result, $rr->address.":".$hit_port);
+ }
+ }
+ }
+ }
+
+ return @result;
+}
+
+
sub get_logged_in_users {
my $result = qx(/usr/bin/w -hs);
my @res_lines;
}
+
+sub import_events {
+ my ($event_dir) = @_;
+ my $event_hash;
+ my $error = 0;
+ my @result = ();
+ if (not -e $event_dir) {
+ $error++;
+ push(@result, "cannot find directory or directory is not readable: $event_dir");
+ }
+
+ my $DIR;
+ if ($error == 0) {
+ opendir ($DIR, $event_dir) or do {
+ $error++;
+ push(@result, "cannot open directory '$event_dir' for reading: $!\n");
+ }
+ }
+
+ if ($error == 0) {
+ while (defined (my $event = readdir ($DIR))) {
+ if( $event eq "." || $event eq ".." ) { next; }
+
+ # try to import event module
+ eval{ require $event; };
+ if( $@ ) {
+ $error++;
+ push(@result, "import of event module '$event' failed: $@");
+ next;
+ }
+
+ # fetch all single events
+ $event =~ /(\S*?).pm$/;
+ my $event_module = $1;
+ my $events_l = eval( $1."::get_events()") ;
+ foreach my $event_name (@{$events_l}) {
+ $event_hash->{$event_name} = $event_module;
+ }
+ my $events_string = join( ", ", @{$events_l});
+ push(@result, "import of event module '$event' succeed: $events_string");
+ }
+
+ close $DIR;
+ }
+
+ return ($error, \@result, $event_hash);
+
+}
+
+
1;