
7 changed files with 206 additions and 1 deletions
@ -0,0 +1,78 @@
|
||||
/*
|
||||
* Copyright (C) 2015 Martine Lenders <mlenders@inf.fu-berlin.de> |
||||
* |
||||
* This file is subject to the terms and conditions of the GNU Lesser |
||||
* General Public License v2.1. See the file LICENSE in the top level |
||||
* directory for more details. |
||||
*/ |
||||
|
||||
/**
|
||||
* @defgroup gnrc_ipv6_whitelist Allows to whitelist certain IPv6 source addresses for |
||||
* reception. |
||||
* @ingroup gnrc_ipv6 |
||||
* @brief This allows you to only accept IPv6 addresses that are defined in this list. |
||||
* @{ |
||||
* |
||||
* @file |
||||
* @brief IPv6 whitelist definitions |
||||
* |
||||
* @author Martine Lenders <mlenders@inf.fu-berlin.de> |
||||
*/ |
||||
#ifndef GNRC_IPV6_WHITELIST_H_ |
||||
#define GNRC_IPV6_WHITELIST_H_ |
||||
|
||||
#include <stdbool.h> |
||||
|
||||
#include "net/ipv6/addr.h" |
||||
|
||||
#ifdef __cplusplus |
||||
extern "C" { |
||||
#endif |
||||
|
||||
/**
|
||||
* Maximum size of the whitelist. |
||||
*/ |
||||
#ifndef GNRC_IPV6_WHITELIST_SIZE |
||||
#define GNRC_IPV6_WHITELIST_SIZE (8) |
||||
#endif |
||||
|
||||
/**
|
||||
* @brief Adds an IPv6 address to the whitelist. |
||||
* |
||||
* @param[in] addr An IPv6 address. |
||||
* |
||||
* @return 0, on success. |
||||
* @return -1, if whitelist is full. |
||||
*/ |
||||
int gnrc_ipv6_whitelist_add(const ipv6_addr_t *addr); |
||||
|
||||
/**
|
||||
* @brief Removes an IPv6 address from the whitelist. |
||||
* |
||||
* Addresses not in the whitelist will be ignored. |
||||
* |
||||
* @param[in] addr An IPv6 address. |
||||
*/ |
||||
void gnrc_ipv6_whitelist_del(const ipv6_addr_t *addr); |
||||
|
||||
/**
|
||||
* @brief Checks if an IPv6 address is whitelisted. |
||||
* |
||||
* @param[in] addr An IPv6 address. |
||||
* |
||||
* @return true, if @p addr is whitelisted. |
||||
* @return false, if @p addr is not whitelisted. |
||||
*/ |
||||
bool gnrc_ipv6_whitelisted(const ipv6_addr_t *addr); |
||||
|
||||
/**
|
||||
* @brief Prints the whitelist. |
||||
*/ |
||||
void gnrc_ipv6_whitelist_print(void); |
||||
|
||||
#ifdef __cplusplus |
||||
} |
||||
#endif |
||||
|
||||
#endif /* GNRC_IPV6_WHITELIST_H_ */ |
||||
/** @} */ |
@ -0,0 +1,3 @@
|
||||
MODULE = gnrc_ipv6_whitelist
|
||||
|
||||
include $(RIOTBASE)/Makefile.base |
@ -0,0 +1,67 @@
|
||||
/*
|
||||
* Copyright (C) Freie Universität Berlin |
||||
* |
||||
* This file is subject to the terms and conditions of the GNU Lesser |
||||
* General Public License v2.1. See the file LICENSE in the top level |
||||
* directory for more details. |
||||
*/ |
||||
|
||||
/**
|
||||
* @{ |
||||
* |
||||
* @file |
||||
* @author Martine Lenders <mlenders@inf.fu-berlin.de> |
||||
*/ |
||||
|
||||
#include "bitfield.h" |
||||
|
||||
#include "net/gnrc/ipv6/whitelist.h" |
||||
|
||||
#define ENABLE_DEBUG (0) |
||||
#include "debug.h" |
||||
|
||||
ipv6_addr_t gnrc_ipv6_whitelist[GNRC_IPV6_WHITELIST_SIZE]; |
||||
BITFIELD(gnrc_ipv6_whitelist_set, GNRC_IPV6_WHITELIST_SIZE); |
||||
|
||||
#if ENABLE_DEBUG |
||||
static char addr_str[IPV6_ADDR_MAX_STR_LEN]; |
||||
#endif |
||||
|
||||
int gnrc_ipv6_whitelist_add(const ipv6_addr_t *addr) |
||||
{ |
||||
for (int i = 0; i < GNRC_IPV6_WHITELIST_SIZE; i++) { |
||||
if (!bf_isset(gnrc_ipv6_whitelist_set, i)) { |
||||
bf_set(gnrc_ipv6_whitelist_set, i); |
||||
gnrc_ipv6_whitelist[i].u64[0].u64 = addr->u64[0].u64; |
||||
gnrc_ipv6_whitelist[i].u64[1].u64 = addr->u64[1].u64; |
||||
DEBUG("IPv6 whitelist: whitelisted %s\n", |
||||
ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); |
||||
return 0; |
||||
} |
||||
} |
||||
return -1; |
||||
} |
||||
|
||||
void gnrc_ipv6_whitelist_del(const ipv6_addr_t *addr) |
||||
{ |
||||
for (int i = 0; i < GNRC_IPV6_WHITELIST_SIZE; i++) { |
||||
if (ipv6_addr_equal(addr, &gnrc_ipv6_whitelist[i])) { |
||||
bf_unset(gnrc_ipv6_whitelist_set, i); |
||||
DEBUG("IPv6 whitelist: unwhitelisted %s\n", |
||||
ipv6_addr_to_str(addr_str, addr, sizeof(addr_str))); |
||||
} |
||||
} |
||||
} |
||||
|
||||
bool gnrc_ipv6_whitelisted(const ipv6_addr_t *addr) |
||||
{ |
||||
for (int i = 0; i < GNRC_IPV6_WHITELIST_SIZE; i++) { |
||||
if (bf_isset(gnrc_ipv6_whitelist_set, i) && |
||||
ipv6_addr_equal(addr, &gnrc_ipv6_whitelist[i])) { |
||||
return true; |
||||
} |
||||
} |
||||
return false; |
||||
} |
||||
|
||||
/** @} */ |
@ -0,0 +1,36 @@
|
||||
/*
|
||||
* Copyright (C) Freie Universität Berlin |
||||
* |
||||
* This file is subject to the terms and conditions of the GNU Lesser |
||||
* General Public License v2.1. See the file LICENSE in the top level |
||||
* directory for more details. |
||||
*/ |
||||
|
||||
/**
|
||||
* @{ |
||||
* |
||||
* @file |
||||
* @author Martine Lenders <mlenders@inf.fu-berlin.de> |
||||
*/ |
||||
|
||||
#include <stdio.h> |
||||
|
||||
#include "bitfield.h" |
||||
#include "net/ipv6/addr.h" |
||||
|
||||
#include "net/gnrc/ipv6/whitelist.h" |
||||
|
||||
extern ipv6_addr_t gnrc_ipv6_whitelist[GNRC_IPV6_WHITELIST_SIZE]; |
||||
extern BITFIELD(gnrc_ipv6_whitelist_set, GNRC_IPV6_WHITELIST_SIZE); |
||||
|
||||
void gnrc_ipv6_whitelist_print(void) |
||||
{ |
||||
char addr_str[IPV6_ADDR_MAX_STR_LEN]; |
||||
for (int i = 0; i < GNRC_IPV6_WHITELIST_SIZE; i++) { |
||||
if (bf_isset(gnrc_ipv6_whitelist_set, i)) { |
||||
puts(ipv6_addr_to_str(addr_str, &gnrc_ipv6_whitelist[i], sizeof(addr_str))); |
||||
} |
||||
} |
||||
} |
||||
|
||||
/** @} */ |
Loading…
Reference in new issue