The eddystone config service allows you to configure the eddystone frame data over BLE for a set period of time and then starts an eddystone beacon. This example defaults to 30 seconds of config time.

Dependencies:   BLE_API mbed nRF51822 X_NUCLEO_IDB0XA1

Fork of BLE_EddystoneBeaconConfigServiceRelease by Austin Blackstone

This is the eddystone config service. This code starts up and for a user configured time period (default 30 seconds) will advertise the configuration service.

The configuration service allows for modifying various frames of the eddystone specification.

For more details on the Configuration Service please see : https://github.com/google/eddystone/blob/master/eddystone-url/docs/config-service-spec.md

Committer:
Vincent Coubard
Date:
Tue Sep 20 14:21:04 2016 +0100
Revision:
8:f53d48e5d64f
Parent:
6:321047f0190a
Update libraries and add support of ST shield.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
andresag 6:321047f0190a 1 /* mbed Microcontroller Library
andresag 6:321047f0190a 2 * Copyright (c) 2006-2015 ARM Limited
andresag 6:321047f0190a 3 *
andresag 6:321047f0190a 4 * Licensed under the Apache License, Version 2.0 (the "License");
andresag 6:321047f0190a 5 * you may not use this file except in compliance with the License.
andresag 6:321047f0190a 6 * You may obtain a copy of the License at
andresag 6:321047f0190a 7 *
andresag 6:321047f0190a 8 * http://www.apache.org/licenses/LICENSE-2.0
andresag 6:321047f0190a 9 *
andresag 6:321047f0190a 10 * Unless required by applicable law or agreed to in writing, software
andresag 6:321047f0190a 11 * distributed under the License is distributed on an "AS IS" BASIS,
andresag 6:321047f0190a 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
andresag 6:321047f0190a 13 * See the License for the specific language governing permissions and
andresag 6:321047f0190a 14 * limitations under the License.
andresag 6:321047f0190a 15 */
andresag 6:321047f0190a 16
andresag 6:321047f0190a 17 #ifndef __URLFRAME_H__
andresag 6:321047f0190a 18 #define __URLFRAME_H__
andresag 6:321047f0190a 19
andresag 6:321047f0190a 20 #include "EddystoneTypes.h"
andresag 6:321047f0190a 21 #include <string.h>
andresag 6:321047f0190a 22
andresag 6:321047f0190a 23 class URLFrame
andresag 6:321047f0190a 24 {
andresag 6:321047f0190a 25 public:
andresag 6:321047f0190a 26 URLFrame(void);
andresag 6:321047f0190a 27
andresag 6:321047f0190a 28 URLFrame(const char *urlDataIn);
andresag 6:321047f0190a 29
andresag 6:321047f0190a 30 URLFrame(UrlData_t urlDataIn, uint8_t urlDataLength);
andresag 6:321047f0190a 31
andresag 6:321047f0190a 32 void constructURLFrame(uint8_t* rawFrame, int8_t advPowerLevel);
andresag 6:321047f0190a 33
andresag 6:321047f0190a 34 size_t getRawFrameSize(void) const;
andresag 6:321047f0190a 35
andresag 6:321047f0190a 36 uint8_t* getEncodedURLData(void);
andresag 6:321047f0190a 37
andresag 6:321047f0190a 38 uint8_t getEncodedURLDataLength(void) const;
andresag 6:321047f0190a 39
andresag 6:321047f0190a 40 void setURLData(const char *urlDataIn);
andresag 6:321047f0190a 41
andresag 6:321047f0190a 42 void setEncodedURLData(const uint8_t* urlEncodedDataIn, const uint8_t urlEncodedDataLengthIn);
andresag 6:321047f0190a 43
andresag 6:321047f0190a 44 private:
andresag 6:321047f0190a 45 void encodeURL(const char *urlDataIn);
andresag 6:321047f0190a 46
andresag 6:321047f0190a 47 static const uint8_t FRAME_TYPE_URL = 0x10;
andresag 6:321047f0190a 48 /* Even if the URL is 0 bytes we still need to include the type and txPower i.e. 2 bytes */
andresag 6:321047f0190a 49 static const uint8_t FRAME_MIN_SIZE_URL = 2;
andresag 6:321047f0190a 50
andresag 6:321047f0190a 51 uint8_t urlDataLength;
andresag 6:321047f0190a 52 UrlData_t urlData;
andresag 6:321047f0190a 53
andresag 6:321047f0190a 54 };
andresag 6:321047f0190a 55
andresag 6:321047f0190a 56 #endif /* __URLFRAME_H__ */