diff --git a/fhem/FHEM/98_DOIF.pm b/fhem/FHEM/98_DOIF.pm
index 5cb0e7918..0ecf631f6 100644
--- a/fhem/FHEM/98_DOIF.pm
+++ b/fhem/FHEM/98_DOIF.pm
@@ -473,7 +473,8 @@ DOIF_CheckCond($$)
{
my ($hash,$condition) = @_;
my $err="";
- my ($sec,$min,$hour,$mday,$month,$year,$wday,$yday,$isdst) = localtime;
+ my ($seconds, $microseconds) = gettimeofday();
+ my ($sec,$min,$hour,$mday,$month,$year,$wday,$yday,$isdst) = localtime($seconds);
my $hms = sprintf("%02d:%02d:%02d", $hour, $min, $sec);
my $hm = sprintf("%02d:%02d", $hour, $min);
my $device;
@@ -635,7 +636,8 @@ DOIF_SetTimer($$)
my ($err, $h, $m, $s, $fn) = GetTimeSpec($timeStr);
return $err if($err);
my $second = $h*3600+$m*60+$s;
- my $now = time();
+ #my $now = time();
+ my ($now, $microseconds) = gettimeofday();
my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime($now);
my $isdst_now=$isdst;
my $sec_today = $hour*3600+$min*60+$sec;
@@ -682,7 +684,8 @@ DOIF_SetSleepTimer($$$$$)
if ($hash->{helper}{sleeptimer} == -1 and ($last_cond != $nr or AttrVal($pn,"do","") eq "always")) {
my @sleeptimer=split(/:/,AttrVal($pn,"wait",""));
if ($sleeptimer[$nr]) {
- my $next_time = time()+$sleeptimer[$nr];
+ my ($seconds, $microseconds) = gettimeofday();
+ my $next_time = $seconds+$sleeptimer[$nr];
$hash->{helper}{sleeptimer}=$nr;
$hash->{helper}{sleepdevice}=$device;
my $cmd_nr=$nr+1;
@@ -1070,7 +1073,7 @@ Zeitintervalle über mehrere Tage müssen als Zeitpunkte angegeben werden, z. B.
Schalten bei Sonnenaufgang und Sonnenuntergang:
-define di_light DOIF ([{sunset(0,"17:00","21:00")}-{sunset_abs()}]) (set outdoorlight off) DOELSE (set outdoorlight on)
+define di_light DOIF ([{sunrise_abs()}-{sunset(1800,"17:00","21:00")}])(set outdoorlight off) DOELSE (set outdoorlight on)
Kombination von Ereignis- und Zeitsteuerung mit logischen Abfragen