def ip_cron(): import json from app.arduino.common import PublicIPInteractor from urllib2 import urlopen ip = PublicIPInteractor.get() currentIP = "%s:%s" % ( json.load(urlopen('http://httpbin.org/ip'))['origin'].rstrip(), settings.PORT ) app.logger.info("---- START IP cron START----") app.logger.info("IP ADDRESS - %s" % currentIP) if ( not ip.address or ip.address != currentIP ): try: for gateway in GatewayInteractor.get_all_device_registered(): r = request_helper.delete_device(gateway.address, gateway.post_authorization) if r != False: app.logger.info("Delete dev: %d" % r.status_code) ip.address = currentIP ip.save() r = request_helper.init_device(gateway.address, gateway.post_authorization) if r != False: app.logger.info("Init dev: %d" % r.status_code) r = request_helper.init_descriptor(gateway.address, gateway.post_authorization) if r != False: app.logger.info("Init descriptor: %d" % r.status_code) r = request_helper.send_descriptor(gateway.address, gateway.post_authorization) if r != False: app.logger.info("Descriptor: %d" % r.status_code) for sensor in SensorInteractor.get_all_active(): for sensor_method in sensor.sensor_methods: r = request_helper.delete_sensor(gateway.address, gateway.post_authorization, sensor.identificator, sensor_method.method.path) if r != False: app.logger.info("Delete sensor method %s: %d" % (sensor_method.method.path, r.status_code)) r = request_helper.init_sensor(gateway.address, gateway.post_authorization, sensor.identificator, sensor_method.method.path) if r != False: app.logger.info("Init sensor method %s: %d" % (sensor_method.method.path, r.status_code)) if sensor_method.method.type in ["read", "write"]: r = request_helper.send_sensor_value(gateway.address, gateway.post_authorization, sensor.identificator, sensor_method.method.path, sensor_method.value) if r != False: app.logger.info("Send method value %s: %d" % (sensor_method.method.path, r.status_code)) log = "%s - %s %s %s - %s (%s)" % ( gateway.address, sensor.module.hardware.name, sensor.module.name, sensor.identificator, sensor_method.method.path, sensor_method.value ) app.logger.info(log) else: ip.address = "" ip.save() else: ip.address = "" ip.save() else: ip.address = "" ip.save() except: app.logger.error( "%s" % sys.exc_info()[0] ) ip.address = "" ip.save() else: app.logger.warning("address wasn't changed") app.logger.info("----END IP cron END----") return make_response()
def remove_device_from_gateway(gateway_id): gateway = GatewayInteractor.get(gateway_id) if gateway: r = request_helper.delete_device(gateway.address, gateway.post_authorization) if r != False: if r.status_code == 204: flash("Device successfully removed from gateway!", category={"theme": "success"}) gateway.device_registered = False gateway.save() elif r.status_code == 404: flash("Device is already removed!", category={"theme": "warning"}) gateway.device_registered = False gateway.save() else: flash("Something went wrong!", category={"theme": "error"}) app.logger.error("Unregistering device: Unknown error during device deletion") else: flash("Gateway does not exist!", category={"theme": "error"}) app.logger.error("Unregistering device: Gateway doesn't exist") return redirect("/")