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
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
UIDFrame.cpp
- Committer:
- andresag
- Date:
- 2015-11-24
- Revision:
- 3:d0f3e00cbfdf
File content as of revision 3:d0f3e00cbfdf:
/* mbed Microcontroller Library * Copyright (c) 2006-2015 ARM Limited * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "UIDFrame.h" UIDFrame::UIDFrame(void) { memset(uidNamespaceID, 0, sizeof(UIDNamespaceID_t)); memset(uidInstanceID, 0, sizeof(UIDInstanceID_t)); } UIDFrame::UIDFrame(const UIDNamespaceID_t uidNamespaceIDIn, const UIDInstanceID_t uidInstanceIDIn) { memcpy(uidNamespaceID, uidNamespaceIDIn, sizeof(UIDNamespaceID_t)); memcpy(uidInstanceID, uidInstanceIDIn, sizeof(UIDInstanceID_t)); } void UIDFrame::setUIDData(const UIDNamespaceID_t *uidNamespaceIDIn, const UIDInstanceID_t *uidInstanceIDIn) { memcpy(uidNamespaceID, uidNamespaceIDIn, sizeof(UIDNamespaceID_t)); memcpy(uidInstanceID, uidInstanceIDIn, sizeof(UIDInstanceID_t)); } void UIDFrame::constructUIDFrame(uint8_t *rawFrame, int8_t advPowerLevel) { size_t index = 0; rawFrame[index++] = EDDYSTONE_UUID[0]; // 16-bit Eddystone UUID rawFrame[index++] = EDDYSTONE_UUID[1]; rawFrame[index++] = FRAME_TYPE_UID; // 1B Type rawFrame[index++] = advPowerLevel; // 1B Power @ 0meter memcpy(rawFrame + index, uidNamespaceID, sizeof(UIDNamespaceID_t)); // 10B Namespace ID index += sizeof(UIDNamespaceID_t); memcpy(rawFrame + index, uidInstanceID, sizeof(UIDInstanceID_t)); // 6B Instance ID index += sizeof(UIDInstanceID_t); memset(rawFrame + index, 0, 2 * sizeof(uint8_t)); // 2B RFU, which are unused } size_t UIDFrame::getRawFrameSize(void) const { return FRAME_SIZE_UID + EDDYSTONE_UUID_SIZE; } uint8_t* UIDFrame::getUIDNamespaceID(void) { return uidNamespaceID; } uint8_t* UIDFrame::getUIDInstanceID(void) { return uidInstanceID; }