1
0
mirror of https://github.com/kepler155c/opus synced 2025-01-23 05:36:53 +00:00
opus/sys/apps/network/trust.lua

47 lines
1.2 KiB
Lua
Raw Normal View History

local Crypto = require('opus.crypto.chacha20')
local Event = require('opus.event')
local Security = require('opus.security')
local Socket = require('opus.socket')
local Util = require('opus.util')
2017-05-05 11:34:20 +00:00
2019-06-29 20:35:33 +00:00
local trustId = '01c3ba27fe01383a03a1785276d99df27c3edcef68fbf231ca'
2019-04-20 17:48:13 +00:00
local function trustConnection(socket)
local data = socket:read(2)
if data then
local password = Security.getPassword()
if not password then
socket:write({ msg = 'No password has been set' })
else
2019-07-02 00:39:34 +00:00
local s
s, data = pcall(Crypto.decrypt, data, password)
if s and data and data.pk and data.dh == socket.dhost then
2019-04-20 17:48:13 +00:00
local trustList = Util.readTable('usr/.known_hosts') or { }
2019-06-29 20:35:33 +00:00
trustList[data.dh] = data.pk
2019-04-20 17:48:13 +00:00
Util.writeTable('usr/.known_hosts', trustList)
socket:write({ success = true, msg = 'Trust accepted' })
else
socket:write({ msg = 'Invalid password' })
end
end
end
end
2017-08-03 05:46:39 +00:00
Event.addRoutine(function()
2018-01-24 22:39:38 +00:00
print('trust: listening on port 19')
2018-01-24 22:39:38 +00:00
while true do
2019-06-29 20:35:33 +00:00
local socket = Socket.server(19, { identifier = trustId })
2017-05-05 11:34:20 +00:00
2018-01-24 22:39:38 +00:00
print('trust: connection from ' .. socket.dhost)
2017-05-05 11:34:20 +00:00
2019-04-20 17:48:13 +00:00
local s, m = pcall(trustConnection, socket)
2018-01-24 22:39:38 +00:00
socket:close()
2019-04-20 17:48:13 +00:00
if not s and m then
print('Trust error')
_G.printError(m)
end
2018-01-24 22:39:38 +00:00
end
2017-05-05 11:34:20 +00:00
end)