1 package gosaTriggered;
2 use Exporter;
3 @ISA = qw(Exporter);
4 my @events = (
5 "get_events",
6 "get_login_usr_for_client",
7 "get_client_for_login_usr",
8 "gen_smb_hash",
9 "trigger_reload_ldap_config",
10 "ping",
11 "network_completition",
12 "set_activated_for_installation",
13 "new_key_for_client",
14 "detect_hardware",
15 "get_login_usr",
16 "get_login_client",
17 "trigger_action_localboot",
18 "trigger_action_faireboot",
19 "trigger_action_reboot",
20 "trigger_action_activate",
21 "trigger_action_lock",
22 "trigger_action_halt",
23 "trigger_action_update",
24 "trigger_action_reinstall",
25 "trigger_action_memcheck",
26 "trigger_action_sysinfo",
27 "trigger_action_instant_update",
28 "trigger_action_rescan",
29 "trigger_action_wake",
30 "recreate_fai_server_db",
31 "send_user_msg",
32 );
33 @EXPORT = @events;
35 use strict;
36 use warnings;
37 use GOSA::GosaSupportDaemon;
38 use Data::Dumper;
39 use Crypt::SmbHash;
40 use Net::ARP;
41 use Net::Ping;
42 use Socket;
44 BEGIN {}
46 END {}
48 ### Start ######################################################################
50 #&main::read_configfile($main::cfg_file, %cfg_defaults);
52 sub get_events {
53 return \@events;
54 }
56 sub send_user_msg {
57 my ($msg, $msg_hash, $session_id) = @_ ;
58 my $header = @{$msg_hash->{'header'}}[0];
59 my $source = @{$msg_hash->{'source'}}[0];
60 my $target = @{$msg_hash->{'target'}}[0];
62 #my $subject = &decode_base64(@{$msg_hash->{'subject'}}[0]);
63 my $subject = @{$msg_hash->{'subject'}}[0];
64 my $from = @{$msg_hash->{'from'}}[0];
65 my $to = @{$msg_hash->{'to'}}[0];
66 my $delivery_time = @{$msg_hash->{'delivery_time'}}[0];
67 #my $message = &decode_base64(@{$msg_hash->{'message'}}[0]);
68 my $message = @{$msg_hash->{'message'}}[0];
70 # keep job queue uptodate if necessary
71 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
72 if( defined $jobdb_id) {
73 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
74 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
75 my $res = $main::job_db->exec_statement($sql_statement);
76 }
78 # error handling
79 if (not $delivery_time =~ /^\d{14}$/) {
80 my $error_string = "delivery_time '$delivery_time' is not a valid timestamp, please use format 'yyyymmddhhmmss'";
81 &main::daemon_log("$session_id ERROR: $error_string", 1);
82 return &create_xml_string(&create_xml_hash($header, $target, $source, $error_string));
83 }
85 # add incoming message to messaging_db
86 my $func_dic = {table=>$main::messaging_tn,
87 primkey=>['id'],
88 subject=>$subject,
89 message_from=>$from,
90 message_to=>$to,
91 flag=>"n",
92 direction=>"in",
93 delivery_time=>$delivery_time,
94 message=>$message,
95 timestamp=>&get_time(),
96 };
97 my $res = $main::messaging_db->add_dbentry($func_dic);
98 if (not $res == 0) {
99 &main::daemon_log("$session_id ERROR: gosaTriggered.pm: cannot add message to message_db: $res", 1);
100 } else {
101 &main::daemon_log("$session_id INFO: gosaTriggered.pm: message with subject '$subject' successfully added to message_db", 5);
102 }
104 return;
105 }
107 sub send_user_msg_OLD {
108 my ($msg, $msg_hash, $session_id) = @_ ;
109 my @out_msg_l;
110 my @user_list;
111 my @group_list;
113 my $header = @{$msg_hash->{'header'}}[0];
114 my $source = @{$msg_hash->{'source'}}[0];
115 my $target = @{$msg_hash->{'target'}}[0];
116 my $message = @{$msg_hash->{'message'}}[0];
117 if( exists $msg_hash->{'user'} ) { @user_list = @{$msg_hash->{'user'}}; }
118 if( exists $msg_hash->{'group'} ) { @group_list = @{$msg_hash->{'group'}}; }
120 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
121 if( defined $jobdb_id) {
122 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
123 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
124 my $res = $main::job_db->exec_statement($sql_statement);
125 }
127 # error handling
128 if( not @user_list && not @group_list ) {
129 &main::daemon_log("$session_id WARNING: no user-tag or a group-tag specified in 'send_user_msg'", 3);
130 return ("<xml><header>$header</header><source>GOSA</source><target>GOSA</target>".
131 "<error_string>no user-tag or a group-tag specified in 'send_user_msg'</error_string></xml>");
132 }
133 if( not defined $message ) {
134 &main::daemon_log("$session_id WARNING: no message-tag specified in 'send_user_msg'", 3);
135 return ("<xml><header>$header</header><source>GOSA</source><target>GOSA</target>".
136 "<error_string>no message-tag specified in 'send_user_msg'</error_string></xml>");
138 }
140 # resolve groups to users
141 my $ldap_handle = &main::get_ldap_handle($session_id);
142 if( @group_list ) {
143 if( not defined $ldap_handle ) {
144 &main::daemon_log("$session_id ERROR: cannot connect to ldap", 1);
145 return ();
146 }
147 foreach my $group (@group_list) { # Perform search
148 my $mesg = $ldap_handle->search(
149 base => $main::ldap_base,
150 scope => 'sub',
151 attrs => ['memberUid'],
152 filter => "(&(objectClass=posixGroup)(cn=$group)(memberUid=*))");
153 if($mesg->code) {
154 &main::daemon_log($mesg->error, 1);
155 return ();
156 }
157 my $entry= $mesg->entry(0);
158 my @users= $entry->get_value("memberUid");
159 foreach my $user (@users) { push(@user_list, $user); }
160 }
161 }
163 # drop multiple users in @user_list
164 my %seen = ();
165 foreach my $user (@user_list) {
166 $seen{$user}++;
167 }
168 @user_list = keys %seen;
170 # build xml messages sended to client where user is logged in
171 foreach my $user (@user_list) {
172 my $sql_statement = "SELECT * FROM $main::login_users_tn WHERE user='$user'";
173 my $db_res = $main::login_users_db->select_dbentry($sql_statement);
175 if(0 == keys(%{$db_res})) {
177 } else {
178 while( my($hit, $content) = each %{$db_res} ) {
179 my $out_hash = &create_xml_hash('send_user_msg', $main::server_address, $content->{'client'});
180 &add_content2xml_hash($out_hash, 'message', $message);
181 &add_content2xml_hash($out_hash, 'user', $user);
182 if( exists $msg_hash->{'jobdb_id'} ) {
183 &add_content2xml_hash($out_hash, 'jobdb_id', @{$msg_hash->{'jobdb_id'}}[0]);
184 }
185 my $out_msg = &create_xml_string($out_hash);
186 push(@out_msg_l, $out_msg);
187 }
188 }
189 }
191 return @out_msg_l;
192 }
195 sub recreate_fai_server_db {
196 my ($msg, $msg_hash, $session_id) = @_ ;
197 my $out_msg;
199 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
200 if( defined $jobdb_id) {
201 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
202 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
203 my $res = $main::job_db->exec_statement($sql_statement);
204 }
206 $main::fai_server_db->create_table("new_fai_server", \@main::fai_server_col_names);
207 &main::create_fai_server_db("new_fai_server");
208 $main::fai_server_db->move_table("new_fai_server", $main::fai_server_tn);
210 my @out_msg_l = ( $out_msg );
211 return @out_msg_l;
212 }
215 sub get_login_usr_for_client {
216 my ($msg, $msg_hash, $session_id) = @_ ;
217 my $header = @{$msg_hash->{'header'}}[0];
218 my $source = @{$msg_hash->{'source'}}[0];
219 my $target = @{$msg_hash->{'target'}}[0];
220 my $client = @{$msg_hash->{'client'}}[0];
222 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
223 if( defined $jobdb_id) {
224 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
225 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
226 my $res = $main::job_db->exec_statement($sql_statement);
227 }
229 $header =~ s/^gosa_//;
231 my $sql_statement = "SELECT * FROM known_clients WHERE hostname='$client' OR macaddress LIKE '$client'";
232 my $res = $main::known_clients_db->select_dbentry($sql_statement);
234 my $out_msg = "<xml><header>$header</header><source>$target</source><target>$source</target>";
235 $out_msg .= &db_res2xml($res);
236 $out_msg .= "</xml>";
238 my @out_msg_l = ( $out_msg );
239 return @out_msg_l;
240 }
243 sub get_client_for_login_usr {
244 my ($msg, $msg_hash, $session_id) = @_ ;
245 my $header = @{$msg_hash->{'header'}}[0];
246 my $source = @{$msg_hash->{'source'}}[0];
247 my $target = @{$msg_hash->{'target'}}[0];
249 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
250 if( defined $jobdb_id) {
251 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
252 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
253 my $res = $main::job_db->exec_statement($sql_statement);
254 }
256 my $usr = @{$msg_hash->{'usr'}}[0];
257 $header =~ s/^gosa_//;
259 my $sql_statement = "SELECT * FROM known_clients WHERE login LIKE '%$usr%'";
260 my $res = $main::known_clients_db->select_dbentry($sql_statement);
262 my $out_msg = "<xml><header>$header</header><source>$target</source><target>$source</target>";
263 $out_msg .= &db_res2xml($res);
264 $out_msg .= "</xml>";
265 my @out_msg_l = ( $out_msg );
266 return @out_msg_l;
268 }
271 sub ping {
272 my ($msg, $msg_hash, $session_id) = @_ ;
273 my $out_msg = $msg;
274 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
275 if( defined $jobdb_id) {
276 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
277 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
278 my $res = $main::job_db->exec_statement($sql_statement);
279 }
281 $out_msg =~ s/<header>gosa_/<header>/;
283 my @out_msg_l = ( $out_msg );
284 return @out_msg_l;
285 }
287 sub gen_smb_hash {
288 my ($msg, $msg_hash, $session_id) = @_ ;
289 my $source = @{$msg_hash->{source}}[0];
290 my $target = @{$msg_hash->{target}}[0];
291 my $password = @{$msg_hash->{password}}[0];
293 my %data= ('hash' => join(q[:], ntlmgen $password));
294 my $out_msg = &build_msg("gen_smb_hash", $target, 'GOSA', \%data );
295 return ( $out_msg );
296 }
299 sub network_completition {
300 my ($msg, $msg_hash, $session_id) = @_ ;
301 my $source = @{$msg_hash->{source}}[0];
302 my $target = @{$msg_hash->{target}}[0];
303 my $name = @{$msg_hash->{hostname}}[0];
305 # Can we resolv the name?
306 my %data;
307 if (inet_aton($name)){
308 my $address = inet_ntoa(inet_aton($name));
309 my $p = Net::Ping->new('tcp');
310 my $mac= "";
311 if ($p->ping($address, 1)){
312 $mac = Net::ARP::arp_lookup("", $address);
313 }
315 %data= ('ip' => $address, 'mac' => $mac);
316 } else {
317 %data= ('ip' => '', 'mac' => '');
318 }
320 my $out_msg = &build_msg("network_completition", $target, 'GOSA', \%data );
322 return ( $out_msg );
323 }
326 sub detect_hardware {
327 my ($msg, $msg_hash, $session_id) = @_ ;
328 # just forward msg to client, but dont forget to split off 'gosa_' in header
329 my $source = @{$msg_hash->{source}}[0];
330 my $target = @{$msg_hash->{target}}[0];
331 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
332 if( defined $jobdb_id) {
333 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
334 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
335 my $res = $main::job_db->exec_statement($sql_statement);
336 }
338 my $out_hash = &create_xml_hash("detect_hardware", $source, $target);
339 if( defined $jobdb_id ) {
340 &add_content2xml_hash($out_hash, 'jobdb_id', $jobdb_id);
341 }
342 my $out_msg = &create_xml_string($out_hash);
344 my @out_msg_l = ( $out_msg );
345 return @out_msg_l;
347 }
350 sub trigger_reload_ldap_config {
351 my ($msg, $msg_hash, $session_id) = @_ ;
352 my $target = @{$msg_hash->{target}}[0];
354 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
355 if( defined $jobdb_id) {
356 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
357 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
358 my $res = $main::job_db->exec_statement($sql_statement);
359 }
361 my $out_hash = &create_xml_hash("reload_ldap_config", $main::server_address, $main::server_address, $target);
362 if( defined ) {
363 &add_content2xml_hash($out_hash, 'jobdb_id', $jobdb_id);
364 }
365 my $out_msg = &create_xml_string($out_hash);
366 my @out_msg_l;
367 push(@out_msg_l, $out_msg);
368 return @out_msg_l;
369 }
372 sub set_activated_for_installation {
373 my ($msg, $msg_hash, $session_id) = @_;
374 my $header = @{$msg_hash->{header}}[0];
375 my $source = @{$msg_hash->{source}}[0];
376 my $target = @{$msg_hash->{target}}[0];
377 my @out_msg_l;
379 # create set_activated_for_installation message
380 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
381 if( defined $jobdb_id) {
382 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
383 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
384 my $res = $main::job_db->exec_statement($sql_statement);
385 }
387 my $out_hash = &create_xml_hash("set_activated_for_installation", $source, $target);
388 if( defined $jobdb_id ) {
389 &add_content2xml_hash($out_hash, 'jobdb_id', $jobdb_id);
390 }
391 my $out_msg = &create_xml_string($out_hash);
392 push(@out_msg_l, $out_msg);
394 # create new_ldap_config message, client is waiting for that piece of information
395 my $new_ldap_config_out = &main::new_ldap_config($source, $session_id);
396 push(@out_msg_l, $new_ldap_config_out);
399 return @out_msg_l;
400 }
403 sub trigger_action_faireboot {
404 my ($msg, $msg_hash, $session_id) = @_;
405 my $macaddress = @{$msg_hash->{target}}[0];
406 my $source = @{$msg_hash->{source}}[0];
408 my @out_msg_l;
409 $msg =~ s/<header>gosa_trigger_action_faireboot<\/header>/<header>trigger_action_faireboot<\/header>/;
410 push(@out_msg_l, $msg);
412 &main::change_goto_state('locked', \@{$msg_hash->{target}}, $session_id);
413 &main::change_fai_state('install', \@{$msg_hash->{target}}, $session_id);
415 # delete all jobs from jobqueue which correspond to fai
416 my $sql_statement = "DELETE FROM $main::job_queue_tn WHERE (macaddress='$macaddress' AND ".
417 "status='processing')";
418 $main::job_db->del_dbentry($sql_statement );
420 return @out_msg_l;
421 }
424 sub trigger_action_lock {
425 my ($msg, $msg_hash, $session_id) = @_;
426 my $macaddress = @{$msg_hash->{target}}[0];
427 my $source = @{$msg_hash->{source}}[0];
429 &main::change_goto_state('locked', \@{$msg_hash->{target}}, $session_id);
430 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
431 if( defined $jobdb_id) {
432 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
433 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
434 my $res = $main::job_db->exec_statement($sql_statement);
435 }
437 my @out_msg_l;
438 return @out_msg_l;
439 }
442 sub trigger_action_activate {
443 my ($msg, $msg_hash, $session_id) = @_;
444 my $macaddress = @{$msg_hash->{target}}[0];
445 my $source = @{$msg_hash->{source}}[0];
447 &main::change_goto_state('active', \@{$msg_hash->{target}}, $session_id);
448 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
449 if( defined $jobdb_id) {
450 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
451 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
452 my $res = $main::job_db->exec_statement($sql_statement);
453 }
455 my $out_hash = &create_xml_hash("set_activated_for_installation", $source, $macaddress);
456 if( exists $msg_hash->{'jobdb_id'} ) {
457 &add_content2xml_hash($out_hash, 'jobdb_id', @{$msg_hash->{'jobdb_id'}}[0]);
458 }
459 my $out_msg = &create_xml_string($out_hash);
461 return ( $out_msg );
462 }
465 sub trigger_action_localboot {
466 my ($msg, $msg_hash, $session_id) = @_;
467 $msg =~ s/<header>gosa_trigger_action_localboot<\/header>/<header>trigger_action_localboot<\/header>/;
468 &main::change_fai_state('localboot', \@{$msg_hash->{target}}, $session_id);
469 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
470 if( defined $jobdb_id) {
471 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
472 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
473 my $res = $main::job_db->exec_statement($sql_statement);
474 }
476 my @out_msg_l = ($msg);
477 return @out_msg_l;
478 }
481 sub trigger_action_halt {
482 my ($msg, $msg_hash, $session_id) = @_;
483 $msg =~ s/<header>gosa_trigger_action_halt<\/header>/<header>trigger_action_halt<\/header>/;
485 &main::change_fai_state('halt', \@{$msg_hash->{target}}, $session_id);
486 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
487 if( defined $jobdb_id) {
488 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
489 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
490 my $res = $main::job_db->exec_statement($sql_statement);
491 }
493 my @out_msg_l = ($msg);
494 return @out_msg_l;
495 }
498 sub trigger_action_reboot {
499 my ($msg, $msg_hash, $session_id) = @_;
500 $msg =~ s/<header>gosa_trigger_action_reboot<\/header>/<header>trigger_action_reboot<\/header>/;
502 &main::change_fai_state('reboot', \@{$msg_hash->{target}}, $session_id);
503 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
504 if( defined $jobdb_id) {
505 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
506 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
507 my $res = $main::job_db->exec_statement($sql_statement);
508 }
510 my @out_msg_l = ($msg);
511 return @out_msg_l;
512 }
515 sub trigger_action_memcheck {
516 my ($msg, $msg_hash, $session_id) = @_ ;
517 $msg =~ s/<header>gosa_trigger_action_memcheck<\/header>/<header>trigger_action_memcheck<\/header>/;
519 &main::change_fai_state('memcheck', \@{$msg_hash->{target}}, $session_id);
520 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
521 if( defined $jobdb_id) {
522 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
523 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
524 my $res = $main::job_db->exec_statement($sql_statement);
525 }
527 my @out_msg_l = ($msg);
528 return @out_msg_l;
529 }
532 sub trigger_action_reinstall {
533 my ($msg, $msg_hash, $session_id) = @_;
534 $msg =~ s/<header>gosa_trigger_action_reinstall<\/header>/<header>trigger_action_reinstall<\/header>/;
536 &main::change_fai_state('reinstall', \@{$msg_hash->{target}}, $session_id);
538 my %data = ( 'macAddress' => \@{$msg_hash->{target}} );
539 my $wake_msg = &build_msg("trigger_wake", "GOSA", "KNOWN_SERVER", \%data);
540 my @out_msg_l = ($wake_msg, $msg);
541 return @out_msg_l;
542 }
545 sub trigger_action_update {
546 my ($msg, $msg_hash, $session_id) = @_;
547 $msg =~ s/<header>gosa_trigger_action_update<\/header>/<header>trigger_action_update<\/header>/;
549 &main::change_fai_state('update', \@{$msg_hash->{target}}, $session_id);
551 my %data = ( 'macAddress' => \@{$msg_hash->{target}} );
552 my $wake_msg = &build_msg("trigger_wake", "GOSA", "KNOWN_SERVER", \%data);
553 my @out_msg_l = ($wake_msg, $msg);
554 return @out_msg_l;
555 }
558 sub trigger_action_instant_update {
559 my ($msg, $msg_hash, $session_id) = @_;
560 $msg =~ s/<header>gosa_trigger_action_instant_update<\/header>/<header>trigger_action_instant_update<\/header>/;
562 &main::change_fai_state('update', \@{$msg_hash->{target}}, $session_id);
564 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
565 if( defined $jobdb_id) {
566 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
567 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
568 my $res = $main::job_db->exec_statement($sql_statement);
569 }
571 my %data = ( 'macAddress' => \@{$msg_hash->{target}} );
572 my $wake_msg = &build_msg("trigger_wake", "GOSA", "KNOWN_SERVER", \%data);
573 my @out_msg_l = ($wake_msg, $msg);
574 return @out_msg_l;
575 }
578 sub trigger_action_sysinfo {
579 my ($msg, $msg_hash, $session_id) = @_;
580 $msg =~ s/<header>gosa_trigger_action_sysinfo<\/header>/<header>trigger_action_sysinfo<\/header>/;
582 &main::change_fai_state('sysinfo', \@{$msg_hash->{target}}, $session_id);
583 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
584 if( defined $jobdb_id) {
585 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
586 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
587 my $res = $main::job_db->exec_statement($sql_statement);
588 }
590 my @out_msg_l = ($msg);
591 return @out_msg_l;
592 }
595 sub new_key_for_client {
596 my ($msg, $msg_hash, $session_id) = @_;
598 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
599 if( defined $jobdb_id) {
600 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
601 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
602 my $res = $main::job_db->exec_statement($sql_statement);
603 }
605 $msg =~ s/<header>gosa_new_key_for_client<\/header>/<header>new_key<\/header>/;
606 my @out_msg_l = ($msg);
607 return @out_msg_l;
608 }
611 sub trigger_action_rescan {
612 my ($msg, $msg_hash, $session_id) = @_;
614 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
615 if( defined $jobdb_id) {
616 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
617 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
618 my $res = $main::job_db->exec_statement($sql_statement);
619 }
622 $msg =~ s/<header>gosa_trigger_action_rescan<\/header>/<header>trigger_action_rescan<\/header>/;
623 my @out_msg_l = ($msg);
624 return @out_msg_l;
625 }
628 sub trigger_action_wake {
629 my ($msg, $msg_hash, $session_id) = @_;
631 my $jobdb_id = @{$msg_hash->{'jobdb_id'}}[0];
632 if( defined $jobdb_id) {
633 my $sql_statement = "UPDATE $main::job_queue_tn SET status='processed' WHERE id='$jobdb_id'";
634 &main::daemon_log("$session_id DEBUG: $sql_statement", 7);
635 my $res = $main::job_db->exec_statement($sql_statement);
636 }
639 my %data = ( 'macAddress' => \@{$msg_hash->{target}} );
640 my $out_msg = &build_msg("trigger_wake", "GOSA", "KNOWN_SERVER", \%data);
641 my @out_msg_l = ($out_msg);
642 return @out_msg_l;
643 }
646 1;