feat: tls-psk

This commit is contained in:
unknown
2023-02-16 09:52:18 +09:00
parent 480aef1626
commit 842380caf6
5 changed files with 230 additions and 3 deletions

29
samples/psk/client.lua Normal file
View File

@ -0,0 +1,29 @@
--
-- Public domain
--
local socket = require("socket")
local ssl = require("ssl")
local params = {
mode = "client",
protocol = "tlsv1_2",
psk = function(hint, max_psk_len)
print("PSK Callback: hint=", hint, ", max_psk_len=", max_psk_len)
return "abcd", "1234"
end
}
local peer = socket.tcp()
peer:connect("127.0.0.1", 8888)
peer = assert( ssl.wrap(peer, params) )
assert(peer:dohandshake())
print("--- INFO ---")
local info = peer:info()
for k, v in pairs(info) do
print(k, v)
end
print("---")
peer:close()

42
samples/psk/server.lua Normal file
View File

@ -0,0 +1,42 @@
--
-- Public domain
--
local socket = require("socket")
local ssl = require("ssl")
local params = {
mode = "server",
protocol = "any",
options = "all",
psk = function(identity, max_psk_len)
print("PSK Callback: identity=", identity, ", max_psk_len=", max_psk_len)
if identity == "abcd" then
return "1234"
end
return nil
end
}
-- [[ SSL context
local ctx = assert(ssl.newcontext(params))
--]]
local server = socket.tcp()
server:setoption('reuseaddr', true)
assert( server:bind("127.0.0.1", 8888) )
server:listen()
local peer = server:accept()
peer = assert( ssl.wrap(peer, ctx) )
assert( peer:dohandshake() )
print("--- INFO ---")
local info = peer:info()
for k, v in pairs(info) do
print(k, v)
end
print("---")
peer:close()
server:close()