Added an EddystoneURLConfigService in addition to UriBeaconConfigService. Updated README and converted comments that used UriBeacon to EddystoneURL in the EddystoneService.h
Dependents: mbed_EddystoneURL_Beacon_ssci mbed_EddystoneURL_Beacon_ssci mbed_EddystoneURL_Beacon_ssci
Fork of BLE_API by
Revision 797:13164356b568, committed 2015-08-19
- Comitter:
- roywant
- Date:
- Wed Aug 19 04:27:52 2015 +0000
- Parent:
- 796:fc73c1ddcd09
- Commit message:
- Updated EddystoneURLConfigService.h : 1) lockedState now is a member of params.lockedState ; zeros are not the unlock value (and a valid key), this now passes the Validator, 2) After disconnect the timeADV is disabled, and ADV params recreated.
Changed in this revision
diff -r fc73c1ddcd09 -r 13164356b568 ble/services/EddystoneURLConfigService.h --- a/ble/services/EddystoneURLConfigService.h Tue Aug 18 00:29:03 2015 +0000 +++ b/ble/services/EddystoneURLConfigService.h Wed Aug 19 04:27:52 2015 +0000 @@ -31,7 +31,7 @@ extern const uint8_t UUID_BEACON_PERIOD_CHAR[UUID::LENGTH_OF_LONG_UUID]; extern const uint8_t UUID_RESET_CHAR[UUID::LENGTH_OF_LONG_UUID]; -extern const uint8_t BEACON_UUID[sizeof(UUID::ShortUUIDBytes_t)]; +extern const uint8_t EDDYSTONE_BEACON_UUID[sizeof(UUID::ShortUUIDBytes_t)]; /** * @class EddystoneURLConfigService @@ -60,6 +60,7 @@ typedef uint8_t UriData_t[URI_DATA_MAX]; struct Params_t { + uint8_t lockedState; Lock_t lock; uint8_t uriDataLength; UriData_t uriData; @@ -97,7 +98,7 @@ defaultAdvPowerLevels(defaultAdvPowerLevelsIn), initSucceeded(false), resetFlag(), - lockedStateChar(UUID_LOCK_STATE_CHAR, &lockedState), + lockedStateChar(UUID_LOCK_STATE_CHAR, ¶ms.lockedState), lockChar(UUID_LOCK_CHAR, ¶ms.lock), uriDataChar(UUID_URI_DATA_CHAR, params.uriData, 0, URI_DATA_MAX, GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_READ | GattCharacteristic::BLE_GATT_CHAR_PROPERTIES_WRITE), @@ -122,8 +123,6 @@ updateCharacteristicValues(); } - lockedState = isLocked(); - lockChar.setWriteAuthorizationCallback(this, &EddystoneURLConfigService::lockAuthorizationCallback); unlockChar.setWriteAuthorizationCallback(this, &EddystoneURLConfigService::unlockAuthorizationCallback); uriDataChar.setWriteAuthorizationCallback(this, &EddystoneURLConfigService::uriDataWriteAuthorizationCallback); @@ -204,12 +203,12 @@ ble.gap().setAdvertisingType(GapAdvertisingParams::ADV_NON_CONNECTABLE_UNDIRECTED); ble.gap().setAdvertisingInterval(beaconPeriod); ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::BREDR_NOT_SUPPORTED | GapAdvertisingData::LE_GENERAL_DISCOVERABLE); - ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS, BEACON_UUID, sizeof(BEACON_UUID)); + ble.gap().accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS, EDDYSTONE_BEACON_UUID, sizeof(EDDYSTONE_BEACON_UUID)); uint8_t serviceData[SERVICE_DATA_MAX]; unsigned serviceDataLen = 0; - serviceData[serviceDataLen++] = BEACON_UUID[0]; - serviceData[serviceDataLen++] = BEACON_UUID[1]; + serviceData[serviceDataLen++] = EDDYSTONE_BEACON_UUID[0]; + serviceData[serviceDataLen++] = EDDYSTONE_BEACON_UUID[1]; serviceData[serviceDataLen++] = flags; serviceData[serviceDataLen++] = advPowerLevels[txPowerMode]; for (unsigned j = 0; j < uriDataLength; j++) { @@ -219,13 +218,6 @@ } private: - // True if the lock bits are non-zero - bool isLocked() { - Lock_t testLock; - memset(testLock, 0, sizeof(Lock_t)); - return memcmp(params.lock, testLock, sizeof(Lock_t)); - } - /* * This callback is invoked when a GATT client attempts to modify any of the * characteristics of this service. Attempts to do so are also applied to @@ -238,11 +230,11 @@ // Validated earlier memcpy(params.lock, writeParams->data, sizeof(Lock_t)); // use isLocked() in case bits are being set to all 0's - lockedState = isLocked(); + params.lockedState = true; } else if (handle == unlockChar.getValueHandle()) { // Validated earlier memset(params.lock, 0, sizeof(Lock_t)); - lockedState = false; + params.lockedState = false; } else if (handle == uriDataChar.getValueHandle()) { params.uriDataLength = writeParams->len; memcpy(params.uriData, writeParams->data, params.uriDataLength); @@ -278,7 +270,7 @@ * Reset the default values. */ void resetToDefaults(void) { - lockedState = false; + params.lockedState = false; memset(params.lock, 0, sizeof(Lock_t)); memcpy(params.uriData, defaultUriData, URI_DATA_MAX); params.uriDataLength = defaultUriDataLength; @@ -294,7 +286,7 @@ * change to the internal state of the service object. */ void updateCharacteristicValues(void) { - ble.gattServer().write(lockedStateChar.getValueHandle(), &lockedState, 1); + ble.gattServer().write(lockedStateChar.getValueHandle(), ¶ms.lockedState, 1); ble.gattServer().write(uriDataChar.getValueHandle(), params.uriData, params.uriDataLength); ble.gattServer().write(flagsChar.getValueHandle(), ¶ms.flags, 1); ble.gattServer().write(beaconPeriodChar.getValueHandle(), @@ -306,7 +298,7 @@ protected: void lockAuthorizationCallback(GattWriteAuthCallbackParams *authParams) { - if (lockedState) { + if (params.lockedState) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INSUF_AUTHORIZATION; } else if (authParams->len != sizeof(Lock_t)) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INVALID_ATT_VAL_LENGTH; @@ -319,7 +311,7 @@ void unlockAuthorizationCallback(GattWriteAuthCallbackParams *authParams) { - if (!lockedState) { + if ((!params.lockedState) && (authParams->len == sizeof(Lock_t))) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_SUCCESS; } else if (authParams->len != sizeof(Lock_t)) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INVALID_ATT_VAL_LENGTH; @@ -333,7 +325,7 @@ } void uriDataWriteAuthorizationCallback(GattWriteAuthCallbackParams *authParams) { - if (lockedState) { + if (params.lockedState) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INSUF_AUTHORIZATION; } else if (authParams->offset != 0) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INVALID_OFFSET; @@ -343,7 +335,7 @@ } void powerModeAuthorizationCallback(GattWriteAuthCallbackParams *authParams) { - if (lockedState) { + if (params.lockedState) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INSUF_AUTHORIZATION; } else if (authParams->len != sizeof(uint8_t)) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INVALID_ATT_VAL_LENGTH; @@ -358,7 +350,7 @@ template <typename T> void basicAuthorizationCallback(GattWriteAuthCallbackParams *authParams) { - if (lockedState) { + if (params.lockedState) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INSUF_AUTHORIZATION; } else if (authParams->len != sizeof(T)) { authParams->authorizationReply = AUTH_CALLBACK_REPLY_ATTERR_INVALID_ATT_VAL_LENGTH; @@ -377,7 +369,6 @@ UriData_t defaultUriData; // Default value that is restored on reset PowerLevels_t &defaultAdvPowerLevels; // Default value that is restored on reset - uint8_t lockedState; bool initSucceeded; uint8_t resetFlag;
diff -r fc73c1ddcd09 -r 13164356b568 source/services/EddystoneURLConfigService.cpp --- a/source/services/EddystoneURLConfigService.cpp Tue Aug 18 00:29:03 2015 +0000 +++ b/source/services/EddystoneURLConfigService.cpp Wed Aug 19 04:27:52 2015 +0000 @@ -33,6 +33,5 @@ const uint8_t UUID_TX_POWER_MODE_CHAR[UUID::LENGTH_OF_LONG_UUID] = UUID_URI_BEACON(0x20, 0x87); const uint8_t UUID_BEACON_PERIOD_CHAR[UUID::LENGTH_OF_LONG_UUID] = UUID_URI_BEACON(0x20, 0x88); const uint8_t UUID_RESET_CHAR[UUID::LENGTH_OF_LONG_UUID] = UUID_URI_BEACON(0x20, 0x89); - -const uint8_t BEACON_UUID[sizeof(UUID::ShortUUIDBytes_t)] = {0xAA, 0xFE}; -*/ \ No newline at end of file +*/ +const uint8_t EDDYSTONE_BEACON_UUID[sizeof(UUID::ShortUUIDBytes_t)] = {0xAA, 0xFE};