[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Next Article in Journal
Development of SPR Imaging-Impedance Sensor for Multi-Parametric Living Cell Analysis
Next Article in Special Issue
Time-Efficient Allocation Mechanisms for Crowdsensing Tasks with Precedence Constraints
Previous Article in Journal
An End-to-End Deep Neural Network for Autonomous Driving Designed for Embedded Automotive Platforms
Previous Article in Special Issue
Design and Analysis of a Lightweight Context Fusion CNN Scheme for Crowd Counting
You seem to have javascript disabled. Please note that many of the page functionalities won't work as expected without javascript enabled.
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Authentication and Delegation for Operating a Multi-Drone System

School of Electrical Engineering, Korea University, Seoul 02841, Korea
*
Author to whom correspondence should be addressed.
Sensors 2019, 19(9), 2066; https://doi.org/10.3390/s19092066
Submission received: 22 February 2019 / Revised: 14 April 2019 / Accepted: 1 May 2019 / Published: 3 May 2019

Abstract

:
As the era of IoT comes, drones are in the spotlight as a mobile medium of Internet of Things (IoT) devices and services. However, drones appear to be vulnerable to physical capture attacks since they usually operate far from operators. If a drone is illegally captured, some important data will be exposed to the attacker. In this paper, we propose a saveless-based key management and delegation system for a multi-drone control system. The proposed system enables a multi-drone control system to highly resist physical capture by minimizing exposure of confidential data. In addition, when the drone leaves the formation for performing another mission or by a natural environment, the system can allow the drone to securely re-participate in the formation with the help of the ground control station (GCS) when it comes back. The analysis result shows that the proposed system can reduce storage space usage and require less computational overhead. From the result, we expect that the system can guarantee the resistance of physical capture and secure key management to the drones as well as many mobile IoT devices.

1. Introduction

Unmanned aerial vehicle (or drone) technology has begun to be used in the private sector [1,2] due to technological advances such as control, communication, and cameras, unlike the past that was only used for military purposes. Drones with a higher degree of freedom can be used to provide various kinds of services [3]. For example, drones are widely used for shooting diverse sports activities at the individual level. Amazon is conducting research on using drones for book delivery [4], and New Zealand’s Domino pizza had succeeded in delivering pizza using drones [5]. This mobility raises the importance of employing one or more drones in the Internet of Things (IoT) environment [6,7]. Drone can provide surveillance [8] in the places or angles that humans are unable to reach due to the drone’s unlimited mobility, and it also can provide connectivity by improvising a local area network infrastructure in real-time according to the overall situation. In addition, the multi-drone system enables us to diffuse commands into and/or collect data from geographically-disperse sensor devices, which are essential functions in an IoT system, and thus, it can extend the battery life of sensor devices and reduce the cost of infrastructure deployment by collecting the data while moving.
However, there are limitations to controlling a drone based on a remote controller (RC) because it requires interaction with the controller, and it can be worse when multiple drones are employed in providing services. It is infeasible for one pilot to control several drones at the same time through multiple RCs. Even if several pilots operate drones one by one, the burden of labor costs will increase as the number of drones required for service increases. To make drone control autonomous and reduce control overhead from pilots, ground control station (GCS)-based control draws much attention in drone research and community [9]. Using features such as waypoint flight or setpoint flight in the GCS, a drone can autonomously move to the target point without any RC operation. The GCS also makes it easy to implement a multi-drone system and its formation.
Due to its performance and purpose of the drone, the altitude at which actual drones fly is at a level that humans can see with the naked eye. As a result, drones are likely to be exposed to other people and, even more, can be physically captured by hostile persons. Attackers can then inject false data into the captured drone, or directly control the drone as if it is a normal drone. Physical capture is actually meaningful. Note that many researchers are conducting studies to catch drones by birds or make a forced landing using radio waves. Considering most drones communicate with each other based on an ad-hoc network [10] in a multi-drone system, using the same group key for all the drones may expose all their session keys to the same hacking risk when one of the drones is captured. To show how dangerous group key usurpation is in a multi-drone system, we designed a simple scenario. In this scenario, we first extracted a secret key from the packets between the GCS and the multi-drone system with a common hacking tool. After that, we made a fake GCS and tried to send a command disarm with the extracted group key, which forces the drone to crash. The whole process is shown in our video (https://youtu.be/tw95S1KBlls/). Following the video, what we can see is that it is important to have strong resistance to physical capture to prevent group key exposure. The key update to prevent this exposure can cause a temporary disconnection of all the drones, which may result in a catastrophe in the control of a multi-drone system. Moreover, asymmetric key encryption based on a public key requires many operations and subsequently much computation, so it is better to exclude it if possible.
Consequently, a security scheme for a multi-drone system should have strong resistance to such physical capture. Moreover, using a symmetric key-based encryption is better than an asymmetric key-based algorithm due to the constrained resource on the drone. In this paper, we propose a saveless-based key management and delegation system for a multi-drone system. The meaning of saveless property is that the drone saves a minimum of secret data in its storage. In the proposed system, all group session keys are not the same, only drones which are same-hop from the GCS have the same group key, which is different from other group key management systems. These session keys are generated by the hash chain function, so one of the drones can know the other’s session key, and they can communicate with each other. When a physical capture occurs, which leads to changing the network topology, the GCS generates new session key and sends it to all drones except the captured drone. However, it is possible for a drone to leave the flight formation according to flight schedules or external factors, such as wind or flat battery. In order to compensate for this, the proposed system provides a readmission process for breakaway drones. We then propose the delegation system for GCS, which can be used in many scenarios. Complexity analysis shows that our algorithm can reduce storage usage and communication traffic.
The major contributions of our paper are:
  • We propose the saveless-based drone authentication system, which is resistant to physically capture. Following the system, all drones in the network basically have a different session key, so secret data leakage can be minimized even when one drone is captured;
  • We introduce the saveless-based drone delegation system. With our delegation system, the GCS can temporarily give the control right to another GCS with simple authentication.
The rest of the paper is as follows: We shows the related work in Section 2. The proposed saveless-based group key management system is shown in Section 3. Section 4 presents our drone delegation system. Section 5 analyzes how our system is secure. Section 6 shows the results of our system in numerical evaluation and simulation study based on actual experimental data. Finally, we conclude the paper in Section 7.

2. Related Work

Issues related to group key management have already been studied extensively. The advantage of a group key is the ability to reduce the key size since all members in the same group share one group key to communicate with each other. For example, if all connections require different keys, the number of required keys is n ( n 1 ) 2 . However, using the group key, the required key is only one. This idea is supposed to be used for networks whose nodes have limited calculating power and storage, such as sensor networks. Recent studies on the group key are based on attribute-based encryption [11,12,13,14]. Following this idea, it is possible to send the data to users who have appropriate attributes without additional checking attributes, unlike other algorithms. However, this idea is too heavy to directly apply to sensor networks or drone networks.
Our system is symmetric key-based key management, and movable node-based key management, which seems like a network dependent-based scheme [15]. A network-dependent approach basically supports node moving over a widely distributed wireless network. The main point of this environment is re-keying [16], which is introduced as a key renewal process in the proposed system. For re-keying, there are some studies to reduce the re-keying overhead. Sandirigama et al. [17] used password-based key management with a combination of re-keying and authentication. Suganthi et al. [18] proposed the energy efficient key management scheme by generating pair-wise keys and maintaining them without key sharing. However, these algorithms are not suitable for the drone environment.
The proliferation of the IoT network, which includes devices which have small size and limited performance but can be highly distributed with an ad-hoc-based wireless network, has been highlighted. These devices are basically operated on a group basis; the network operating environment is similar to the drone environment. Li et al. [19] showed the secure sensor association and key management scheme in a body area network. A group of nodes establish group pairing before the deployment, then the secret keys are generated. However, the difference with the body area network is that each node in the drone network moves to a different path. Zhang et al. [20] were able to filter the false data through group rekeying which is sent by the compromised node. Following this idea, the future key cannot be extracted without neighbor nodes, but it is not sufficient to satisfy mobility, which is important for the drone environment.
The self-healing key distribution scheme [21,22,23] is useful when network status is unstable in the wireless network. In a drone environment, the self-healing property seems important since all connections are based on an ad-hoc wireless network and all nodes continuously move in 3D-based directions. However, the property is vulnerable to physical capture. Following this property, the node stores some information to restore the session key. When the node is physically captured, all data in the storage will be disclosed. In the proposed system, the only exposed data are the current session key, and the topology and session key will be changed when the system notices the physical capture attack.

3. Saveless-Based Group Key Management System

In this section, we propose a saveless-based group key management system to guarantee resistance to physical capture. This system consists of four protocols: Initial key management, node communication, group key renewal, and withdrawal management. These protocols are described in detail below.
Before introducing the protocols, some assumptions and the environments of multi-drone flight control are as follows: All drones and GCSs are connected with Wi-Fi-based ad-hoc networks. The GCS is the administrator which gives various commands and sets the course of the drones. The n drones fly following the flight path and execute the command by the GCS. The drones are located in the proximity of the GCS before the flight, which means that initial group key generation and distribution protocols are secured.

3.1. Initial Group Key Generation and Distribution Protocol

This protocol will be run before the initiation of the flight, and all communication is secured. When a key generation protocol is finished, the GCS sends the group key k 0 1 to drones selected by prearranged topology with one-hop distance, since the GCS and all drones are not in operation. The drones, which receive their group key k 0 1 , calculate following each of their next-hop node’s group key and then send the key to next-hop drones.
k i h + 1 = h k i h ,
where i will be 0 in this protocol. The idea is that the group symmetric key belongs to each drone and is different compared to other drones except the same-hop drone.

3.2. saveless-Based Communication Protocol

After the registration is over, the GCS can send some command messages, such as take-off and move to the setpoint, to the drone formation. The command message sent to the drone has to be encrypted with the group key. There are two possible types of communication protocol: GCS-to-drone broadcasting or node-to-node direct communication. Table 1 shows notations for this protocol and the group key renewal protocol.

3.2.1. GCS-to-Drone Broadcasting Protocol

In the case of broadcasting, this type of communication is commonly used when the GCS sends the command message to the drone formation. There are two possible methods to broadcast the message: single node-based broadcasting, and forwarding-based broadcasting. Single node-based broadcasting is that a sender encrypts messages using each receiver’s group key. After that, the sender sends the appropriate message to the receiver one by one. This method seems common at our scheme, but it requires lots of overhead in the sending phase.
The forwarding-based broadcasting method is that a sender only forwards the encrypted message to next-hop receivers. The whole procedure is as follows.
  • A sender encrypts the message using next-hop’s group key in session i:
    e m s g = E s m s g , k i h + 1 ;
  • The sender forwards e m s g to next-hop receivers;
  • The next-hop receivers get the m s g decrypting e s m g with their key k i h + 1 :
    m s g = D s e m s g , k i h + 1 ;
  • The next-hop receivers reiterate the previous process, such as re-encrypt m s g , using the next-hops’ session key and forward the result to their next-hop nodes.
As a result, all nodes in the network can receive the sender’s message. The encrypt function can be a commonly used symmetric encryption algorithm, such as DES or AES. The method can reduce the sending overhead compared to the previous method, and the energy consumption of intermediate drones can be also reduced since intermediate drones send the data at one time and symmetric key-based encryption and hashing does not need many computation power.

3.2.2. Node-to-Node Direct Communication Protocol

The overall process of direct communication is almost the same as the broadcasting type. A different point is that the hop distance between a sender and a receiver may be higher than one. In this case, the temporal encryption key between two nodes will become the group key value of the node, which has higher hop distance. The reason is that the node which has a lower hop number can easily calculate the higher one’s group key using the hash chain. Following Equation (2), the message sent to the receiver is as follows:
e m s g = E s m s g , h s h r h k i min s h , r h ,
where s h is the sender’s hop number, and r h is the receiver’s hop number. When two drones which are physically connected want to communicate with each other before the key renewal protocol activation, it is possible to share their hop count in this session.

3.3. Group Key Renewal Protocol

All drones in the network send a beacon message to announce their own network status. From the beacon message, the drone can see the need to update the network topology due to the position change of some drones. In this case, all group keys of the drones should be renewed to satisfy the saveless property. The member drone sends a message that requests a routing table and group key renewal to the GCS. Then, the GCS calculates a new session’s group key as follows:
k i + 1 0 = h k i 0 r i + 1 .
To send the new session’s group key, the GCS determines which drone is the nearest one using the general routing algorithm and reported drones’ position. The GCS then wants to forward the new group key to the new 1-hop drone; there are the following issues in broadcasting the renewed key.
  • The new group key has to be encrypted to send them because all drones are not close-range, in contrast to the initial key distribution protocol. Therefore, the GCS cannot use near communication or secured channel communication in this case;
  • The key which will be used to encrypt should be an old group key since all drones do not have the new session’s group key;
  • The position of all drones and routing paths is already changed, so the next-hop node may not have the k i h + 1 when the drone’s old group key is k i h .
The whole procedure of renewed group key distribution considering previous issues is as follows (see also Figure 1).
  • Each drone periodically senses all neighbor drones;
  • When a drone notices that the neighbor drones has been changed, it broadcasts a request message that all drones need to report the list of their neighbor drones to the GCS;
  • The GCS collects the neighbor list of each drone, then calculates the new routing paths;
  • The GCS generates the following tuple t u :
    t u = { i d 1 , p i d 1 , h i , i d 1 , , i d N , p i d N , h i , i d N } .
    Figure 2 shows an example of the tuple. In the figure, a circle represents a drone x, a number in the circle is i d x , and a blue colored text above the circle is h i , i d x . When network topology has been changed like in Figure 2b, the tuple t u generated by the GCS is t u = 1 , 4 , 1 , 2 , 1 , 2 , 3 , 4 , 3 , 4 , 0 , 2 ;
  • The GCS calculates its new session key k i + 1 0 following Equation (4) and next-hop’s new session key k i + 1 1 = h k i + 1 0 ;
  • The GCS encrypts the k i + 1 1 and t u by Equation (3) to forward the result message to the next-hop node. In the example, the encrypted message e m s g 0 , 4 which will be sent to drone 4 by the GCS is e m s g 0 , 4 = E s k i + 1 1 t u , h 2 k i 0 , because drone 4’s old hop count is 2;
  • The nodes decrypt the encrypted message to get the new session key k i + 1 1 and find their next-hop nodes. In the example, drone 4 decrypts e m s g 0 , 4 and gets k e y i + 1 1 using its old session key k i 2 . After that, drone 4 can find that the next-hop nodes are drone 3 and drone 1 by checking p i d x in t u ;
  • The nodes encrypt the new session key for their next-hop nodes as the following equation:
    e m s g s = E s k i + 1 h i + 1 , s + 1 t u , h max h i , θ { S , R } k i 0 , s S , r R .
    All the next-hop nodes of the GCS just broadcast the message { h max h i , θ { S , R } , e m s g s , r } to their next-hop nodes. The next-hop nodes can decrypt e m s g s since they know the i d of the sender and session i’s hop count for all nodes. In the example, drone 4 has to broadcast a new session key to drone 3 and drone 1. Therefore, the encrypted message which drone 3 and drone 1 will receive is as follows:
    e m s g 4 = E s k i + 1 2 t u , h max 2 , 1 , 3 k i 0 ;
  • All drones in the drone flight formation repeat the above procedures from step (7) to step (8), then all drones can get the new group key in session i + 1 .

3.4. Node Withdrawal and Re-Participation Protocol

There are two cases where a new node participates in the drone flight formation already in operation: When another GCS delegates its drone’s control, or when a drone is readmitted into the formation of the intended flight. Since a delegation case is explained in a later section; the readmission case is introduced in this subsection.
In the following flight environment or pre-populated scenario, some drones can break out of the formation. The factors that can affect the flight route of the drone are not only a natural environment, but also built environment, such as winds, rain, the position of the building or trees, etc. Some drones may be disconnected from the flight formation because of these situations. The breakaway drones can lead back to the right position of the formation due to the adjustment of an attitude control system.
The breakaway drones attempt to re-join the drone network but will be denied. First, the drones have to prove that they were not physically captured while they departed from the network. Even though this proof has been accepted, the drones cannot accept the new group key from the proposed group key renewal protocol since they do not have the group key of the last session. The GCS may change the session and run the group key renewal protocol at the moment of confirmation that some drones left the network. Initializing the session and distributing the initial group key is too dangerous in action.
Even though there are some solutions to re-authenticate the drone with a symmetric-based encryption scheme, a new re-authentication protocol is needed since it is hard to distinguish the cases between the physical capture or scheduled/adventitious breakaway. This is because our protocol guarantees saveless property to defend the physical capture. The scheme for re-authentication consists of two parts, the withdrawal and the readmission part. Table 2 shows notations used in the withdrawal and re-participation scheme. The whole procedures of the withdrawal part are as follows.
  • When the breakaway drone N b is aware that the link between itself and the other drones in a formation is broken, it rapidly runs the encryption algorithm to save the information, where r is a random nonce:
    e d 1 = E s i d b f d 1 t w r b , k i h , r b = h t w r ;
  • Further, it immediately replaces the key k i h with temporary key k ^ 1 h = h k i h f d 1 , and the flight data f d 1 with e d 1 ;
  • After some period of time, N b repeatedly generates encrypted flight data e d j + 1 and a new temporary key k ^ j + 1 h following equations, where j means a temporary session number:
    e d j + 1 = E s f d j + 1 , k ^ j h , k ^ j + 1 h = h k ^ j h r b ;
  • N b replaces the old temporary key with a new temporary key at the indicated intervals but saves all encrypted flight data e d 1 , , e d λ , and timestamp t w when N b is far away.
The readmission part consists of two processes: The pre-verification process and the readmission process. Figure 3 shows the whole readmission part. When N b re-meets its original formation, a pre-verification process will be started as follows.
  • N b sends the verification request message m s g 1 = i d b , t w , e d 1 , λ to a first node N d which discovers N b ;
  • N d sends m s g 1 and m s g 2 = E s i d b t w r d , k i d h d to the GCS, where r d is a random nonce of N d , h d is a hop number of N d , and i d is a current session number of N d ;
  • The GCS extracts the e d 1 from m s g 1 since it knows the session when N b has been left the formation;
  • The GCS verifies the real position of N d at t w :
    r p o s N d , 1 s p o s N d , 1 d t h ;
  • Further, the GCS verifies the timestamp t w by t c t w t t h , where t c is a current time;
    • If the withdrawal is scheduled, the GCS can estimate the t c t w , then t t h will be set to an appropriate time;
    • If the withdrawal reason is uncertainty, such as wind and obstacles, t t h has to be very short.
    If the two verification processes are completed, the GCS orders N d and N b to run a one-time key exchange protocol.
  • The GCS sends a message m s g 3 to N d as follows:
    m s g 3 = t w , m s g 3 a , E s r d , k i d h d , where m s g 3 a = E s r b k ˜ , k ^ λ h ;
  • N d saves k ˜ , then sends the m s g 3 a to N b ;
  • N b decrypts the received message and saves k ˜ .
In this process, the GCS can know the k ^ λ h , because following equation k ^ λ h = h λ 1 h k i h f d 1 , r b , the GCS already knows k i h and receives f d 1 and r b from e d 1 . N b cannot communicate with the GCS since it does not have the old session key k i h . The above algorithm gives the one-time session key used to complete a readmission process. The readmission process involves the following steps:
  • N b sends c m s g = E s e d 2 , e d 3 , , e d λ , k ˜ ;
  • The GCS extracts e d 2 , e d 3 , , e d λ from c m s g ;
  • The GCS verifies following two conditions:
    u = 1 λ r p o s N b , u s p o s N b , u λ d t h
    max d d u r p o s N b , u Δ t h for u = 1 , , λ ,
    where the first condition means how the breakaway drone has followed the correct route on average, and the second condition means whether or not the breakaway drone sharply changes its position by virtue of the attacker’s physical capture;
  • If the two conditions are successfully passed, the GCS sends a message which encrypts its new session key, E s k i d h d + 1 , k ˜ , to N b ;
  • N b revokes k ˜ .

4. Drone Delegation System

According to the operational scenarios, a drone flight formation can be controlled by multiple GCSs. Moreover, some GCSs can temporarily or permanently delegate the control of the drone flight when the range of operations is very large. In this case, drone delegation and ownership transfer are important things in both drone security and security performance. The drone delegation system requires two protocols: The GCS authentication protocol and the drone delegation protocol. Table 3 shows the notation used in this section. Figure 4 shows the whole procedure of the drone delegation system.

4.1. GCS Authentication Protocol

The whole procedure in which a delegator GCS and a mandatory GCS authenticate each other is as follows:
  • The delegator GCS D, which delegates its drones to the mandatory GCS M, first requests delegation to M sending i d D ;
  • M sends random nonce r M to D;
  • D sends a message r D , i d M , Sig r M i d M , s k D to M;
  • M sends a message i d D , Sig r D i d D , s k M to D;
  • Each of M and D uses the other side’s public key, p k D and p k M , to verify the other side’s identity, where the public keys can be gotten from the key master which manages the GCS’s public key.

4.2. Delegation Protocol

After the authentication of GCS, the next phase is drone delegation, and the mandatory GCS can control the drones with its key. An important point of the delegation is that this protocol temporarily controls the right to the mandatory GCS.
There are two cases in this protocol; the drone group belonging to D is far away from the group of M and the close case. The far case is very simple because M sends a command message to the D, in which the message is encrypted with shared key between D and M. The close case, however, M can directly send a command message to drones belonging to D. A procedure of the close case is as follows:
  • D decides c max , r D , and replacement key k ;
  • D broadcasts the following message to all of the drones under its command, where i is the current session of D:
    i d M , E s r D h c max r D k , k i 1 , f i d M , k i 1 ;
  • Some drones, which receive the broadcast message, check if i d M is true by a keyed hash function, and save the message, then generate a forwarding message and forward it to their next-hop drone, where α = r D h c max r D k :
    i d M , E s α , k i h + 1 , f i d M , k i h + 1 ;
  • Repeat (2) until all drones receive the message;
  • D sends the following message to M, where i d d is the drone’s id, and n is the number of drone under D:
    E s i d d 1 , p o s 1 , , i d d n , p o s n k , k D M ;
  • M calculates the new route for the delegated drones;
  • M sends the following key renewal message to all nodes in A , where i d d x is a delegated pair of drone x:
    E s i d d x k , k j x h x , x A ;
  • Each drone in A decrypts the received message, then it sends the following message to their pair delegated drone for distributing a new session key:
    i d M , i d d x , E s h k i x h x + 1 , k , x A ;
  • The delegated nodes check i d M using the keyed hash function and save key k ;
  • If the previous hop node of a delegated node is also a delegated node, then the previous node runs step (8) to act as a node in A .

4.3. Delegation-Based Command Protocol

Since M receives the command right temporarily in our delegation system, delegated drones have to send the update message to the M. Like many delegation protocols, we adopted the parameter as a command counter, rather than a time duration. In drone control, there is a risk of loss of control in some cases if control is provided based on duration. The process of sending and receiving commands is as follows:
  • When the delegated node receives a command message, it replaces the stored encrypted message following equation:
    E s h c r D h c max r D , h c k i h , h c k i h ;
  • If c = c max , then the delegated node notes to M that delegation has to be renewed with E s h c max r D , h c max k i h ;
  • M sends the received message to D;
  • D verifies if delegation renewal is required by checking h c max r D since D has r D and k i h ;
  • If this verification succeeds, then D and M run the delegation protocol again.

5. Security and Usability Analysis

In this section, we show that the proposed algorithm is secure against possible attacks in a drone environment. The above four items in the table show the security analysis; the other four items represent how these systems are suitable for a drone environment.

5.1. Physical Capture Attack

As we have already noticed in the introduction and related work, the drone is easy for the attacker to capture. Following our protocol, exposed data in the drone are as follows when the drone is captured: Hashed session key, encrypted flying data of the drone, and the timestamp when the node has been hijacked. When the protocol uses the cryptographic hash function, the attacker cannot know the last session key due to the one-way property of the hash function. The encrypted flying data are protected with the last session key, as the attacker who does not know the last session key cannot decrypt this message. Even though the attacker can extract the session key from the captured drone, the network topology and session key will be updated when the capture attack is detected. After that, the extracted session key is of no use. Overall, the riskiness of key exposure depends on the security of cryptographic hash functions.
The easy method for attacking the proper network after the physical capture attack is the masquerading attack, which acts as a proper drone. The captured drone returns to the flight formation and wants to report false data to the GCS. The malicious drone will try to run a re-participation protocol to join the drone network at first, but there are two reasons it is hard to pass the conditions in the re-participation protocol. The one reason is that there is no way to modify the encrypted flight data since the attacker does not have the key. The other is that route design considering cross-validation analysis by the neighbors of the captured drone can easily defend this attack, even though the session key is exposed.
It seems to be a threat to the drone environment when the drone near the GCS is physically captured. Following our protocol, the drone near the GCS has low hash chains, so it can generate the child node’s session key with ease. Therefore, the attacker which captures the drone near the GCS seems to disrupt the service by maliciously controlling many child nodes. However, this attack cannot succeed in two possible cases. In the first case, when the drone deployment and the GCS is physically near, the operator can observe the drone network with the naked eye. In this case, the operator will easily notice the physical capture attack and run an emergency mode to return the other nodes. In the second case, even the distance between the drone network and the GCS is too large to see with the naked eye, our system runs the key renewal protocol after the beaconing period. There is not enough time for the captured drone to come back in the beaconing period. Moreover, the returned drone’s re-joining into the deployment will be failed by the node withdrawal and re-participation protocols.

5.2. Forward and Backward Secrecy

To satisfy the forward secrecy [15], a drone cannot acquire the group key in any way while it is away from the flight formation. By the key renewal protocol, there is no relationship between the current master session key k i 0 and the next master session key k i + 1 0 . A specific node’s session key is calculated with a hash chain function. The idea using these facts is that the breakaway node cannot generate an expected next session key with its secret information. The backward secrecy is satisfied if the new member joining the group cannot decrypt the ciphertext before then. The proposed system guarantees the backward secrecy due to the similar reason of forward secrecy.

5.3. Key Independence

The characteristic of hash function and hash chain function and the key between different session and different hops guarantee independence. Especially since the random nonce is included in the input of the next session key generation, key independence is satisfied. A possible concern is that the node can acquire its children’s session key only using the hash function. However, by considering the concept of a group key, where all group members share the keys, our system satisfies key independence.

5.4. Usability Analysis

Guaranteeing the security requirement is indispensable, but satisfying with the concept of usability is also important. As in Table 4, each group key management scheme is designed for its own target system, such as the body area network and wireless sensor network. The attributes and the requirement conditions for the drone network environment are different from other network environments. The systematic attributes for the drone network environment are mobility, multi-hop-based communication, message broadcasting availability, and delegation support. Other algorithms can guarantee some attributes, but our algorithm is the most suitable for the drone environment.

5.5. Networking Issue

Drones networks with high mobility in real environments are vulnerable to hidden node problems. This paper basically focuses on the physical capture attack and the key management, but we briefly explain how the proposed system can cope with this problem. In our service scenario, the drone network is configured with a tree topology, and the GCS is a root node. When the key renewal protocol starts, all drones in the network change their antennas to listening mode. Only drones which receive the key renewal message from the GCS (or their parent nodes) can change their antennae into transmission mode. According to this procedure, our protocol follows a top–down communication method. Since this method transmits data from the root node to leaf node following a fixed order, it is possible to say that the method is scheduled. Therefore, our protocol can reduce the hidden node problem without any modification. Additionally, by adding transmission order data into the key renewal message, the hidden node problem can be nearly resolved.

6. Evaluation and Simulation Study

In this section, we simply analyze the complexity of the proposed system and some previous work to show that it can satisfy saveless property and low computational overhead and data sending. After then, we show the results of simulation study based on combination of the experimental result and numerical calculation.

6.1. Evaluation

Table 5 shows the analysis, where N is the total number of drones in the network, L is the length of an encrypted group key, w is a word size, and n, t and μ are system parameters and smaller than N. We assume that the network topology is binary-tree and that each parent node has two child nodes except the leaf nodes. All criteria in the table are evaluated at the key renewal protocol. Compared to other schemes, the proposed system has the lowest data sending traffic, computational overhead, and storage usage. Following these evaluations, we can assert that our system satisfies saveless property and is suitable for a multi-drone system.

6.1.1. Communication Overhead

Our protocol just broadcast the new key renewal message which contains one integer value, L bits encrypted group key, and new topology map with 3 N w bits. In our protocol, the node broadcasts the renewal message with w + L + 3 N w only once. In the case of [19], the controller unicasts 2 L bits share to N nodes. Each node in [20] sends out n messages with 2 L bits. Following [24], a group manager firstly broadcasts 2 log N 1 ’s new public keys whose size is basically 8 L . After that, the group manager broadcasts the L bits encrypted message to all nodes. The total communication overhead of [24] is L + 8 w L ( 2 log N 1 ) .

6.1.2. Computation Overhead

The computation overhead of each node in our protocol is the received message decryption, 2 log N times hash chaining, and a message encryption. Following [19], each node receives the encrypted message which contains an update order and a polynomial share. Then it computes the polynomial with t 2 powers and t multiplications. It also computes the group key and share key by running each hash function. In the case of [20], each node updates all pairwise keys from the connected nodes. Therefore, the node must decrypt N messages and calculates the key with o ( μ 3 ) multiplications and divisions. In [24], each node calculates the new public auxiliary keys for its all parents, and it can get the new group key by decrypting the final public auxiliary key using its secret key.

6.1.3. Storage Overhead

Our system only saves the current session key, L bits. However, other algorithms save all sessions’ keys, or lots of information to generate new keys. Especially all members in [24] have a private auxiliary key and log N parents’ public auxiliary key.

6.2. Experimentation and Simulation Study

In this subsection, we conduct a simulation study on our key renewal protocol in two perspectives: Computation overhead and energy consumption overhead. Before the simulation, we first implemented our key renewal protocol on Samsung Galaxy A5 2017 with Android 8.0. This system has ARM Cortex-A53 MP8 1.9 GHz CPU and 3 GB LPDDR4 SDRAM. We used this system as a drone control system because of its similar performance to the Odroid XU4 generally used for the drone control system. The Wi-Fi module used in this system is compliant with IEEE 802.11g. To reflect the realistic drone environment, we set a beaconing period as one second.

6.2.1. Computation and Networking Overhead

Following this overhead simulation, we assumed that every parent node has three child nodes. We calculated the total time to complete our key renewal protocol via the hop length of the drone network. After the network topology change, the form of position structure is not changed even when hop count of each node has been changed. Before the simulation, we actually implemented each function and measured their performance on the drone control system. Table 6 shows the experimental result. Following the table, networking delay is larger than computation delay, and it is about 24.5 times larger than the hash chain delay. However, the networking overhead is very small compared to the beaconing period. The maximum possible height of the proposed system is 37 when the beacon period is 1 second. From the experimental result, each function is suitable for a real environment because the system does not actually maintain this height in terms of stability.
Figure 5 shows the result of simulation of the key renewal protocol using the above experimental result. In this figure, as the number of maximum increased, the total delay of the key renewal protocol also increased linearly. However, there was no relationship between the number of child nodes and the total delay. The reason behind these results is that the drone runs one decrypting, several hash functions, and one encrypting function, then broadcasts one encrypted message in our key renewal protocol. As the number of hops increases, the number of hash function execution will also be increasing. However, the delay of hash function is negligible compared to encryption or transmission delay.

6.2.2. Energy Consumption Overhead

Energy analysis is important [25] in our system because the power consumption is a significant factor in the battery-based drone operations. We first measured the actual amount of energy consumed by each function within the key renewal protocol from the drone control device. The result of measured data is shown in Table 7, where KRP means the key renewal protocol. The first column shows the energy consumption of each function with one time activation per one second for 30 minutes. The second column is the ratio comparison, where M600 Pro, which has a 4500 mAh battery and 30 minutes flight time, is the DJI’s drone for industrial purpose. In this result, we can see that our key renewal protocol’s effects on energy consumption are very low compared to flight energy consumption.
Using the measured energy consumption data, we performed a simulation to analyze the correlation between the actual drones’ flight duration and the beaconing period through the timeline graph. For the simulation, some assumptions were acceptable for actual drone operational scenario: (1) The root node is a mothership drone (a mothership drone is defined as the drone that is directly connected to GCS and can be a delegate of GCS when several drones work at a distance from GCS) which can directly communicate with the GCS; (2) the height of the tree topology is up to 5; (3) all drones except the mothership drone are free to move; (4) there is no drone to withdraw from the formation or re-join. Figure 6 shows the result for the simulation. Compared to the case where the beaconing period is 200 ms, the cases where the beaconing period is 1 second, 5 seconds, and 0 second (no beaconing) can fly 2.17%, 2.62%, and 2.68% longer, respectively. Since each function required for the key renewal protocol basically consumes a small amount of power, it does not affect the actual flight time relatively. Consequently, the proposed algorithms can work well in real-world operating scenarios.

7. Conclusions

In this paper, we proposed an authentication and delegation system which is appropriate for a GCS-based multi-drone control system that is necessary for the IoT environment to compose and operate it. Compared to a general group key management scheme, the proposed system is focused on the physical capture attack that is a critical threat to the multi-drone system. Therefore, the proposed system is based on the idea that storing secret data, such as a group key, flight data, and operational intelligence, will be a minimized, so-called saveless property. The proposed key distribution protocol is based on the saveless property. It also includes key renewal and a node re-participation protocol to apply unconstrained mobility, which is the core attribute of drone environment. We additionally proposed the drone delegation system for delegating control right to other GCSs by the drone’s operation and position. The complexity analysis shows that the algorithm can reduce storage space without any additional overhead. The simulations based on the data from experiments verify that our system is suitable in the real-world environment.
As future work, we would like to reduce the proposed key management and delegation protocol to work with very small IoT devices that have limited computation power, and to find a proper key renewal period that satisfies a low computation cost and more security guarantee.

Author Contributions

Conceptualization, M.B. and H.K.; Methodology, M.B. and H.K.; Software, M.B.; Validation, M.B.; Writing—Original Draft Preparation, M.B.; Writing—Review Editing, M.B. and H.K.; Supervision, H.K.

Funding

This work was supported by “Human Resources program in Energy Technology” of the Korea Institute of Energy Technology Evaluation and Planning (KETEP) granted financial resource from the Ministry of Trade, Industry & Energy, Republic of Korea (No. 20174030201820).

Conflicts of Interest

The authors declare that they have no conflicts of interest.

References

  1. Stratistics MRC. UAV Drones—Global Market Outlook (2016–2022); Report ID: SMRC16075; STRATISTICS MRC: Secunderabad, India, 2016. [Google Scholar]
  2. Meola, A. DRONE INDUSTRY ANALYSIS: Market Trends & Growth Forecasts. 2017. Available online: https://www.businessinsider.com/drone-industry-analysis-market-trends-growth-forecasts-2017-7 (accessed on 1 May 2019).
  3. Bae, M.; Yoo, S.; Jung, J.; Park, S.; Kim, K.; Lee, J.; Kim, H. Devising Mobile Sensing and Actuation Infrastructure with Drones. Sensors 2018, 18, 624. [Google Scholar] [CrossRef] [PubMed]
  4. Symington, S. Amazon.com Has Officially Begun Drone Delivery. 2016. Available online: https://www.fool.com/investing/2016/12/20/amazoncom-has-officially-begun-drone-delivery.aspx (accessed on 1 May 2019).
  5. Ryan, H. Domino’s Delivers Its First Pizza Using a Drone. 2016. Available online: https://www.nzherald.co.nz/business/news/article.cfm?c_id=3&objectid=11749185 (accessed on 1 May 2019).
  6. Erdelj, M.; Uk, B.; Konam, D.; Natalizio, E. From the Eye of the Storm: An IoT Ecosystem Made of Sensors, Smartphones and UAVs. Sensors 2018, 18, 3814. [Google Scholar] [CrossRef] [PubMed]
  7. Valentino, R.; Jung, W.S.; Ko, Y.B. A Design and Simulation of the Opportunistic Computation Offloading with Learning-Based Prediction for Unmanned Aerial Vehicle (UAV) Clustering Networks. Sensors 2018, 18, 3751. [Google Scholar] [CrossRef] [PubMed]
  8. Kim, B.; Min, H.; Heo, J.; Jung, J. Dynamic Computation Offloading Scheme for Drone-Based Surveillance Systems. Sensors 2018, 18, 2982. [Google Scholar] [CrossRef] [PubMed]
  9. Lee, W.; Lee, J.; Lee, J.; Kim, K.; Yoo, S.; Park, S.; Kim, H. Ground Control System Based Routing for Reliable and Efficient Multi-Drone Control System. Appl. Sci. 2018, 8, 2027. [Google Scholar] [CrossRef]
  10. Lee, J.; Kim, K.; Yoo, S.; Chung, A.Y.; Lee, J.Y.; Park, S.J.; Kim, H. Constructing a reliable and fast recoverable network for drones. In Proceedings of the 2016 IEEE International Conference on Communications (ICC), Kuala Lumpur, Malaysia, 22–27 May 2016; pp. 1–6. [Google Scholar]
  11. Nabeel, M.; Yoosuf, M.; Bertino, E. Attribute based group key management. In Proceedings of the 14th ACM Symposium on Access Control Models and Technologies, Stresa, Italy, 3–5 June 2009. [Google Scholar]
  12. Tysowski, P.K.; Hasan, M.A. Hybrid attribute-and re-encryption-based key management for secure and scalable mobile applications in clouds. IEEE Trans. Cloud Comput. 2013, 1, 172–186. [Google Scholar] [CrossRef]
  13. Thomas, R.; Salim, A. A novel decentralized group key management using attribute based encryption. In Proceedings of the 2014 First International Conference on Computational Systems and Communications (ICCSC), Trivandrum, India, 17–18 December 2014; pp. 358–363. [Google Scholar]
  14. Wang, Q.; Yu, C.W.; Li, F.; Wang, H.; Cao, L. A group key-policy attribute-based encryption with partial outsourcing decryption in wireless sensor networks. Secur. Commun. Netw. 2016, 9, 4138–4150. [Google Scholar] [CrossRef]
  15. Mapoka, T.T. Group key management protocols for secure mobile multicast communication: A comprehensive survey. Int. J. Comput. Appl. 2013, 84, 12. [Google Scholar]
  16. Eidkhani, E.; Hajyvahabzadeh, M.; Mortazavi, S.A.; Pour, A.N. CRAW: Combination of Re-Keying and Authentication in Wireless Networks for Secure Multicast Increasing Efficiency of Member Join/Leave and Movement. Int. J. Comput. Netw. Commun. (IJCNC) 2012, 4. [Google Scholar] [CrossRef]
  17. Sandirigama, M.; Shimizu, A.; Noda, M.T. Simple and secure password authentication protocol (SAS). IEICE Trans. Commun. 2000, 83, 1363–1365. [Google Scholar]
  18. Suganthi, N.; Vembu, S. Energy efficient key management scheme for wireless sensor networks. Int. J. Comput. Commun. Control 2014, 9, 71–78. [Google Scholar] [CrossRef]
  19. Li, M.; Yu, S.; Lou, W.; Ren, K. Group device pairing based secure sensor association and key management for body area networks. In Proceedings of the IEEE INFOCOM 2010, San Diego, CA, USA, 14–19 March 2010; pp. 1–9. [Google Scholar]
  20. Zhang, W.; Cao, G. Group rekeying for filtering false data in sensor networks: A predistribution and local collaboration-based approach. In Proceedings of the IEEE INFOCOM 2005, Miami, FL, USA, 13–17 March 2005; pp. 503–514. [Google Scholar]
  21. Rams, T.; Pacyna, P. A survey of group key distribution schemes with self-healing property. IEEE Commun. Surv. Tutor. 2013, 15, 820–842. [Google Scholar] [CrossRef]
  22. Chen, H.; Xie, L. Improved one-way hash chain and revocation polynomial-based self-healing group key distribution schemes in resource-constrained wireless networks. Sensors 2014, 14, 24358–24380. [Google Scholar] [CrossRef] [PubMed]
  23. Sun, X.; Wu, X.; Huang, C.; Xu, Z.; Zhong, J. Modified access polynomial based self-healing key management schemes with broadcast authentication and enhanced collusion resistance in wireless sensor networks. Ad Hoc Netw. 2016, 37, 324–336. [Google Scholar] [CrossRef]
  24. Chen, Y.R.; Tygar, J.; Tzeng, W.G. Secure group key management using uni-directional proxy re-encryption schemes. In Proceedings of the IEEE INFOCOM 2011, Shanghai, China, 10–15 April 2011; pp. 1952–1960. [Google Scholar]
  25. Abdallah, A.; Ali, M.Z.; Mišić, J.; Mišić, V.B. Efficient Security Scheme for Disaster Surveillance UAV Communication Networks. Information 2019, 10, 43. [Google Scholar] [CrossRef]
Figure 1. The procedure of the group key renewal protocol.
Figure 1. The procedure of the group key renewal protocol.
Sensors 19 02066 g001
Figure 2. Example of the key renewal protocol.
Figure 2. Example of the key renewal protocol.
Sensors 19 02066 g002
Figure 3. The procedure of the node’s withdrawal and re-participation protocol.
Figure 3. The procedure of the node’s withdrawal and re-participation protocol.
Sensors 19 02066 g003
Figure 4. The procedure of the drone delegation system.
Figure 4. The procedure of the drone delegation system.
Sensors 19 02066 g004
Figure 5. The simulation result based on the experimental data about the key renewal protocol.
Figure 5. The simulation result based on the experimental data about the key renewal protocol.
Sensors 19 02066 g005
Figure 6. The result for battery power level over time on an operational scenario.
Figure 6. The result for battery power level over time on an operational scenario.
Sensors 19 02066 g006
Table 1. Notations for the communication protocol and key renewal protocol.
Table 1. Notations for the communication protocol and key renewal protocol.
E s m s g , k Encrypt plaintext m s g using symmetric key k
D s e m s g , k Decrypt ciphertext e m s g using symmetric key k
h n · Hash chains with n rounds
i d x Identification of drone x
p i d x Identification of drone x’s parent
h i , i d A hop count of drone i d at session i
r x A random nonce generated by x
S A set of sending nodes
R A set of next-hop receiving nodes
n l x A list of neighbor of node x
Table 2. Notations for withdrawal and re-participation.
Table 2. Notations for withdrawal and re-participation.
N b / N d The breakaway node/the first discovered node
f d x A drone flight data with temporary session x
t x A timestamp
r p o s x , t The real position of node x at time t
s p o s x , t The scheduled position of node x at time t
d t h The distance threshold which follows the system settings
t t h The breakaway time threshold
k ˜ One-time session key between N b and GCS
λ Maximum of temporary session number of N b
h n x , y Hash chain functions each hashing input is previousresult x concatenated y for n times
e t h An average cross track error threshold
Δ t h Distance threshold during one temporal session
Table 3. Notations used in the delegation system.
Table 3. Notations used in the delegation system.
Sig x , y Signing a message x with key y
s k x / p k x The private key of x/the public key of x
f x , y Keyed hash function (x is message, y is key)
k x y Shared key between node x and y
c max A maximum command counter
A A set of nearest nodes for each delegated node
Table 4. Comparison between our proposed system and some previous works.
Table 4. Comparison between our proposed system and some previous works.
CriteriaOursGDP [19]C-PCGR [20]Chen’s [24]
Symmetric key-based×
Capture resistant××
For-/backward secrecy Δ ×
Key independence××
Multi-hop communication×
Msg. broadcasting support×
Mobility support Δ × Δ
Delegation support×××
Table 5. Complexity analysis between our proposed system and some previous works.
Table 5. Complexity analysis between our proposed system and some previous works.
Criteria for Each DroneOursGDP [19]C-PCGR [20]Chen’s [24]
Data sent (bits) w + L + 3 N w 2 N L 2 n L L + 8 w L ( 2 log N 1 )
computational overhead1 encryption, 1 decryption, 2 log N hashings1 decryption, 2 hashings, t multiplications and t 2 powers over F ( q ) N decryptions, o ( μ 3 ) multiplications and divisions over F ( q ) log N public key encryptions, 1 public key decryption
Storage usage (bits)L N ( N 1 ) 2 + 1 L ( 2 N + 1 ) ( t + 1 ) L L ( 1 + log N )
Table 6. The experiment result for computation and networking overhead.
Table 6. The experiment result for computation and networking overhead.
ComputationNetworking
hash chainAESbroadcast
mean (ms)1.103.8326.9
std. (ms)0.691.025.93
Table 7. The simulation result for energy consumption.
Table 7. The simulation result for energy consumption.
Hashenc/decTrans.KRP
30 min (mAh)1.232.6615.9523.73
M600 Pro (%)0.0270.0590.350.53

Share and Cite

MDPI and ACS Style

Bae, M.; Kim, H. Authentication and Delegation for Operating a Multi-Drone System. Sensors 2019, 19, 2066. https://doi.org/10.3390/s19092066

AMA Style

Bae M, Kim H. Authentication and Delegation for Operating a Multi-Drone System. Sensors. 2019; 19(9):2066. https://doi.org/10.3390/s19092066

Chicago/Turabian Style

Bae, Mungyu, and Hwangnam Kim. 2019. "Authentication and Delegation for Operating a Multi-Drone System" Sensors 19, no. 9: 2066. https://doi.org/10.3390/s19092066

APA Style

Bae, M., & Kim, H. (2019). Authentication and Delegation for Operating a Multi-Drone System. Sensors, 19(9), 2066. https://doi.org/10.3390/s19092066

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop