Weather control switch for connected day. NXP LPC 1768 module. Ethernet connectivity.
Dependencies: EthernetInterface mbed-rtos mbed nanoservice_client_1_12
Fork of Trenton_Switch_LPC1768_WIFLY by
Diff: Resources/door_trip.cpp
- Revision:
- 26:3467812d5832
- Parent:
- 25:cb16c5248769
diff -r cb16c5248769 -r 3467812d5832 Resources/door_trip.cpp --- a/Resources/door_trip.cpp Wed Dec 03 09:03:29 2014 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,99 +0,0 @@ -// door_trip (from Sharpir) sensor resource implementation - -#include "mbed.h" -#include "nsdl_support.h" -#include "sensor_ctl.h" -//#include "node_cfg.h" - -#include "SHARPIR.h" - -#define DOOR_TRIP_RES_ID "/sen/door/trip" -#define DOOR_TRIP_RES_RT "Door Trip" - - -#if NODE_DOOR_TRIP_STATION -extern bool current_door_trip_value; -static char door_trip_val[2]; -static uint8_t max_age = 0; -static uint8_t content_type = 50; - -static uint8_t obs_number = 0; -static uint8_t *obs_token_ptr = NULL; -static uint8_t obs_token_len = 0; - - -//This is to be called from main program loop... it only sends report if door tripped. -void door_trip_report() { - if(obs_number != 0){ - obs_number++; - snprintf(door_trip_val,2,"%d" ,current_door_trip_value); - if(sn_nsdl_send_observation_notification(obs_token_ptr, obs_token_len, (uint8_t*)door_trip_val, 1, &obs_number, 1, COAP_MSG_TYPE_NON_CONFIRMABLE, 0) == 0) { - printf("Door Trip Observation Sending Failed\r\n"); - } else { - printf("Door Trip Observation Sent\r\n"); - } - } -} - - - -/* Only GET method allowed */ -static uint8_t door_trip_resource_cb(sn_coap_hdr_s *received_coap_ptr, sn_nsdl_addr_s *address, sn_proto_info_s * proto) -{ - sn_coap_hdr_s *coap_res_ptr = 0; - snprintf(door_trip_val,2,"%d" ,current_door_trip_value); - printf("door_trip callback\r\n"); - printf("door_trip: %s\r\n", door_trip_val); - - if(received_coap_ptr->msg_code == COAP_MSG_CODE_REQUEST_GET) - { - coap_res_ptr = sn_coap_build_response(received_coap_ptr, COAP_MSG_CODE_RESPONSE_CONTENT); - - coap_res_ptr->payload_len = strlen(door_trip_val); - coap_res_ptr->payload_ptr = (uint8_t*)door_trip_val; - - coap_res_ptr->content_type_ptr = &content_type; - coap_res_ptr->content_type_len = sizeof(content_type); - - if(received_coap_ptr->token_ptr){ - printf(" Token included\r\n"); - if(obs_token_ptr){ - free(obs_token_ptr); - obs_token_ptr = 0; - } - obs_token_ptr = (uint8_t*)malloc(received_coap_ptr->token_len); - if(obs_token_ptr){ - memcpy(obs_token_ptr, received_coap_ptr->token_ptr, received_coap_ptr->token_len); - obs_token_len = received_coap_ptr->token_len; - } - } - - coap_res_ptr->options_list_ptr = (sn_coap_options_list_s*)nsdl_alloc(sizeof(sn_coap_options_list_s)); - if(!coap_res_ptr->options_list_ptr) - { - printf("cant alloc option list for max-age\r\n"); - coap_res_ptr->options_list_ptr = NULL; //FIXME report error and recover - } - memset(coap_res_ptr->options_list_ptr, 0, sizeof(sn_coap_options_list_s)); - coap_res_ptr->options_list_ptr->max_age_ptr = &max_age; - coap_res_ptr->options_list_ptr->max_age_len = sizeof(max_age); - - sn_nsdl_send_coap_message(address, coap_res_ptr); - nsdl_free(coap_res_ptr->options_list_ptr); - coap_res_ptr->options_list_ptr = NULL; - coap_res_ptr->content_type_ptr = NULL;// parser_release below tries to free this memory - - } - - sn_coap_parser_release_allocated_coap_msg_mem(coap_res_ptr); - - return 0; -} - -int create_door_trip_resource(sn_nsdl_resource_info_s *resource_ptr) -{ - obs_number++; - nsdl_create_dynamic_resource(resource_ptr, sizeof(DOOR_TRIP_RES_ID)-1, (uint8_t*)DOOR_TRIP_RES_ID, sizeof(DOOR_TRIP_RES_RT)-1, (uint8_t*)DOOR_TRIP_RES_RT, 1, &door_trip_resource_cb, (SN_GRS_GET_ALLOWED)); - return 0; -} -#endif