This example show how to manage users inside the whitelist of the BLE module,
Required Materials
1 x Waspmote
1 x Battery
1 x Bluetooth Low Energy module
1 x Bluetooth module antenna
1 x Expansion board (if socket 1 is used)
1 x SD card
Notes
- Socket 0 is used by default
- EEPROM is used in this example by default.
- Never unplug module while Waspmote is turned ON.
- Bluetooth module antenna should be connected.
- The battery must be connected in ANY example.
- This example can be executed in Waspmote v12 and Waspmote v15
Code
/*
* ------------------ [BLE_14] - managing whitelist -------------------
*
* Explanation: This example show how to manage users inside the
* whitelist of the BLE module,
*
* Copyright (C) 2016 Libelium Comunicaciones Distribuidas S.L.
* http://www.libelium.com
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS ARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*
* Version: 1.0
* Design: David Gascón
* Implementation: Javier Siscart
*/
#include <WaspBLE.h>
// Aux variable
uint16_t aux = 0;
// MAC address of a BLE module
char BleMacAddress[13] = "001122334455";
void setup()
{
USB.println(F("BLE_14 Example"));
// 0. Turn BLE module ON
BLE.ON(SOCKET0);
}
void loop()
{
// 1. Add new member.
aux = BLE.whiteListAppend(BleMacAddress);
if (aux == 0)
{
USB.print(BleMacAddress);
USB.println(" member added");
}
else
{
USB.println(F(" Append failed"));
}
// 2. Remove new member
aux = BLE.whiteListRemove(BleMacAddress);
if (aux == 0)
{
USB.print(BleMacAddress);
USB.println(" member removed");
}
else
{
USB.println(F(" Remove failed"));
}
// 3. add new member
aux = BLE.whiteListAppend(BleMacAddress);
if (aux == 0)
{
USB.print(BleMacAddress);
USB.println(" member added");
}
else
{
USB.println(F(" Append failed"));
}
// 4. clear all members
if (BLE.whiteListClear() == 1)
{
USB.println(F("Whitelist is empty"));
}
else
{
USB.println(F("clear failed"));
}
USB.println();
delay(10000);
/* NOTE 1: Do not use this command while advertising, scanning,
or while being connected. The current list is discarded upon
reset or power-cycle.
*/
/* NOTE 2: There is no function to show the current members of
the whitelist.
*/
}
Output
H#
BLE_14 Example
member 001122334455 added
member 001122334455 removed
member 001122334455 added
Whitelist is empty