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 __UIDFRAME_H__
andresag 6:321047f0190a 18 #define __UIDFRAME_H__
andresag 6:321047f0190a 19
andresag 6:321047f0190a 20 #include <string.h>
andresag 6:321047f0190a 21 #include "EddystoneTypes.h"
andresag 6:321047f0190a 22
andresag 6:321047f0190a 23 class UIDFrame
andresag 6:321047f0190a 24 {
andresag 6:321047f0190a 25 public:
andresag 6:321047f0190a 26 UIDFrame(void);
andresag 6:321047f0190a 27
andresag 6:321047f0190a 28 UIDFrame(const UIDNamespaceID_t uidNamespaceIDIn, const UIDInstanceID_t uidInstanceIDIn);
andresag 6:321047f0190a 29
andresag 6:321047f0190a 30 void setUIDData(const UIDNamespaceID_t *uidNamespaceIDIn, const UIDInstanceID_t *uidInstanceIDIn);
andresag 6:321047f0190a 31
andresag 6:321047f0190a 32 void constructUIDFrame(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* getUIDNamespaceID(void);
andresag 6:321047f0190a 37
andresag 6:321047f0190a 38 uint8_t* getUIDInstanceID(void);
andresag 6:321047f0190a 39
andresag 6:321047f0190a 40 private:
andresag 6:321047f0190a 41 static const uint8_t FRAME_TYPE_UID = 0x00;
andresag 6:321047f0190a 42 static const uint8_t FRAME_SIZE_UID = 20;
andresag 6:321047f0190a 43
andresag 6:321047f0190a 44 UIDNamespaceID_t uidNamespaceID;
andresag 6:321047f0190a 45 UIDInstanceID_t uidInstanceID;
andresag 6:321047f0190a 46 };
andresag 6:321047f0190a 47
andresag 6:321047f0190a 48 #endif /* __UIDFRAME_H__ */