änderungen am Batteriemodul
This commit is contained in:
@@ -28,8 +28,10 @@ class Batterie extends IPSModule
|
|||||||
$this->RegisterVariableInteger("PV_Prio", "PV_Prio");
|
$this->RegisterVariableInteger("PV_Prio", "PV_Prio");
|
||||||
$this->RegisterVariableInteger("Power", "Power");
|
$this->RegisterVariableInteger("Power", "Power");
|
||||||
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
|
$this->RegisterVariableBoolean("Is_Peak_Shaving", "Is_Peak_Shaving");
|
||||||
$this->RegisterVariableBoolean("Hysterese", "Hysterese","",0);
|
//$this->RegisterVariableBoolean("Hysterese", "Hysterese","",0);
|
||||||
$this->RegisterVariableBoolean("Hysterese_Netz", "Hysterese_Netz","",0);
|
//$this->RegisterVariableBoolean("Hysterese_Netz", "Hysterese_Netz","",0);
|
||||||
|
|
||||||
|
$this->RegisterVariableBoolean("Hysterese", "Hysterese","",false);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -151,15 +153,84 @@ public function RequestAction($Ident, $Value)
|
|||||||
|
|
||||||
public function GetCurrentData(bool $Peak)
|
public function GetCurrentData(bool $Peak)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if ($this->ReadPropertyInteger("Batteriemanagement") == 1) {
|
||||||
|
$dummy_array[] = 0;
|
||||||
|
return $this->SetValue("PowerSteps", json_encode($dummy_array));
|
||||||
|
}
|
||||||
|
|
||||||
|
$netzbezug = GetValue($this->ReadPropertyInteger("Netzbezug"));
|
||||||
|
if (abs($netzbezug) > $maxleistung) {
|
||||||
|
$netzbezug = $maxleistung * (-1);
|
||||||
|
}
|
||||||
|
|
||||||
$array_powersteps = $this->GeneratePowerSteps();
|
$array_powersteps = $this->GeneratePowerSteps();
|
||||||
$aufdasnachladen = $this->ReadPropertyInteger("AufdasNachladen");
|
$aufdasnachladen = $this->ReadPropertyInteger("AufdasNachladen");
|
||||||
$minimumentladen = $this->ReadPropertyInteger("MinimumEntladen");
|
$minimumentladen = $this->ReadPropertyInteger("MinimumEntladen");
|
||||||
$maxleistung = $this->ReadPropertyInteger("MaxBatterieleistung");
|
$maxleistung = $this->ReadPropertyInteger("MaxBatterieleistung");
|
||||||
$dummy_array = [];
|
$dummy_array = [];
|
||||||
$inhystere = $this->GetValue("Hysterese");
|
$batterieladezustand = $this->ReadPropertyInteger("Batterieladezustand");
|
||||||
$inhystere_netz = $this->GetValue("Hysterese_Netz");
|
|
||||||
|
|
||||||
$batterieManagement = $this->ReadPropertyInteger("Batteriemanagement");
|
if($batterieladezustand>(5+$aufdasnachladen)){
|
||||||
|
|
||||||
|
$this->SetValue("Hysterese", false);
|
||||||
|
|
||||||
|
}elseif($batterieladezustand<$aufdasnachladen){
|
||||||
|
$this->SetValue("Hysterese", true);
|
||||||
|
}
|
||||||
|
|
||||||
|
$hyst = $this->GetValue("Hysterese");
|
||||||
|
|
||||||
|
if($Peak){
|
||||||
|
|
||||||
|
if($batterieladezustand>=$aufdasnachladen && $hyst==false){
|
||||||
|
|
||||||
|
$dummy_array[] = $netzbezug;
|
||||||
|
$this->SetValue("PowerSteps", json_encode($dummy_array));
|
||||||
|
|
||||||
|
}else if($batterieladezustand>$minimumentladen){
|
||||||
|
|
||||||
|
$this->SetValue("PowerSteps", json_encode($array_powersteps));
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
|
||||||
|
$filtered_powersteps = array_filter($array_powersteps, function ($value) {
|
||||||
|
return $value >= 0;
|
||||||
|
});
|
||||||
|
$this->SetValue("PowerSteps", json_encode(array_values($filtered_powersteps)));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
else{
|
||||||
|
|
||||||
|
if($batterieladezustand>99){
|
||||||
|
|
||||||
|
$filtered_powersteps_entladen = array_filter($array_powersteps, function ($value) {
|
||||||
|
return $value <= 0;
|
||||||
|
});
|
||||||
|
$this->SetValue("PowerSteps", json_encode($filtered_powersteps_entladen));
|
||||||
|
|
||||||
|
}else if($batterieladezustand>=$aufdasnachladen && $hyst==false){
|
||||||
|
|
||||||
|
$this->SetValue("PowerSteps", json_encode($array_powersteps));
|
||||||
|
|
||||||
|
}else{
|
||||||
|
|
||||||
|
$dummy_array[] = $this->ReadPropertyInteger("MaxNachladen");
|
||||||
|
$this->SetValue("PowerSteps", json_encode($dummy_array));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// $inhystere = $this->GetValue("Hysterese");
|
||||||
|
// $inhystere_netz = $this->GetValue("Hysterese_Netz");
|
||||||
|
|
||||||
|
/*$batterieManagement = $this->ReadPropertyInteger("Batteriemanagement");
|
||||||
if ($batterieManagement == 1) {
|
if ($batterieManagement == 1) {
|
||||||
$dummy_array[] = 0;
|
$dummy_array[] = 0;
|
||||||
return $this->SetValue("PowerSteps", json_encode($dummy_array));
|
return $this->SetValue("PowerSteps", json_encode($dummy_array));
|
||||||
@@ -172,7 +243,6 @@ public function RequestAction($Ident, $Value)
|
|||||||
IPS_LogMessage("Batterie", "Fehler: Ungültige Batterieladezustand-ID.");
|
IPS_LogMessage("Batterie", "Fehler: Ungültige Batterieladezustand-ID.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($Peak) {
|
if ($Peak) {
|
||||||
if ($batterieladezustand >= 5 + $aufdasnachladen) {
|
if ($batterieladezustand >= 5 + $aufdasnachladen) {
|
||||||
$this->SetValue("Hysterese", false);
|
$this->SetValue("Hysterese", false);
|
||||||
@@ -268,7 +338,7 @@ public function RequestAction($Ident, $Value)
|
|||||||
$this->SetValue("PowerSteps", json_encode($filtered_powersteps_entladen));
|
$this->SetValue("PowerSteps", json_encode($filtered_powersteps_entladen));
|
||||||
IPS_LogMessage("Batterie", ": Solar über 100%" );
|
IPS_LogMessage("Batterie", ": Solar über 100%" );
|
||||||
}
|
}
|
||||||
}
|
}*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -50,7 +50,6 @@ class HauptManager extends IPSModule
|
|||||||
|
|
||||||
$decodedUser = json_decode(GetValue($user["User_Up"]), true);
|
$decodedUser = json_decode(GetValue($user["User_Up"]), true);
|
||||||
|
|
||||||
|
|
||||||
if (isset($decodedUser["Timestamp"]) && (($currentTime - $decodedUser["Timestamp"])) < 30) {
|
if (isset($decodedUser["Timestamp"]) && (($currentTime - $decodedUser["Timestamp"])) < 30) {
|
||||||
|
|
||||||
foreach ($decodedUser["Users"] as $subuser) {
|
foreach ($decodedUser["Users"] as $subuser) {
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
"compatibility": {
|
"compatibility": {
|
||||||
"version": "7.1"
|
"version": "7.1"
|
||||||
},
|
},
|
||||||
"version": "1.235",
|
"version": "1.236",
|
||||||
"build": 0,
|
"build": 0,
|
||||||
"date": 0
|
"date": 0
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user