mirror of https://github.com/arendst/Tasmota.git
Matter CASE Sigma1 resumption mode for faster reconnection (#21644)
This commit is contained in:
parent
d3f8afed29
commit
bdfe3524a9
|
@ -21,6 +21,7 @@ All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
- Matter interverted attributes 0xFFF9 and 0xFFFB (#21636)
|
- Matter interverted attributes 0xFFF9 and 0xFFFB (#21636)
|
||||||
|
- Matter CASE Sigma1 resumption mode for faster reconnection
|
||||||
|
|
||||||
### Removed
|
### Removed
|
||||||
|
|
||||||
|
|
|
@ -334,9 +334,6 @@ class Matter_Commisioning_Context
|
||||||
|
|
||||||
# find session
|
# find session
|
||||||
var is_resumption = (sigma1.resumptionID != nil && sigma1.initiatorResumeMIC != nil)
|
var is_resumption = (sigma1.resumptionID != nil && sigma1.initiatorResumeMIC != nil)
|
||||||
# log(format("MTR: is_resumption=%i", is_resumption ? 1 : 0), 4)
|
|
||||||
# TODO disable resumption until fixed
|
|
||||||
is_resumption = false
|
|
||||||
|
|
||||||
# Check that it's a resumption
|
# Check that it's a resumption
|
||||||
var session_resumption
|
var session_resumption
|
||||||
|
@ -344,6 +341,7 @@ class Matter_Commisioning_Context
|
||||||
session_resumption = self.device.sessions.find_session_by_resumption_id(sigma1.resumptionID)
|
session_resumption = self.device.sessions.find_session_by_resumption_id(sigma1.resumptionID)
|
||||||
# log(format("MTR: session_resumption found session=%s session_resumption=%s", matter.inspect(session), matter.inspect(session_resumption)), 4)
|
# log(format("MTR: session_resumption found session=%s session_resumption=%s", matter.inspect(session), matter.inspect(session_resumption)), 4)
|
||||||
if session_resumption == nil || session_resumption._fabric == nil
|
if session_resumption == nil || session_resumption._fabric == nil
|
||||||
|
log(f"MTR: Sigma1 Resumption FAILED, session not found resumption_id={sigma1.resumptionID}", 3)
|
||||||
is_resumption = false
|
is_resumption = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -363,6 +361,8 @@ class Matter_Commisioning_Context
|
||||||
var decrypted_tag = ec.tag()
|
var decrypted_tag = ec.tag()
|
||||||
|
|
||||||
# log("****************************************", 4)
|
# log("****************************************", 4)
|
||||||
|
# log("MTR: * initiatorRandom = " + sigma1.initiatorRandom.tohex(), 4)
|
||||||
|
# log("MTR: * ResumptionID = " + session_resumption.resumption_id.tohex(), 4)
|
||||||
# log("MTR: * s1rk = " + s1rk.tohex(), 4)
|
# log("MTR: * s1rk = " + s1rk.tohex(), 4)
|
||||||
# log("MTR: * tag = " + tag.tohex(), 4)
|
# log("MTR: * tag = " + tag.tohex(), 4)
|
||||||
# log("MTR: * Resume1MICPayload = " + Resume1MICPayload.tohex(), 4)
|
# log("MTR: * Resume1MICPayload = " + Resume1MICPayload.tohex(), 4)
|
||||||
|
@ -392,8 +392,8 @@ class Matter_Commisioning_Context
|
||||||
|
|
||||||
var sigma2resume = matter.Sigma2Resume()
|
var sigma2resume = matter.Sigma2Resume()
|
||||||
sigma2resume.resumptionID = session.resumption_id
|
sigma2resume.resumptionID = session.resumption_id
|
||||||
sigma2resume.responderSessionID = session.__future_local_session_id
|
|
||||||
sigma2resume.sigma2ResumeMIC = Resume2MIC
|
sigma2resume.sigma2ResumeMIC = Resume2MIC
|
||||||
|
sigma2resume.responderSessionID = session.__future_local_session_id
|
||||||
|
|
||||||
# log("****************************************", 4)
|
# log("****************************************", 4)
|
||||||
# log("MTR: * s2rk = " + s2rk.tohex(), 4)
|
# log("MTR: * s2rk = " + s2rk.tohex(), 4)
|
||||||
|
@ -403,8 +403,10 @@ class Matter_Commisioning_Context
|
||||||
# log("MTR: * sigma2ResumeMIC = " + Resume2MIC.tohex(), 4)
|
# log("MTR: * sigma2ResumeMIC = " + Resume2MIC.tohex(), 4)
|
||||||
# log("****************************************", 4)
|
# log("****************************************", 4)
|
||||||
# # compute session key, p.178
|
# # compute session key, p.178
|
||||||
|
var salt_sessions = sigma1.initiatorRandom + session_resumption.resumption_id
|
||||||
|
# log("MTR: * salt_session = " + salt_sessions.tohex(), 4)
|
||||||
var session_keys = crypto.HKDF_SHA256().derive(session.shared_secret #- input key -#,
|
var session_keys = crypto.HKDF_SHA256().derive(session.shared_secret #- input key -#,
|
||||||
sigma1.initiatorRandom + session.resumption_id #- salt -#,
|
salt_sessions #- salt -#,
|
||||||
bytes().fromstring("SessionResumptionKeys") #- info -#,
|
bytes().fromstring("SessionResumptionKeys") #- info -#,
|
||||||
48)
|
48)
|
||||||
var i2r = session_keys[0..15]
|
var i2r = session_keys[0..15]
|
||||||
|
@ -431,6 +433,7 @@ class Matter_Commisioning_Context
|
||||||
|
|
||||||
session.close()
|
session.close()
|
||||||
session.set_keys(i2r, r2i, ac, created)
|
session.set_keys(i2r, r2i, ac, created)
|
||||||
|
session.peer_node_id = session_resumption.peer_node_id # copy peer_node_id from session
|
||||||
|
|
||||||
# CASE Session completed, persist it
|
# CASE Session completed, persist it
|
||||||
session._breadcrumb = 0 # clear breadcrumb
|
session._breadcrumb = 0 # clear breadcrumb
|
||||||
|
@ -440,8 +443,10 @@ class Matter_Commisioning_Context
|
||||||
session.persist_to_fabric()
|
session.persist_to_fabric()
|
||||||
session.save()
|
session.save()
|
||||||
|
|
||||||
|
log("MTR: Sigma1 Resumption SUCCEEDED", 3)
|
||||||
return true
|
return true
|
||||||
else
|
else
|
||||||
|
log("MTR: Sigma1 Resumption FAILED, switching to CASE", 3)
|
||||||
is_resumption = false
|
is_resumption = false
|
||||||
# fall through normal sigma1 (non-resumption)
|
# fall through normal sigma1 (non-resumption)
|
||||||
end
|
end
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue