The present invention relates to a method for operating a node in a network, in particular in a wireless sensor network.
This invention is, for example, relevant for Zigbee networks, or for sensor networks being ad hoc networks and where the nodes are usually resource constrained.
Wireless sensor networks (WSNs) may comprise thousands of resource-constrained (energy, CPU, etc) sensors and actuators communicating through wireless links. Routing protocols are used to exchange information between a number of nodes. Security protocols are used to bootstrap security and ensure basic security services.
ZigBee, ZigBee IP and 6LoWPAN networks are examples of such WSNs. ZigBee uses an AODV (Ad hoc On demand Distance Vector)-based routing protocol and a centralized security architecture for the distribution of keys. Indeed, in a Zigbee network, a Trust Center may distribute the encryption keys to be used in the network. 6LoWPAN runs on the top of IEEE 802.15.4 IPv6 complaint protocols for routing. In this context, the management of the addresses needed for neighbour discovery, route discovery etc., is cumbersome. The use of traditional security primitives is unfeasible on resource-constrained devices regarding the security architecture.
A first problem in such networks refers to the non-secure neighbour discovery and routing protocol. In an exemplary network 100 illustrated on
A second issue is sensor networks such as ZigBee refers to the protocol overhead for routing and security. In a traditional scenario illustrated on
It is an object of the invention to propose a method for operating a network offering a secure mechanism for the nodes joining the network.
It is another object of the invention to propose a method for operating a network with a route discovery which is efficient but secure.
It is still another object of the present invention to alleviate some of the above problems.
This invention addresses a number of issues related to security and routing in wireless sensor networks whose main goal is to improve the performance (energy consumption) and system operation (latency, delays, security) by means of cross-layer optimization techniques between routing and security.
To this end, in accordance with a first aspect of the invention, a method is proposed for operating a first node in a network, the network including a plurality of nodes, the method comprising
In accordance with a second aspect of the invention, a method is proposed for operating a network, the network including a plurality of nodes, the method comprising
(a) a first node, having a first identifier, joining the network by transmitting the first identifier to a second node having a second identifier,
(b1) the first node generating a first key on the basis of the second identifier,
(b2) the second node generating a second key on the basis of the first identifier,
(c) the second node authenticating the first node by means of the second key,
(d) the first node communicating with a third node if the first and second keys are equal.
In accordance with a third aspect of the invention, independent or in combination of the first and second aspects of the invention, a method is proposed for operating a network, the network including a plurality of nodes, the method comprising (c′) the first node discovering a route to the third node,
wherein the third node comprises a third identifier, wherein the network is a multihop network and wherein step (c′) comprises
(c′1) the first node transmitting to first neighboring nodes in the vicinity of the first node a route request for discovering a route to the third node, the route request including the address of the third node and an encrypted first route verification message, the encrypted first route verification message being encrypted with a third key generated by the first node on the basis of the third identifier.
In accordance with a fourth aspect of the invention, it is proposed a node having a first identifier and comprising a transceiver for communicating in a network,
the transceiver being adapted for joining the network by transmitting the first identifier to a second node having a second identifier,
for receiving an authentication message encrypted with a second key generated by the second node on the basis of the first identifier,
the node further comprising a key generator adapted for generating a first key on the basis of the second identifier
and control means for comparing the first and the second keys with the authentication message,
the transceiver being adapted for communicating with a third node if the first and second keys are equal.
As a consequence, the two main advantages of this approach are secure neighbour discovery, energy-system operation as no-messages are needed to be exchanged for key agreement, and a simplified addressing scheme that reduces the amount of information to be stored, processed, and exchanged.
These and other aspects of the invention will be apparent from and will be elucidated with reference to the embodiments described hereinafter.
The present invention will now be described in more detail, by way of example, with reference to the accompanying drawings, wherein:
This invention describes a cross-layer optimization between security and routing protocols to overcome above drawbacks. The main idea relies on the use of an ID-based cryptography scheme for key agreement, and the use of the routing addresses as crypto identifiers.
ID-based cryptography allows for key agreement and/or authentication based on some keying material and the identifier assigned to a node. In this description, the main approach uses an ID-based cryptosystem based on polynomials. It is to be noted that there are also other types of ID-based cryptosystems based on, e.g., public-key cryptography or other key generators using the routing address as a seed.
In a conventional system as those described in relation with
As shown on
As a consequence, it is proposed in a first embodiment to reduce the risk of attack.
Similarly, the node A may send an authentication message to one or all nodes that replied to the discovery. This authentication message is encrypted with a key based on the respective identifier of node B and node X. Here the node A uses its keying material. This keying material may be present in the node A in accordance with several possibilities or obtained from a trust center in the network.
It might be that in a previous work the node A already has the keying material when it joins the network. It is also possible that the system configuration is such that the nodes are configured with keying material. This might happen offline or online. It is also possible, after node deployment, that the system operates in a secure manner as described in the below embodiments. It is also possible that the network nodes are configured without any keying material. Then, the network nodes are deployed and the system starts operating. The nodes form a non-secure network at time zero. During this first configuration step, the nodes receive keying material from the network coordinator. The keying material is linked to a crypto-identifier as described in the below embodiment. Eventually, normal system operation during which the network operates in a secure manner as described in the below embodiment.
This first embodiment is represented on
In order A to be able to verify that node B is actually its neighbor with high accuracy and that the node is not located further away, node A requires the handshake to occur within a period of time T where T is the reference time to carry the authentication handshake. In this way, an attacker acting as relay between two honest nodes would introduce a delay D so that the overall handshake time will be T+D, and he would, therefore, fail in his attempt of subverting the network operation.
This step comprises node A broadcasting (i.e. transmitting to any neighboring nodes in its vicinity) a route request for discovering a route to the node E. The route request includes the Identifier or the address of the node E. Moreover, as will be explained in further details in another embodiment of the invention, the route request may comprise a message encrypted with a key generated by the node A on the basis of the identifier of node E. This message may be the mere route request codeword, or any other convenient codeword, as soon as it is known from each party.
From this, it is clear that the exchanges are secure really early in the process, especially when compared with the method represented on
It is also possible to have the following variations.
In accordance with another embodiment of the invention, it will be examined how the route discovery can be made more secure. Cross-layer optimization is a key feature for distributed wireless sensor networks as it allows reducing the overall resource-requirements and offering new capabilities.
As a reactive ad hoc routing protocol in a conventional network, DYMO includes two protocol operations: route discovery and route maintenance. Routes are discovered on-demand when a node needs to send a packet to a destination currently not in its routing table. A route request message is flooded in the network using broadcast and if the packet reaches its destination, a reply message is sent back containing the discovered, accumulated path. Each node maintains a routing table with information about nodes. Each entity may comprise (i) destination address, (ii) sequence number, (iii) hop count, (iv) next hop address, (v) next hop interface, (vi) its gateway, (vii) prefix, (viii) valid timeout, and (ix) delete timeout.
In an exemplary route discovery handshake; the originator node sends a Route Request (RREQ) and awaits the reception of a Route Response (RREP) message from the target. The waiting time is controlled by an additional parameter RREQ_WAIT_TIME. When a node receives a RREQ packet, the node updates its routing tables if needed. If the originator entry in the RREQ is found to be, e.g., stale, the RREQ is dropped. If not, each node processing an RREQ can create reverse routes to all the nodes for which addresses are accumulated in the RREQ. When the RREQ reaches the destination, it processes the packet and uses the information accumulated in the RREQ to add route table entries. An RREP message is then created as a response to the REEQ, containing information about the target node (address, sequence number, prefix, etc). Since replies are sent on the reverse path, DYMO does not support asymmetric links. The packet processing done by nodes forwarding the RREP is identical to the processing that nodes forwarding an RREQ perform, i.e., the information found in the RREP can be used to create forward routes to nodes that have added their address blocks to the RREP.
Routing protocols are prone to many different kind of attacks including spoofed, altered, or replayed routing information, selective forwarding, Sinkhole attacks, the Sybil attack, Wormhole attacks, the HELLO flood attack, or acknowledgement spoofing. Protecting the system against those threats is challenging as the attack might come from insiders or outsiders, furthermore we might find laptop-class attackers that are much more powerful than mote-class attackers. In this context, the system should be able to avoid those attackers in the presence of outsider attackers. However, if insider attackers are involved in the attack, the best we can hope is graceful degradation, i.e., the effectiveness of the routing protocol should degrade no faster than a rate approximately proportional to the ratio of compromised nodes to the total nodes in the network.
The security architecture of IPSec comprises the Internet Key Exchange (IKE) for security association and key agreement, the Authentication Header (AU) for connectionless integrity, origin authentication, and reply protection, and the Encapsulating Security Payload (ESP) for confidentiality, origin authentication, and connectionless integrity. Additionally, IPSec includes two different modes of operation. The first one, the transport mode, allows delivering traffic end-to-end between networks and within the same network. The second one, tunnel mode ensure secure transmission through an insecure network.
Therefore, ensuring effective and practicable security in such networks requires finding an approach offering a trade-off between the provided (and required) security services—data confidentiality, data authentication, data integrity, data freshness, availability, robustness, resiliency, resistance, energy efficiency, and assurance—and the security challenges such as minimizing resource consumption or enduring a big range of interfering,
The main idea of this embodiment is the combination of the polynomial approach based on the deterministic segment diversification scheme implemented on the MSP430 and the routing protocol used in 6LoWPAN to allow for host-to-host security without requiring a key establishment handshake. In other words, it is aimed at converting a routing protocol such as DYMO into a secure routing protocol.
It is to be noted that the above polynomial-scheme is an identity-based cryptographic protocol, i.e., it allows a party A to generate a pairwise key with B given the identity of the target node B. This nicely fits into the secure host-to-host operation of related routing protocols such as 6LoWPAN.
According to these concepts, this cross-layer optimization involves the modification of the operation of IPSec for 6LoWPAN networks in such a way that DSD is used for key distribution and establishment and IEEE 802.15.4 security to ensure basice security services. When two nodes want to communicate with each other, they do NOT launch the IKE, but use the DSD to establish a pairwise key with the other party. This key is used to protect the information by means of 1.5.4 security instead of ESP. The approach does not include any mechanism as AU. Furthermore, we integrate these changes in the 6LoWPAN routing protocol so that phases such as neighbor discovery or the update of the routing tables become secure.
The comparison between
ID-based cryptography can be used allow for secure routing protocols and efficient cross-layer optimizations between security and routing. We apply this concept to the DYMO protocol.
It is proposed to make the following design decisions linked to the exemplary embodiment of a sensor network:
The operation of the DYMO protocol is adapted in combination with the DSD to operate in a secure way in the sense that (i) in each step the parties can verify the authenticity of the peers, and (ii) the end-hosts can verify the identities of the nodes in the route. Furthermore, we remove the need of a key establishment handshake reducing the communication overhead.
As seen in the first embodiment, before starting any route discovery, a node needs to know which nodes are in its close vicinity. This phase of the secure DYMO protocol follows the next steps:
1. Node A sends a broadcast message Neighbor Request including its address A.
2. A's Neighbors reply including their addresses. A creates a list of non-verified neighbors (LNVNs)
3. A's proceeds to verify the neighbors in the LNVNs by:
a. Generating a pairwise key with each of them based on the other peer's address and its own DSD keying material
b. Launching a mutual-authentication handshake with each of its neighbors
4. The nodes in the LNVNs for which the authentication handshake is successful are stored in the list of verified neighbors (LVNs)
Regarding the route discovery, it will be explained in connection with
A route request message is flooded in the network using broadcast to connect node A with node E over a route {B, C, D}. The route request message includes information to verify the discovered route. This information is built hop-by-hop. At stage 0, or step c′1 on
When a node B receives a SRREQ packet, comprising a header (HD), the source (SRC being A), the destination (DEST (being E), the node updates its routing tables if needed. If the originator entry in the SRREQ is found to be, e.g., stale, the SRREQ is dropped. If not, each node processing an SRREQ can create reverse routes to all the nodes for which addresses are accumulated in the SRREQ. Node B encrypts the route verification information at stage 0 with its pairwise key with the destination B, as shown on
The same is applied for the subsequent nodes C and D, as shown on
When the SRREQ reaches the destination E, node E processes the packet and uses the information accumulated in the SRREQ ROUTE filed to add route table entries. Node E can also verify the validity of the route by decrypting the given received route with the corresponding pairwise keys generated by means of the DSD.
Thus, Node E can verify the validity of the route and detect as well where in the route there might be a corrupted node.
As can be shown on
After reception of SRREP, node A can transmit messages to node E through the discovered route by using key KAE to secure the communication link.
The system can be easily adapted to even provide for more advanced features. One of them refers to the session keys, which are used to protect the long term secrets generated from the polynomial keying material by means of the DSD, can be easily generated by including two nonces RN0 and RM0 in N0 and M0, i.e., N0=K_AE{A→E, RN0} and M0=K_EA{E→A, RM0}. Nodes E and A generate the common link key after receiving SRREQ and SRREP respectively as hash(KAB∥RN0∥RM0) where hash( ) refers to a secure one-way hash function.
SDYMO includes an approach to verify the identities of neighboring nodes. This approach fails if an attacker makes use of a high range antenna as the attacker can directly communicate even with those nodes located in distant places. The approach also fails if the attacker replicates the node. This can be solved from the network point of view by looking for collisions in the LVNs of different nodes. The main idea here is that two good nodes in distant locations are going to share a same compromised neighbor with very high probability, and thus, those nodes can be removed from the network in a probabilistic manner.
To this end, the encryption function Mi=EK-IDiA {Mi-1} is substituted by Mi=EK-IDiA {LVNi|Mi-1} (note that the encryption function can represent any cryptographic block) and the LVNi is attached to the message. Both the sender and verifier will be able to verify the claims of the routers regarding their LVNs. If an attacker has captured a node with identity ID and deployed copies of the node in different locations of the network, a same node (and identity) will appear in the LVNs of nodes in different places. This allows the verifiers to decrease the trust level with that node.
SSYMO allows for secure routing between two parties by applying a more efficient approach based on id-based crypto. We consider three main advantages: (i) the use of the identifiers as addresses allows sender and receiver to verify that the actual end is the good one; (ii) each node in the path has to encrypt the message with it's pairwise key with receiver or sender in the SRREQ or SSREP respectively, so that both receiver and sender can verify the path; (iii) finally, the SRREQ uses unsecure broadcast, but SSREP requires secure unicast so that the nodes in the path can also verify that they forwarded packets belong to nodes in the network.
These features allow us to achieve similar security features than related secure routing protocols but in a more efficient way. Specially, the SSYMO protocol prevents attackers from launching the Sybil attack as each node has a unique identifier and mutual authentication can be performed. Here, we assume that if a node is compromised and an attacker uses the same identity/keying material in different locations, the compromised device can be discovered and a revocation message against the devices sent to the network. Protection against fancier attacks such as HELLO flood or WormHole attacks might be possible at the price of establishing additional measures. For instance, HELLO flood attacks might be avoided by exchanging the x first elements of the LVNs tables between y-hop neighbors. If a number of nodes with completely different LVN find that a same id is in their LVN, that node would be a candidate for being guilty of a HELLO flood attack. Note that such collisions are very probable due to the Birthday paradox.
The described approach presents a number of advantages. The energy requirements are much lower as key agreement requires a very low amount of CPU resources and communication is not needed at all as key agreement is based on an identity-based cryptosystem. Delays are minimized in the same manner. Secure route discovery requires n+1 key generation operations and 2(n+1) encryption/decryption handshakes where n refers to the number of hops between two hosts. This can be implemented in a very efficient way due to the low-resource requirements of the DSD and the AES-coprocessor available on the CC2420. Furthermore, the changes required in the original DYMO routing protocol used in 6LoWPAN are minimum. Consequently, the system can be easily updated.
This invention has been developed in the framework of the FP6 WASP EU project. The system can be used by the WASP project or other partners of the WASP project.
In this process of discovering a route from node A to node E, it is possible to have the following steps.
(c′1) node A broadcast to its neighboring nodes B and X a route request for discovering a route to node E. The route request including the address of node E (DEST) and an encrypted first route verification message (VERIF). The encrypted first route verification message is encrypted with a key generated KAE by node A on the basis of the identifier node E.
(c′2) when node B receives the route request from node A, node B generates an encrypted second route verification message VERIF, the encrypted second route verification message being encrypted with a key KBE generated by the node B on the basis of the identifier of node E. Node B broadcasts (relays) the route request to second neighboring nodes C in the vicinity of the node B. However, the route request is modified to include the second route verification message in the field VERIF.
The encrypted second route verification message is the result of the encryption, by means of the key KBE, of the encrypted first route verification message. Node B replaces the first route verification message by the second route verification message in the route request. (c′2) may also comprise node B adding its identifier in the subsequent route request in the ROUTE field.
(c′3) node E receives the route request from node D (intermediate nodes have been skipped for the sake of conciseness)
(c′4) and (c′5) node E decrypts the codeword in the VERIF field by means of itartive decryption with keys KED, KED, KEB and KEA.
(c′6) node E generates an encrypted first route reply verification message, the encrypted first route reply verification message being encrypted with key KEA, and node E transmits a route discovery reply comprising a description of the route from node A to node E and the first route reply verification message.
(c′7) node B receives the route discovery reply, and generates an encrypted second route reply verification message, the encrypted second route verification message being encrypted with key KBA. Then, node B transmits to node A the route discovery reply, the route discovery reply being modified to include the second route reply verification message.
(c′8) Node A receives the route discovery reply,
(c′9) and (c′10) Node A decrypts the codeword in the VERIF field by means of itartive decryption with keys KAB, KAC, KAD and KAE.
Other application areas include distributed systems, and sensor networks, and communication networks.
In the present specification and claims the word “a” or “an” preceding an element does not exclude the presence of a plurality of such elements. Further, the word “comprising” does not exclude the presence of other elements or steps than those listed.
The inclusion of reference signs in parentheses in the claims is intended to aid understanding and is not intended to be limiting.
From reading the present disclosure, other modifications will be apparent to persons skilled in the art. Such modifications may involve other features which are already known in the art of radio communication.
Number | Date | Country | Kind |
---|---|---|---|
09305981.4 | Oct 2009 | EP | regional |
10305018.3 | Jan 2010 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2010/054536 | 10/7/2010 | WO | 00 | 4/3/2012 |