Added retrying mechanism
This commit is contained in:
parent
94b3cc143f
commit
7a0758f883
@ -121,10 +121,11 @@
|
|||||||
## 0.7.3
|
## 0.7.3
|
||||||
* Fixed warnings since homebridge 1.3.0
|
* Fixed warnings since homebridge 1.3.0
|
||||||
|
|
||||||
## 1.0.0-beta.1
|
## 1.0.0-beta.4
|
||||||
* Added bin full sensor
|
* Added bin full sensor
|
||||||
* Added config-ui support for all options
|
* Added config-ui support for all options
|
||||||
* Added config parameter **prefix** to use robot name as prefix for service names
|
* Added config parameter **prefix** to use robot name as prefix for service names
|
||||||
|
* Retrying mechanism if a robot is not available on homebridge launch
|
||||||
* Changed service names to not include robot name as prefix by default
|
* Changed service names to not include robot name as prefix by default
|
||||||
* Changed background update to use better default intervals (1 minute while cleaning, 30 minutes while idle)
|
* Changed background update to use better default intervals (1 minute while cleaning, 30 minutes while idle)
|
||||||
* Changed config parameter **refresh**. Renamed to **backgroundUpdate**, unit changed to minute and will only be used during idle
|
* Changed config parameter **refresh**. Renamed to **backgroundUpdate**, unit changed to minute and will only be used during idle
|
||||||
@ -135,5 +136,4 @@
|
|||||||
|
|
||||||
## TODO until 1.0.0 release
|
## TODO until 1.0.0 release
|
||||||
* Room cleaning
|
* Room cleaning
|
||||||
* Spot size
|
* Spot size
|
||||||
* Retrying when no connection
|
|
2
package-lock.json
generated
2
package-lock.json
generated
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "homebridge-neato",
|
"name": "homebridge-neato",
|
||||||
"version": "1.0.0-beta.1",
|
"version": "1.0.0-beta.2",
|
||||||
"lockfileVersion": 1,
|
"lockfileVersion": 1,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "homebridge-neato",
|
"name": "homebridge-neato",
|
||||||
"displayName": "Homebridge Neato",
|
"displayName": "Homebridge Neato",
|
||||||
"version": "1.0.0-beta.3",
|
"version": "1.0.0-beta.4",
|
||||||
"description": "A Neato vacuum robot plugin for homebridge.",
|
"description": "A Neato vacuum robot plugin for homebridge.",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
@ -67,6 +67,8 @@ export class NeatoVacuumRobotAccessory
|
|||||||
|
|
||||||
// Identify
|
// Identify
|
||||||
this.accessory.on(PlatformAccessoryEvent.IDENTIFY, () => {
|
this.accessory.on(PlatformAccessoryEvent.IDENTIFY, () => {
|
||||||
|
this.robot.findMe();
|
||||||
|
|
||||||
this.robot.getState((error, result) => {
|
this.robot.getState((error, result) => {
|
||||||
this.log.info("[" + this.robot.name + "] Identified");
|
this.log.info("[" + this.robot.name + "] Identified");
|
||||||
if (error)
|
if (error)
|
||||||
@ -329,7 +331,7 @@ export class NeatoVacuumRobotAccessory
|
|||||||
{
|
{
|
||||||
this.goToDockService.updateCharacteristic(this.platform.Characteristic.On, false);
|
this.goToDockService.updateCharacteristic(this.platform.Characteristic.On, false);
|
||||||
}
|
}
|
||||||
}, 1000);
|
}, 10000);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -36,10 +36,11 @@ export class HomebridgeNeatoPlatform implements DynamicPlatformPlugin
|
|||||||
this.cachedRobotAccessories.push(accessory);
|
this.cachedRobotAccessories.push(accessory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
discoverRobots()
|
discoverRobots()
|
||||||
{
|
{
|
||||||
const client = new NeatoApi.Client();
|
const client = new NeatoApi.Client();
|
||||||
|
this.log.debug("blub");
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
@ -47,9 +48,12 @@ export class HomebridgeNeatoPlatform implements DynamicPlatformPlugin
|
|||||||
client.authorize((this.config)["email"], (this.config)["password"], false, (error) => {
|
client.authorize((this.config)["email"], (this.config)["password"], false, (error) => {
|
||||||
if (error)
|
if (error)
|
||||||
{
|
{
|
||||||
this.log.warn("Cannot connect to neato server. No new robots will be found and existing robots will be unresponsive.");
|
this.log.error("Cannot connect to neato server. No new robots will be found and existing robots will be unresponsive. Retrying in 5 minutes.");
|
||||||
this.log.warn(error);
|
this.log.error("Error: " + error);
|
||||||
// TODO retry after x min
|
|
||||||
|
setTimeout(() => {
|
||||||
|
this.discoverRobots();
|
||||||
|
}, 5 * 60 * 1000);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -57,8 +61,12 @@ export class HomebridgeNeatoPlatform implements DynamicPlatformPlugin
|
|||||||
client.getRobots((error, robots) => {
|
client.getRobots((error, robots) => {
|
||||||
if (error)
|
if (error)
|
||||||
{
|
{
|
||||||
this.log.error("Successful login but can't list your neato robots. Error: " + error);
|
this.log.error("Successful login but can't list the robots in your neato robots. Retrying in 5 minutes.");
|
||||||
// TODO retry after x min
|
this.log.error("Error: " + error);
|
||||||
|
|
||||||
|
setTimeout(() => {
|
||||||
|
this.discoverRobots();
|
||||||
|
}, 5 * 60 * 1000);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -107,7 +115,11 @@ export class HomebridgeNeatoPlatform implements DynamicPlatformPlugin
|
|||||||
robot.getState((error, state) => {
|
robot.getState((error, state) => {
|
||||||
if (error)
|
if (error)
|
||||||
{
|
{
|
||||||
this.log.error("[" + robot.name + "] Cannot connect to robot. Is the robot connected to the internet? Error: " + error + ". State: " + state);
|
this.log.error("[" + robot.name + "] Cannot connect to robot. Is the robot connected to the internet? Retrying in 5 minutes.");
|
||||||
|
this.log.error("Error: " + error);
|
||||||
|
setTimeout(() => {
|
||||||
|
this.discoverRobots();
|
||||||
|
}, 5 * 60 * 1000);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user