//The setup function is called once at startup of the sketch void setup() { pinMode(dht11_pin, OUTPUT); digitalWrite(dht11_pin, HIGH); // Add your initialization code here OC_LOG_INIT(); OC_LOG(DEBUG, TAG, PCF("OCServer is starting...")); uint16_t port = OC_WELL_KNOWN_PORT; // Connect to Ethernet or WiFi network if (ConnectToNetwork() != 0) { OC_LOG(ERROR, TAG, "Unable to connect to network"); return; } // Initialize the OC Stack in Server mode if (OCInit(NULL, port, OC_SERVER) != OC_STACK_OK) { OC_LOG(ERROR, TAG, PCF("OCStack init error")); return; } OCStartPresence(60); // Declare and create the example resource: TH createTHResource(); }
OCStackResult InProcServerWrapper::startPresence(const unsigned int seconds) { auto cLock = m_csdkLock.lock(); OCStackResult result = OC_STACK_ERROR; if(cLock) { std::lock_guard<std::recursive_mutex> lock(*cLock); result = OCStartPresence(seconds); } if(result != OC_STACK_OK) { throw OCException(OC::Exception::START_PRESENCE_FAILED, result); } return result; }
//The setup function is called once at startup of the sketch void setup() { Serial.begin(115200); // Add your initialization code here OC_LOG_INIT(); OC_LOG(DEBUG, TAG, PCF("OCServer is starting...")); // uint16_t port = OC_WELL_KNOWN_PORT; // Connect to Ethernet or WiFi network if (ConnectToNetwork() != 0) { OC_LOG(ERROR, TAG, "Unable to connect to network"); return; } // Initialize the OC Stack in Server mode if (OCInit(NULL, OC_WELL_KNOWN_PORT, OC_SERVER) != OC_STACK_OK) { OC_LOG(ERROR, TAG, PCF("OCStack init error")); return; } OCStartPresence(60); // Declare and create the example resource createResource(); // This call displays the amount of free SRAM available on Arduino PrintArduinoMemoryStats(); #if (ARDUINO == 0) ble.init( (long)115200, BLE_MASTER, trackeeID); #elif (ARDUINO == 1) ble.init( (long)115200, BLE_SLAVER, slaveList[0]); #elif (ARDUINO == 2) ble.init( (long)115200, BLE_SLAVER, slaveList[1]); #endif // ble.StatusRead(); OC_LOG_V(INFO, TAG, "Program Start-\r\n"); }
int main() { OIC_LOG(INFO, TAG, "Initializing IoTivity..."); OCStackResult result = OCInit(NULL, 0, OC_SERVER); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "OCInit Failed %d", result); return -1; } result = SetPlatformInfo(); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "SetPlatformInfo Failed %d", result); goto IotivityStop; } result = SetDeviceInfo(); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "SetPlatformInfo Failed: %d", result); goto IotivityStop; } result = OCStartPresence(0); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "OCStartPresence Failed: %d", result); goto IotivityStop; } // PIStartPlugin PIPlugin* plugin = NULL; OIC_LOG(INFO, TAG, "IoTivity Initialized properly, Starting Zigbee Plugin..."); result = PIStartPlugin(defaultComPort, PLUGIN_ZIGBEE, &plugin); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "Zigbee Plugin Start Failed: %d", result); goto IotivityStop; } if (signal(SIGINT, processCancel) == SIG_ERR) { OIC_LOG(ERROR, TAG, "Unable to catch SIGINT, terminating..."); } else { OIC_LOG(INFO, TAG, "Zigbee Plugin started correctly, press Ctrl-C to terminate application"); // Loop until sigint while (!processSignal(false) && result == OC_STACK_OK) { result = OCProcess(); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "OCProcess Failed: %d", result); break; } result = PIProcess(plugin); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "PIProcess Failed: %d", result); } } } OIC_LOG(INFO, TAG, "Stopping Zigbee Plugin..."); result = PIStopPlugin(plugin); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "Zigbee Plugin Stop Failed: %d", result); } OIC_LOG(INFO, TAG, "Zigbee Plugin Stopped"); // OCStop IotivityStop: OIC_LOG(INFO, TAG, "Stopping IoTivity..."); result = OCStop(); if (result != OC_STACK_OK) { OIC_LOG_V(ERROR, TAG, "OCStop Failed: %d", result); return 0; } OIC_LOG(INFO, TAG, "Application Completed Successfully"); return 0; }
int main(int argc, char* argv[]) { uint8_t addr[20] = {0}; uint8_t* paddr = NULL; uint16_t port = OC_WELL_KNOWN_PORT; uint8_t ifname[] = "eth0"; pthread_t threadId; pthread_t threadId_presence; int opt; while ((opt = getopt(argc, argv, "o:")) != -1) { switch(opt) { case 'o': gObserveNotifyType = atoi(optarg); break; default: PrintUsage(); return -1; } } if ((gObserveNotifyType != 0) && (gObserveNotifyType != 1)) { PrintUsage(); return -1; } OC_LOG(DEBUG, TAG, "OCServer is starting..."); /*Get Ip address on defined interface and initialize coap on it with random port number * this port number will be used as a source port in all coap communications*/ if ( OCGetInterfaceAddress(ifname, sizeof(ifname), AF_INET, addr, sizeof(addr)) == ERR_SUCCESS) { OC_LOG_V(INFO, TAG, "Starting ocserver on address %s:%d",addr,port); paddr = addr; } if (OCInit((char *) paddr, port, OC_SERVER) != OC_STACK_OK) { OC_LOG(ERROR, TAG, "OCStack init error"); return 0; } #ifdef WITH_PRESENCE if (OCStartPresence(0) != OC_STACK_OK) { OC_LOG(ERROR, TAG, "OCStack presence/discovery error"); return 0; } #endif OCSetDefaultDeviceEntityHandler(OCDeviceEntityHandlerCb); OCStackResult deviceResult = SetDeviceInfo(contentType, dateOfManufacture, deviceName, deviceUUID, firmwareVersion, hostName, manufacturerName, manufacturerUrl, modelNumber, platformVersion, supportUrl, version); if (deviceResult != OC_STACK_OK) { OC_LOG(INFO, TAG, "Device Registration failed!"); exit (EXIT_FAILURE); } deviceResult = OCSetDeviceInfo(deviceInfo); if (deviceResult != OC_STACK_OK) { OC_LOG(INFO, TAG, "Device Registration failed!"); exit (EXIT_FAILURE); } /* * Declare and create the example resource: Light */ createLightResource(gResourceUri, &Light); // Initialize observations data structure for the resource for (uint8_t i = 0; i < SAMPLE_MAX_NUM_OBSERVATIONS; i++) { interestedObservers[i].valid = false; } /* * Create a thread for changing the representation of the Light */ pthread_create (&threadId, NULL, ChangeLightRepresentation, (void *)NULL); /* * Create a thread for generating changes that cause presence notifications * to be sent to clients */ pthread_create(&threadId_presence, NULL, presenceNotificationGenerator, (void *)NULL); // Break from loop with Ctrl-C OC_LOG(INFO, TAG, "Entering ocserver main loop..."); DeleteDeviceInfo(); signal(SIGINT, handleSigInt); while (!gQuitFlag) { if (OCProcess() != OC_STACK_OK) { OC_LOG(ERROR, TAG, "OCStack process error"); return 0; } sleep(2); } /* * Cancel the Light thread and wait for it to terminate */ pthread_cancel(threadId); pthread_join(threadId, NULL); pthread_cancel(threadId_presence); pthread_join(threadId_presence, NULL); OC_LOG(INFO, TAG, "Exiting ocserver main loop..."); if (OCStop() != OC_STACK_OK) { OC_LOG(ERROR, TAG, "OCStack process error"); } return 0; }
int main(int argc, char* argv[]) { #ifdef RA_ADAPTER char host[] = "localhost"; char user[] = "test1"; char pass[] = "intel123"; char empstr[] = ""; OCRAInfo_t rainfo = {}; rainfo.hostname = host; rainfo.port = 5222; rainfo.xmpp_domain = host; rainfo.username = user; rainfo.password = pass; rainfo.resource = empstr; rainfo.user_jid = empstr; rainfo.jidbound = jidbound; #endif int opt = 0; while ((opt = getopt(argc, argv, "o:s:p:d:u:w:r:j:")) != -1) { switch(opt) { case 'o': gObserveNotifyType = atoi(optarg); break; #ifdef RA_ADAPTER case 's': rainfo.hostname = optarg; break; case 'p': rainfo.port = atoi(optarg); break; case 'd': rainfo.xmpp_domain = optarg; break; case 'u': rainfo.username = optarg; break; case 'w': rainfo.password = optarg; break; case 'j': rainfo.user_jid = optarg; break; case 'r': rainfo.resource = optarg; break; #endif default: PrintUsage(); return -1; } } if ((gObserveNotifyType != 0) && (gObserveNotifyType != 1)) { PrintUsage(); return -1; } #ifdef RA_ADAPTER OCSetRAInfo(&rainfo); #endif OIC_LOG(DEBUG, TAG, "OCServer is starting..."); if (OCInit(NULL, 0, OC_SERVER) != OC_STACK_OK) { OIC_LOG(ERROR, TAG, "OCStack init error"); return 0; } #ifdef WITH_PRESENCE if (OCStartPresence(0) != OC_STACK_OK) { OIC_LOG(ERROR, TAG, "OCStack presence/discovery error"); return 0; } #endif OCSetDefaultDeviceEntityHandler(OCDeviceEntityHandlerCb, NULL); OCStackResult registrationResult = SetPlatformInfo(platformID, manufacturerName, manufacturerUrl, modelNumber, dateOfManufacture, platformVersion, operatingSystemVersion, hardwareVersion, firmwareVersion, supportUrl, systemTime); if (registrationResult != OC_STACK_OK) { OIC_LOG(INFO, TAG, "Platform info setting failed locally!"); exit (EXIT_FAILURE); } registrationResult = OCSetPlatformInfo(platformInfo); if (registrationResult != OC_STACK_OK) { OIC_LOG(INFO, TAG, "Platform Registration failed!"); exit (EXIT_FAILURE); } registrationResult = SetDeviceInfo(deviceName, specVersion, dataModelVersions); if (registrationResult != OC_STACK_OK) { OIC_LOG(INFO, TAG, "Device info setting failed locally!"); exit (EXIT_FAILURE); } OCResourcePayloadAddStringLL(&deviceInfo.types, "oic.d.tv"); registrationResult = OCSetDeviceInfo(deviceInfo); if (registrationResult != OC_STACK_OK) { OIC_LOG(INFO, TAG, "Device Registration failed!"); exit (EXIT_FAILURE); } /* * Declare and create the example resource: Light */ createLightResource(gResourceUri, &Light); // Initialize observations data structure for the resource for (uint8_t i = 0; i < SAMPLE_MAX_NUM_OBSERVATIONS; i++) { interestedObservers[i].valid = false; } /* * Create a thread for generating changes that cause presence notifications * to be sent to clients */ #ifdef WITH_PRESENCE pthread_create(&threadId_presence, NULL, presenceNotificationGenerator, (void *)NULL); #endif // Break from loop with Ctrl-C OIC_LOG(INFO, TAG, "Entering ocserver main loop..."); DeletePlatformInfo(); DeleteDeviceInfo(); signal(SIGINT, handleSigInt); while (!gQuitFlag) { if (OCProcess() != OC_STACK_OK) { OIC_LOG(ERROR, TAG, "OCStack process error"); return 0; } } if (observeThreadStarted) { pthread_cancel(threadId_observe); pthread_join(threadId_observe, NULL); } pthread_cancel(threadId_presence); pthread_join(threadId_presence, NULL); OIC_LOG(INFO, TAG, "Exiting ocserver main loop..."); if (OCStop() != OC_STACK_OK) { OIC_LOG(ERROR, TAG, "OCStack process error"); } return 0; }