Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to main content

Adaptive-ID Secure Hierarchical ID-Based Authenticated Key Exchange Under Standard Assumptions Without Random Oracles

  • Conference paper
  • First Online:
Applied Cryptography and Network Security (ACNS 2021)

Part of the book series: Lecture Notes in Computer Science ((LNSC,volume 12726))

Included in the following conference series:

Abstract

Hierarchical ID-based authenticated key exchange (HID-AKE) is a cryptographic protocol to establish a common session key between parties with authentication based on their IDs with the hierarchical delegation of key generation functionality. All existing HID-AKE schemes are selective ID secure, and the only known standard model scheme relies on a non-standard assumption such as the q-type assumption. In this paper, we propose a generic construction of HID-AKE that is adaptive ID secure in the HID-eCK model (maximal-exposure-resilient security model) without random oracles. One of the concrete instantiations of our generic construction achieves the first adaptive ID secure HID-AKE scheme under the (standard) k-lin assumption in the standard model. Furthermore, it has the advantage that the computational complexity of pairing and exponentiation operations and the communication complexity do not depend on the depth of the hierarchy. Also, the other concrete instantiation achieves the first HID-AKE scheme based on lattices (i.e., post-quantum).

This is a preview of subscription content, log in via an institution to check access.

Access this chapter

Subscribe and save

Springer+ Basic
$34.99 /Month
  • Get 10 units per month
  • Download Article/Chapter or eBook
  • 1 Unit = 1 Article or 1 Chapter
  • Cancel anytime
Subscribe now

Buy Now

Chapter
USD 29.95
Price excludes VAT (USA)
  • Available as PDF
  • Read on any device
  • Instant download
  • Own it forever
eBook
USD 39.99
Price excludes VAT (USA)
  • Available as EPUB and PDF
  • Read on any device
  • Instant download
  • Own it forever
Softcover Book
USD 54.99
Price excludes VAT (USA)
  • Compact, lightweight edition
  • Dispatched in 3 to 5 business days
  • Free shipping worldwide - see info

Tax calculation will be finalised at checkout

Purchases are for personal use only

Institutional subscriptions

Similar content being viewed by others

Notes

  1. 1.

    If both SSK and ESK of a party are compromised in the target session, the adversary can obtain the session key trivially. Similarly, if both MSK and ESK are compromised in the target session, the adversary can also compute the session key trivially. We define freshness to consider combinations except this condition.

  2. 2.

    However, the number of multiplications depends on \(\ell \).

References

  1. Fujioka, A., Suzuki, K., Yoneyama, K.: Hierarchical ID-Based authenticated key exchange resilient to ephemeral key leakage. IEICE Trans. Fundam. Electron. Commun. Comput. Sci. 94–A(6), 1306–1317 (2011)

    Article  Google Scholar 

  2. Yoneyama, K.: Practical and exposure-resilient hierarchical ID-Based authenticated key exchange without random oracles. IEICE Trans. Fundam. Electron. Commun. Comput. Sci. 97–A(6), 1335–1344 (2014)

    Article  Google Scholar 

  3. Fujioka, A., Suzuki, K., Xagawa, K., Yoneyama, K.: Strongly secure authenticated key exchange from factoring, codes, and lattices. Des. Codes Cryptogr. 76(3), 469–504 (2015)

    Article  MathSciNet  Google Scholar 

  4. Langrehr, R., Pan, J.: Tightly secure hierarchical identity-based encryption. PKC 1, 436–465 (2019)

    MathSciNet  MATH  Google Scholar 

  5. Blazy, O., Kiltz, E., Pan, J.: (Hierarchical) identity-based encryption from affine message authentication. In: Garay, J.A., Gennaro, R. (eds.) CRYPTO 2014. LNCS, vol. 8616, pp. 408–425. Springer, Heidelberg (2014). https://doi.org/10.1007/978-3-662-44371-2_23

    Chapter  Google Scholar 

  6. Boneh, D., Canetti, R., Halevi, S., Katz, J.: Chosen-ciphertext security from identity-based encryption. SIAM J. Comput. 36(5), 1301–1328 (2007)

    Article  MathSciNet  Google Scholar 

  7. Mohassel, P.: One-time signatures and chameleon hash functions. In: Biryukov, A., Gong, G., Stinson, D.R. (eds.) SAC 2010. LNCS, vol. 6544, pp. 302–319. Springer, Heidelberg (2011). https://doi.org/10.1007/978-3-642-19574-7_21

    Chapter  Google Scholar 

  8. LaMacchia, B., Lauter, K., Mityagin, A.: Stronger security of authenticated key exchange. In: Susilo, W., Liu, J.K., Mu, Y. (eds.) ProvSec 2007. LNCS, vol. 4784, pp. 1–16. Springer, Heidelberg (2007). https://doi.org/10.1007/978-3-540-75670-5_1

    Chapter  MATH  Google Scholar 

  9. Agrawal, S., Boneh, D., Boyen, X.: Efficient lattice (H)IBE in the standard model. In: Gilbert, H. (ed.) EUROCRYPT 2010. LNCS, vol. 6110, pp. 553–572. Springer, Heidelberg (2010). https://doi.org/10.1007/978-3-642-13190-5_28

    Chapter  MATH  Google Scholar 

  10. Lyubashevsky, V., Micciancio, D.: Asymptotically efficient lattice-based digital signatures. J. Cryptol 31(3), 774–797 (2018)

    Article  MathSciNet  Google Scholar 

  11. Peikert, C.: Lattice cryptography for the internet. In: Mosca, M. (ed.) PQCrypto 2014. LNCS, vol. 8772, pp. 197–219. Springer, Cham (2014). https://doi.org/10.1007/978-3-319-11659-4_12

    Chapter  MATH  Google Scholar 

  12. Boneh, D., Franklin, M.: Identity-based encryption from the Weil pairing. In: Kilian, J. (ed.) CRYPTO 2001. LNCS, vol. 2139, pp. 213–229. Springer, Heidelberg (2001). https://doi.org/10.1007/3-540-44647-8_13

    Chapter  Google Scholar 

  13. Boneh, D., Boyen, X.: Efficient selective-ID secure identity-based encryption without random oracles. In: Cachin, C., Camenisch, J.L. (eds.) EUROCRYPT 2004. LNCS, vol. 3027, pp. 223–238. Springer, Heidelberg (2004). https://doi.org/10.1007/978-3-540-24676-3_14

    Chapter  Google Scholar 

  14. Waters, B.: Efficient identity-based encryption without random oracles. In: Cramer, R. (ed.) EUROCRYPT 2005. LNCS, vol. 3494, pp. 114–127. Springer, Heidelberg (2005). https://doi.org/10.1007/11426639_7

    Chapter  Google Scholar 

  15. Gentry, C., Silverberg, A.: Hierarchical ID-based cryptography. In: Zheng, Y. (ed.) ASIACRYPT 2002. LNCS, vol. 2501, pp. 548–566. Springer, Heidelberg (2002). https://doi.org/10.1007/3-540-36178-2_34

    Chapter  Google Scholar 

  16. Yoneyama, K.: One-round authenticated key exchange without implementation tricks. J. Inf. Process. 24(1), 9–19 (2016)

    Google Scholar 

Download references

Author information

Authors and Affiliations

Authors

Corresponding author

Correspondence to Ren Ishibashi .

Editor information

Editors and Affiliations

A Proof of Other Events

A Proof of Other Events

1.1 A.1 Event \(E_2 \wedge Suc\)

The proof in this case is essentially the same as the event \(E_1 \wedge Suc\). There is a difference in the experiment \(H_3\). For the computation of \(s^*\) in the \(i^*\)-th session, in the event \(E_1 \wedge Suc\), instead of \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\), it is changed as \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {RF}(r^{'*})\). In the event \(E_2 \wedge Suc\), it is changed as \(s^* = \mathsf {RF}(esk^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\). Since \(\mathcal {A}\) cannot obtain \(r^{*}\) of the initiator by the freshness definition in this event, we can construct a distinguisher \(\mathcal {D}\) from \(\mathcal {A}\) in the similar manner in the proof of the event \(E_1 \wedge Suc\).

1.2 A.2 Event \(E_3 \wedge Suc\)

The proof in this case is essentially the same as the event \(E_1 \wedge Suc\). There is a difference in the experiment \(H_3\) and \(H_4\). For the computation of the initiator’s \(s^*\) in the \(i^*\)-th session, in \(H_3\) of the event \(E_1 \wedge Suc\), instead of \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\), it is changed as \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {RF}(r^{'*})\). In \(H_3\) of the event \(E_3 \wedge Suc\), it is changed as \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {RF}(r^{'*})\) for the computation of the responder’s \(s^*\) in the \(i^*\)-th session. For the computation of the initiator’s \(K^{*}\) in the \(i^*\)-th session, in \(H_4\) of the event \(E_1 \wedge Suc\), \((C^{*}, K^{*}) \leftarrow \mathsf {EnCap}(ID^*; s^{*})\), where \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {RF}(r^{'*})\), it is changed as choosing \(K^{*} \leftarrow \mathcal {KS}\) randomly. In \(H_4\) of the event \(E_3 \wedge Suc\), it is changed as choosing \(K^{*} \leftarrow \mathcal {KS}\) randomly for the computation of the responder’s \(K^{*}\) in the \(i^*\)-th session. Since \(\mathcal {A}\) cannot obtain \(esk^{'*}\) of the responder by the freshness definition in this event, we can construct a distinguisher \(\mathcal {D}\) from \(\mathcal {A}\) in the similar manner in the proof of the event \(E_1 \wedge Suc\).

1.3 A.3 Event \(E_4\wedge Suc\)

The proof in this case is essentially the same as the event \(E_2 \wedge Suc\). There is a difference in the experiment \(H_3\) and \(H_4\). For the computation of the initiator’s \(s^*\) in the \(i^*\)-th session, in \(H_3\) of the event \(E_2 \wedge Suc\), instead of \(s^* = \mathsf {F}(esk^*, r^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\), it is changed as \(s^* = \mathsf {RF}(esk^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\). In \(H_3\) of the event \(E_4 \wedge Suc\), it is changed as \(s^* = \mathsf {RF}(esk^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\) for the computation of the responder’s \(s^*\) in the \(i^*\)-th session. For the computation of the initiator’s \(K^{*}\) in the \(i^*\)-th session, in \(H_4\) of the event \(E_2 \wedge Suc\), \((C^{*}, K^{*}) \leftarrow \mathsf {EnCap}(ID^*; s^{*})\), where \(s^* = \mathsf {RF}(esk^*) \oplus \mathsf {F}^{'}(r^{'*}, esk^{'*})\), it is changed as choosing \(K^{*} \leftarrow \mathcal {KS}\) randomly. In \(H_4\) of the event \(E_4 \wedge Suc\), it is changed as choosing \(K^{*} \leftarrow \mathcal {KS}\) randomly for the computation of the responder’s \(K^{*}\) in the \(i^*\)-th session. Since \(\mathcal {A}\) cannot obtain \(r^{*}\) of the responder by the freshness definition in this event, we can construct a distinguisher \(\mathcal {D}\) from \(\mathcal {A}\) in the similar manner in the proof of the event \(E_2 \wedge Suc\).

1.4 A.4 Event \(E_5 \wedge Suc\)

We change the interface of oracle queries and the computation of the session key. These instances are gradually changed over six hybrid experiments, depending on specific subcases. In the last hybrid experiment, the session key in the test session does not contain information of the bit b. Thus, the adversary clearly only outputs a random guess. We denote these hybrid experiments by \(H_0,\dots ,H_5\) and the advantage of the adversary \(\mathcal {A}\) when participating in experiment \(H_i\) by Adv(\(\mathcal {A}, H_i\)).

Hybrid Experiment \(H_0\): This experiment denotes the real experiment for HID-eCK security and in this experiment the environment for \(\mathcal {A}\) is as defined in the protocol. Thus, Adv(\(\mathcal {A}, H_0\)) is the same as the advantage of the real experiment.

Hybrid Experiment \(H_1\): This experiment aborts when sid is matched with multiple sessions.

By the decryption correctness of KEM, the probability of outputting the same ciphertext from different randomness in each session is negligible. Thus, \(|Adv(\mathcal {A}, H_1) - Adv(\mathcal {A}, H_0)| \le negl\).

Hybrid Experiment \(H_2\): This experiment chooses an integer \(i^* \in [1, \ell ]\) in advance and fixes the session to be the target of the \(\mathsf {Test}\) query as the \(i^{*}\)-th session. If \(\mathcal {A}\) queries a session other than the \(i^{*}\)-th in the \(\mathsf {Test}\) query, abort the experiment.

The probability that the guess of the test session is correct is \(1/\ell \), hence \(Adv(\mathcal {A}, H_2)\) \(\ge 1 / \ell \cdot Adv(\mathcal {A}, H_1)\).

Hybrid Experiment \(H_3\): This experiment changes the way of the computation of the \(K^{*}_{T}\) in the \(i^{*}\)-th session. Instead of computing \((C^{*}_{T}, K^{*}_{T}) \leftarrow \mathsf {wEnCap}(ek^{*}_{T},\) \(esk^{*}_{T})\), it is changed as \(K^{*}_{T} \leftarrow \mathcal {KS}\) randomly.

We construct a IND-CPA adversary \(\mathcal {S}\) in \(H_2\) or \(H_3\) from \(\mathcal {A}\). \(\mathcal {S}\) is performs the following steps.

[init]

\(\mathcal {S}\) receives \(ek^{*}_{T}\) as a challenge.

[setup]

\(\mathcal {S}\) chooses \(\mathsf {F}, \mathsf {F}^{'} : \{ 0,1 \}^* \times \mathcal {FS} \rightarrow \mathcal {RS_E}\), \(\mathsf {PRF} : \{ 0,1 \}^* \times \mathcal {KS} \rightarrow \{ 0,1 \}^{\kappa }\), and a KDF \(\mathsf {KDF} : Salt \times \mathcal {KS} \rightarrow \mathcal {FS}\) with a non-secret random salt \(s \in Salt\). These are provided as the public parameters.

\(\mathcal {S}\) sets params as \((params, \mathsf {F}, \mathsf {F^{'}}, \mathsf {PRF}, \mathsf {KDF})\), MPK and MSK.

[simulation]

\(\mathcal {S}\) maintains the list \(L_{SK}\) that contains queries and answers to \(\mathsf {SessionKeyReveal}\). \(\mathcal {S}\) simulates oracle queries by \(\mathcal {A}\) as follows.

  1. 1.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {I}, U_P, U_{\bar{P}}\)) : If the SSK of \(U_P\) is not set, \(\mathcal {S}\) generates and sets the SSK according to the protocol. If the session is the \(i^*\)-th session, \(\mathcal {S}\) receives \((C^{*}_{T}, K^{*}_{Tb})\) as a challenge from the challenger and computes \(C_{\bar{P}}\) according to the protocol. Also, \(\mathcal {S}\) sets \(EPK^{*}=(C_{\bar{P}}, ek^{*}_{T})\) and returns \(EPK^{*}\). Otherwise, \(\mathcal {S}\) computes and returns \(EPK=(C_{\bar{P}}, ek_T)\) according to the protocol and records \((\varPi , U_P, U_{\bar{P}}\), \((C_{\bar{P}}, ek_T))\) in \(L_{SK}\).

  2. 2.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {R}, U_{\bar{P}}, U_P, (C_{\bar{P}}, ek_T)\)) : If the SSK of \(U_{\bar{P}}\) is not set, \(\mathcal {S}\) generates and sets the SSK according to the protocol. If the session is the \(i^*\)-th session, \(\mathcal {S}\) sets \(K_T=K^{*}_{Tb}\), computes \(C_P\) and SK according to the protocol, and returns \(EPK=(C_P, C^{*}_{T})\). Also, \(\mathcal {S}\) records \((\varPi , U_P,U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C^{*}_T))\) as the completed session and SK in \(L_{SK}\). Otherwise, \(\mathcal {S}\) computes \(EPK=(C_P, C_T)\) and SK according to the protocol, returns EPK. Also, \(\mathcal {S}\) records \((\varPi , U_P,U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T))\) as the completed session and SK in \(L_{SK}\).

  3. 3.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {I}, U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T)\)) : If the SSK of \(U_P\) is not set, \(\mathcal {S}\) generates and sets the SSK according to the protocol. If \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T))\) is not recorded in \(L_{SK}\), then \(\mathcal {S}\) records this sid as not completed. Also, if the session is the \(i^*\)-th session, \(\mathcal {S}\) computes SK according to the protocol, except \(K_{T} = K^{*}_{T}\), and records \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T))\) as the completed session and SK in \(L_{SK}\). Otherwise, \(\mathcal {S}\) computes SK and records \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T))\) as the completed session and SK in \(L_{SK}\).

  4. 4.

    \(\mathsf {SessionKeyReveal}\)(sid) :

    1. (a)

      If sid is not completed, then \(\mathcal {S}\) returns error.

    2. (b)

      Otherwise, \(\mathcal {S}\) returns SK as recorded in \(L_{SK}\).

  5. 5.

    \(\mathsf {EphemeralKeyReveal}\)(sid): \(\mathcal {S}\) returns ESK for sid as defined.

  6. 6.

    \(\mathsf {StaticKeyReveal}\)(\(ID_i\)) : If the SSK for \(ID_i\) is not set, \(\mathcal {S}\) generates and sets the SSK according to the protocol. \(\mathcal {S}\) returns the SSK of \(ID_i\) as defined.

  7. 7.

    \(\mathsf {MasterKeyReveal}\)(): \(\mathcal {S}\) returns MSK as defined.

  8. 8.

    \(\mathsf {EstablishParty}\)(\(U_i, ID_i\)): \(\mathcal {S}\) generates and returns SSK for \(ID_i\) according to the protocol and marks \(U_i\) as dishonest.

  9. 9.

    \(\mathsf {Test}\)(\(sid^{*}\)) : \(\mathcal {S}\) responds to the query as defined and gives the \(SSK^{*}\) of the owner and responder of \(sid^{*}\) to \(\mathcal {A}\).

  10. 10.

    If \(\mathcal {A}\) outputs \(b^{'}\), then \(\mathcal {S}\) outputs \(b^{'}\).

[Analysis]

For \(\mathcal {A}\), the simulation by \(\mathcal {S}\) is the same as the experiment \(H_2\) if the challenge is \((C^{*}_{T}, K^{*}_{T0})\). Otherwise, the simulation by \(\mathcal {S}\) is the same as the experiment \(H_3\). Thus, since the advantage of \(\mathcal {S}\) is negligible due to the security of the IND-CPA secure KEM, \(|Adv(\mathcal {A}, H_3) - Adv(\mathcal {A}, H_2)| \le \) negl.

Hybrid Experiment \(H_4\): This experiment changes the way of the computation of the \(\sigma ^{*}_{3}\) in the \(i^{*}\)-th session. Instead of computing \(\sigma ^{*}_{3} \leftarrow \mathsf {KDF}(s,K^{*}_{T})\), it is changed as choosing \(\sigma ^{*}_{3} \in \mathcal {FS}\) randomly.

Since \(K^{*}_{T}\) is randomly chosen in \(H_3\), it has sufficient min-entropy because KEM is \(\delta \)-min-entropy KEM. Thus, by the definition of the KDF, \(|Adv(\mathcal {A}, H_4) - Adv(\mathcal {A}, H_3)| \le \) negl.

Hybrid Experiment \(H_5\): This experiment changes the way of the computation of SK in the \(i^{*}\)-th session. Instead of computing \(SK = \mathsf {PRF}(sid, \sigma _1) \oplus \mathsf {PRF}(sid, \sigma _2) \oplus \mathsf {PRF}(sid, \sigma _3)\), it is changed as \(SK = \mathsf {PRF}(sid, \sigma _1) \oplus \mathsf {PRF}(sid, \sigma _2) \oplus x\) where \(x \in _{R} \{ 0,1 \}^{\kappa }\).

We construct a distinguisher \(\mathcal {D}\) that distinguishes if \(\mathsf {F}^*\) is either a pseudo-random function \(\mathsf {PRF}\) and a random function \(\mathsf {RF}\) from \(\mathcal {A}\) in \(H_4\) or \(H_5\). The \(\mathcal {D}\) performs the following steps.

[setup]

\(\mathcal {D}\) chooses \(\mathsf {F},\mathsf {F}^{'} : \{ 0,1 \}^* \times \mathcal {FS} \rightarrow \mathcal {RS_E}\), \(\mathsf {PRF} : \{ 0,1 \}^* \times \mathcal {KS} \rightarrow \{ 0,1 \}^{\kappa }\), and a KDF \(\mathsf {KDF} : Salt \times \mathcal {KS} \rightarrow \mathcal {FS}\) with a non-secret random salt \(s \in Salt\). These are provided as the public parameters. Also, \(\mathcal {D}\) embeds \(\mathsf {F}^{*}\) into \(\mathsf {PRF}\) of the \(i^*\)-th session.

\(\mathcal {D}\) sets MPK and MSK according to the protocol.

[simulation]

\(\mathcal {D}\) maintains the list \(L_{SK}\) that contains queries and answers to \(\mathsf {SessionKeyReveal}\). \(\mathcal {D}\) simulates oracle queries by \(\mathcal {A}\) as follows.

  1. 1.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {I}, U_P, U_{\bar{P}}\)) : If the SSK of \(U_P\) is not set, \(\mathcal {D}\) generates and sets the SSK according to the protocol. \(\mathcal {D}\) computes and returns \(EPK=(C_{\bar{P}}, ek_T)\) according to the protocol, and records \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T))\) in \(L_{SK}\).

  2. 2.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {R}, U_{\bar{P}}, U_P, (C_{\bar{P}}, ek_T)\)) : If the SSK of \(U_{\bar{P}}\) is not set, \(\mathcal {D}\) generates and sets the SSK according to the protocol. \(\mathcal {D}\) computes \(EPK=(C_P, C_T)\) and SK according to the protocol, returns EPK, and records \((\Pi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T))\) as the completed session and SK in \(L_{SK}\).

  3. 3.

    \(\mathsf {Send}\)(\(\varPi , \mathcal {I}, U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P, C_T)\)) : If the SSK of \(U_P\) is not set, \(\mathcal {D}\) generates and sets the SSK according to the protocol. If \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T))\) is not recorded in \(L_{SK}\), then \(\mathcal {D}\) records this sid as not completed. Also, if the session is the \(i^*\)-th session, \(\mathcal {D}\) poses sid to oracle \(\mathsf {F^{*}}\) (\(\mathsf {PRF^{'}}\) or \(\mathsf {RF}\)) and obtains \(x \in \{ 0,1 \}^{\kappa }\), and computes \(SK^{*}=\mathsf {PRF}(sid, \sigma _1) \oplus \mathsf {PRF}(sid, \sigma _2) \oplus x\). Also \(\mathcal {D}\) records \((\Pi , U_A, U_B, (C ^{*}_{B}, ek^{*}_{T}), (C_A, C_T))\) as the completed session and SK in \(L_{SK}\). Otherwise, \(\mathcal {D^{'}}\) computes SK, and records \((\varPi , U_P, U_{\bar{P}}, (C_{\bar{P}}, ek_T), (C_P,\) \(C_T))\) as the completed session and SK in \(L_{SK}\).

  4. 4.

    \(\mathsf {SessionKeyReveal}\)(sid) :

    1. (a)

      If sid is not completed, then \(\mathcal {D}\) returns error.

    2. (b)

      Otherwise, \(\mathcal {D}\) returns SK as recorded in \(L_{SK}\).

  5. 5.

    \(\mathsf {EphemeralKeyReveal}\)(sid) : \(\mathcal {D}\) returns ESK for sid as defined.

  6. 6.

    \(\mathsf {StaticKeyReveal}\)(\(ID_i\)) : If the SSK for \(ID_i\) is not set, \(\mathcal {D}\) generates and sets the SSK according to the protocol. \(\mathcal {D}\) returns the SSK as defined.

  7. 7.

    \(\mathsf {MasterKeyReveal}\)(): \(\mathcal {D}\) returns MSK as defined.

  8. 8.

    \(\mathsf {EstablishParty}\)(\(U_i, ID_i\)) : \(\mathcal {D}\) generates and returns SSK for \(ID_i\) according to the protocol and marks \(U_i\) as dishonest.

  9. 9.

    \(\mathsf {Test}\)(\(sid^{*}\)) : \(\mathcal {D}\) responds to the query as defined and gives the \(SSK^{*}\) of the owner of \(sid^{*}\) to \(\mathcal {A}\).

  10. 10.

    \(\mathcal {A}\) outputs a guess \(b^{'} \in \{ 0,1 \}\). If \(\mathcal {A}\) outputs \(b^{'} = 0\), then \(\mathcal {D}\) outputs that \(\mathsf {F}^{*}=\mathsf {PRF}\). Otherwise \(\mathcal {D}\) outputs that \(\mathsf {F}^{*}=\mathsf {RF}\).

[Analysis]

For \(\mathcal {A}\), the simulation by \(\mathcal {D}\) is the same as the experiment \(H_4\) if \(\mathsf {F}^{*}=\mathsf {PRF}\). Otherwise, the simulation by \(\mathcal {D}\) is the same as the experiment \(H_5\). Thus, since the advantage of \(\mathcal {D}\) is negligible due to the security of the PRF, \(|Adv(\mathcal {A}, H_5) - Adv(\mathcal {A}, H_4)| \le negl\).

In \(H_5\), the session key in the test session is perfectly randomized. This gives \(\mathcal {A}\) no information from the \(\mathsf {Test}\) query, therefore \(Adv(\mathcal {A}, H_5) = 0\) and \(\Pr [E_5 \wedge Sec] = negl\).

1.5 A.5 Event \(E_6 \wedge Suc\)

The proof in this case is essentially the same as the event \(E_2 \wedge Suc\). The situation that the ephemeral secret key of \(\overline{sid^*}\) is given to \(\mathcal {A}\) is the same as \(sid^{*}\) has no matching session because \(\mathcal {A}\) can decide arbitrary ephemeral key. Thus, the proof in this event follows that in the event \(E_2 \wedge Suc\).

1.6 A.6 Event \(E_7 \wedge Suc\)

The proof in this case is essentially the same as the event \(E_1 \wedge Suc\). The situation that the ephemeral secret key of \(\overline{sid^*}\) is given to \(\mathcal {A}\) is the same as \(sid^{*}\) has no matching session because \(\mathcal {A}\) can decide arbitrary ephemeral key. Thus, the proof in this event follows that in the event \(E_1 \wedge Suc\).

1.7 A.7 Event \(E_8 \wedge Suc\)

The proof in this case is essentially the same as the event \(E_3 \wedge Suc\). The situation that the ephemeral secret key of \(sid^*\) is given to \(\mathcal {A}\) is the same as \(sid^{*}\) has no matching session because \(\mathcal {A}\) can decide arbitrary ephemeral key. Thus, the proof in this event follows that in the event \(E_3 \wedge Suc\).

Rights and permissions

Reprints and permissions

Copyright information

© 2021 Springer Nature Switzerland AG

About this paper

Check for updates. Verify currency and authenticity via CrossMark

Cite this paper

Ishibashi, R., Yoneyama, K. (2021). Adaptive-ID Secure Hierarchical ID-Based Authenticated Key Exchange Under Standard Assumptions Without Random Oracles. In: Sako, K., Tippenhauer, N.O. (eds) Applied Cryptography and Network Security. ACNS 2021. Lecture Notes in Computer Science(), vol 12726. Springer, Cham. https://doi.org/10.1007/978-3-030-78372-3_1

Download citation

  • DOI: https://doi.org/10.1007/978-3-030-78372-3_1

  • Published:

  • Publisher Name: Springer, Cham

  • Print ISBN: 978-3-030-78371-6

  • Online ISBN: 978-3-030-78372-3

  • eBook Packages: Computer ScienceComputer Science (R0)

Publish with us

Policies and ethics