Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of BLE_API by
Diff: services/URIBeacon2Service.h
- Revision:
- 151:cb5df770f05b
- Parent:
- 150:aa2d70369df0
- Child:
- 152:fc0bb2ba916b
--- a/services/URIBeacon2Service.h Fri Nov 28 14:11:20 2014 +0000 +++ b/services/URIBeacon2Service.h Fri Nov 28 14:11:20 2014 +0000 @@ -22,39 +22,39 @@ class URIBeacon2Service { public: // ee0c2080-8786-40ba-ab96-99b91ac981d8 - URIBeacon2Service(BLEDevice &ble_, const char *urldata) : ble(ble_), payloadIndex(0), payload() { + URIBeacon2Service(BLEDevice &ble_, const char *urldata, uint8_t flags = 0, uint8_t power = 0) : ble(ble_), payloadIndex(0), serviceDataPayload() { const uint8_t BEACON_UUID[] = {0xD8, 0xFE}; - payload[payloadIndex++] = BEACON_UUID[0]; - payload[payloadIndex++] = BEACON_UUID[1]; - payload[payloadIndex++] = 0x00; /* flags */ - payload[payloadIndex++] = 0x20; /* power */ + serviceDataPayload[payloadIndex++] = BEACON_UUID[0]; + serviceDataPayload[payloadIndex++] = BEACON_UUID[1]; + serviceDataPayload[payloadIndex++] = flags; + serviceDataPayload[payloadIndex++] = power; size_t sizeofURLData = strlen(urldata); - size_t encodedBytes = encodeURIData(urldata, sizeofURLData); + size_t encodedBytes = encodeServiceData(urldata, sizeofURLData); ble.accumulateAdvertisingPayload(GapAdvertisingData::COMPLETE_LIST_16BIT_SERVICE_IDS, BEACON_UUID, sizeof(BEACON_UUID)); - ble.accumulateAdvertisingPayload(GapAdvertisingData::SERVICE_DATA, payload, encodedBytes + 4); + ble.accumulateAdvertisingPayload(GapAdvertisingData::SERVICE_DATA, serviceDataPayload, encodedBytes + 4); } - void dumpEncoded() { + void dumpEncodedSeviceData() const { printf("encoded: '"); for (unsigned i = 0; i < payloadIndex; i++) { - printf(" %02x", payload[i]); + printf(" %02x", serviceDataPayload[i]); } printf("'\r\n"); } private: - size_t encodeURIData(const char *urldata, size_t sizeofURLData) { + size_t encodeServiceData(const char *urldata, size_t sizeofURLData) { if (sizeofURLData == 0) { return 0; } - return encodePrefix(urldata, sizeofURLData) + copyURLCheckingForSuffixes(urldata, sizeofURLData); + return encodeURISchemePrefix(urldata, sizeofURLData) + encodeURI(urldata, sizeofURLData); } - size_t encodePrefix(const char *&urldata, size_t &sizeofURLData) { + size_t encodeURISchemePrefix(const char *&urldata, size_t &sizeofURLData) { const char *prefixes[] = { "http://www.", "https://www.", @@ -68,7 +68,7 @@ for (unsigned i = 0; i < NUM_PREFIXES; i++) { size_t prefixLen = strlen(prefixes[i]); if (strncmp(urldata, prefixes[i], prefixLen) == 0) { - payload[payloadIndex++] = i; + serviceDataPayload[payloadIndex++] = i; encodedBytes = 1; urldata += prefixLen; @@ -80,7 +80,7 @@ return encodedBytes; } - size_t copyURLCheckingForSuffixes(const char *urldata, size_t sizeofURLData) { + size_t encodeURI(const char *urldata, size_t sizeofURLData) { const char *suffixes[] = { ".com/", ".org/", @@ -110,7 +110,7 @@ } if (strncmp(urldata, suffixes[i], suffixLen) == 0) { - payload[payloadIndex++] = i; + serviceDataPayload[payloadIndex++] = i; ++encodedBytes; urldata += suffixLen; sizeofURLData -= suffixLen; @@ -119,7 +119,7 @@ } /* This is the default case where we've got an ordinary character which doesn't match a suffix. */ if (i == NUM_SUFFIXES) { - payload[payloadIndex++] = *urldata; + serviceDataPayload[payloadIndex++] = *urldata; ++encodedBytes; ++urldata; --sizeofURLData; @@ -155,7 +155,7 @@ BLEDevice &ble; size_t payloadIndex; - uint8_t payload[MAX_SIZEOF_PAYLOAD]; + uint8_t serviceDataPayload[MAX_SIZEOF_PAYLOAD]; // uint8_t batteryLevel; // GattCharacteristic batteryLevelCharacteristic; };