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[]) { #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; }