develop a smartthings find-compatible device objective learn how to create your own smartthings find-compatible device using smartthings find partnership program device sdk and test suite partnership request the smartthings find partnership program is closed to the public and available only to registered partners who wish to commercialize you can only do this code lab and get the resources after successful partnership to form a partnership, contact partners@smartthings com overview the smartthings find partnership program comprises smartthings find device specification, smartthings find device sdk, test tool, and technical support it facilitates the development of devices operating with smartthings find services and mobile applications the smartthings find device sdk is small enough to work on resource-limited micro-controller unit mcu devices in this code lab, you can learn how to develop your own smartthings find device it is explained in three parts the first explains how you can set up your project in smartthings using developer workspace then, it demonstrates how to build your firmware with smartthings find device sdk the third part shows how to check the functionalities of your device with the smartthings find test suite application set up your environment you will need the following host pc running on windows 11 visual studio code smartthings find device sdk code smartthings find test suite smartthings find mobile application toolchain for nrf52833 dk use the ncs nrf connect sdk version 2 4 0 nrf52833 dk and buzzer module notethis code lab supports other chipsets such as the nrf52840 register and deploy to test your device using developer workspace, you can create a device profile, customize the instructions for onboarding the device on the smartthings mobile app, and test the devices by deploying them you can edit the configurations until you submit the device for publication in the smartthings ecosystem sign in to smartthings developers you need to sign in to smartthings developer workspace using your samsung account select a project and add a device profile select stfind codelab example and check its device profile under the device profile, you can specify whether your device will operate on bluetooth low energy ble only, or will it also support ultra wide band uwb afterward, you can customize your device’s onboarding experience in smartthings by uploading your product images, user instructions, and brand name under device onboarding lastly, you can fill in basic product information in the product info deploy your device to test after you complete all of these, you can go back to the overview tab and press deploy to test you can download the tagonboardingconfig h file which includes your project configuration the sdk code needs this configuration file register test devices you can add the identity of the device in the smartthings cloud for authentication this requires device information like serial number and device public key ed25519 since the maximum number of test device is limited per user, once you have reached it, you should remove the existing one this example shows how to create an ed25519 key pair with sdk tools press the tagkeygen red action button of visual studio code at the bottom by pressing the tagkeygen, you can generate the serial number, private key, and public key register it to the smartthings cloud via the developer workspace and include it in your firmware after checking the created information on visual studio code go to developer workspace again go to test > test devices menu, and click register new device copy and paste the serial number and public key to the popup in developer workspace build the firmware with sdk open visual studio code on the host pc and build the firmware for your device open the sdk project there are two tabs at the primary side bar the first tab is file explorer you can find four code lab files here the second tab is nrf connect in this tab, there are important functions such as build, flash, and serial log check the configuration files ensure that two essential configuration files are applied tagonboardingconfig h tagdeviceinfo h write your code complete the main c code to call the api of device sdk you can find code_mission in the source code you can follow the instructions in the code by simply removing the comments #include <zephyr/zephyr h> #include <zephyr/sys/printk h> #include "tagsdk h" #include "mbedtls/aes h" static void init_aes_table void { mbedtls_aes_context dump_ctx; unsigned char dump_key[16]; mbedtls_aes_setkey_enc &dump_ctx, dump_key, 128 ; } void main void { int err = 0xff; tagresult_t result = tag_result_not_supported; /** * code_mission * you will check this serial log later in this codelab */ printk "tag demo! %s-%s-%s\n", config_board, __date__,__time__ ; init_aes_table ; /** * code_mission * call taginit api by removing comment // * * by calling this api, tag sdk will load nv, set rtc and * initialize crypto, and so on * you shall initialize bsp before call this api * services and starts ble advertising */ // result = taginit ; if result != tag_result_success { printk "failed to init %d\n", result ; return; } err = bt_enable 0 ; if err { printk "failed to init bt %d\n", err ; return; } /** * code_mission * call tagstart api by removing comment // * * by calling this api, tag sdk will initialize ble gatt * db and services and starts ble advertising * you shall initialize ble stack before call this api */ // result = tagstart ; if result != tag_result_success { printk "failed to start maintask %d\n", result ; return; } } complete the portbuzzercontrol c code to call the api of device sdk you can find code_mission in the source code follow the instructions in the code by simply removing the comments tagerror_t portbuzzerhwctrlsetvolume soundvolume_t volume { switch volume { case sound_volume_mute /** * code_mission * set currentvolume and call mute function * by removing comments // below */ // currentvolume = pwm_duty_for_mute; // portbuzzerhwctrlmute ; break; case sound_volume_normal /** * code_mission * set currentvolume and call unmute function * by removing comments // below */ // currentvolume = pwm_duty_for_normal; // buzzerhwctrlunmute ; break; case sound_volume_loud /** * code_mission * set currentvolume and call unmute function * by removing comments // below */ // currentvolume = pwm_duty_for_loud; // buzzerhwctrlunmute ; break; default tag_log_e "error volume level value!" ; return tag_error_invalid_arg; } return tag_error_none; build to build, you need to select the nrf connect tab go into actions press build it takes some time for the build to finish by checking the popup at the bottom right corner of the ide, you can see the progress you can also select nrf connect build in the terminal to check the detailed status flash to flash, you need to connect the nrf52833 dk to the host pc select the nrf connect tab go into actions press flash once completed, you can hear a notification sound from the device check the serial log of the device here, to check the serial log, you have to select the nrf connect tab go to connected devices press vcom0 comxx click the plug icon on the right the list will be shown at the top of visual studio code select the first item under connected devices press the reset button briefly on the device by checking the timestamp from the serial log, you can verify whether the device successfully downloaded the firmware create a device configuration file for the test suite you have now completed creating a device with the sdk to test this device with the test suite, a device configuration file is needed click the testsuite config green action button here, you can see the location where the csv file was created go to the file location and copy the csv file to your mobile device internal storage > downloads test via smartthings find test suite app smartthings find test suite allows you to check and test each function and log the results load the device configuration file to load csv file, you have to launch the test suite app on the mobile device press upload file to load the device configuration file select the csv file you copied from the host pc you can now see the loaded project out of box state advertisement once you load the device configuration file, you can start testing items listed by category press out of box state advertisement press start test once completed, press next test group to go to the next test onboarding onboarding is the process of creating a secure communication channel between the app and the device, as well as registering the device information in smartthings find test suite to do this, you need to press start test once completed, press next test group to go to the next test other states advertisement to test this press start test make sure all items listed have a check mark beside them once completed, press next test group to go to the next test authentication to test this press start test make sure all items listed have a check mark beside them once completed, press next test group to go to the next test ringtone status to test this press read ringtone status once completed, press ringtone on check if there's a ringtone sound from the device press ringtone off check if the ringtone sound stops once completed, press write ringtone invalid value then, press next test group to go to the next test factory reset to test this press factory reset wrong value once completed, press factory reset then, the device should beep press finish test export test report test reports can be exported as a file either during the test or when the test is completed click the export icon at the top right of the screen press ok to continue onboard and control the device via smartthings app onboarding to onboard the device, you need to launch the smartthings app press + icon at the top right of the screen click on add device press add in the partner devices section select my testing devices then, select stfind codelab example to start onboarding allow use of location information and press agree verify your device by pressing the button on the board after verifying, a success! page shows up then, press done to finish ring the device and view it on a map here, you can view the location of the find-compatible device and send a command to ring it press view map to view the device on a map select ring and the device should produce a sound through its buzzer module you may switch to either high volume or low volume ringing press stop to stop the ringing you're done! congratulations! you have successfully achieved the goal of this code lab topic now, you can develop your own smartthings find-compatible devices to form a partnership, contact partners@smartthings com