1
0
mirror of https://github.com/kepler155c/opus synced 2025-01-03 20:30:28 +00:00

network group wip + virtual dirs + better trust

This commit is contained in:
kepler155c@gmail.com 2019-04-08 09:30:47 -04:00
parent 9413785248
commit 70733ab4f2
8 changed files with 92 additions and 31 deletions

View File

@ -1,20 +1,18 @@
local Config = require('config') local Config = require('config')
local config = { }
local Security = { } local Security = { }
function Security.verifyPassword(password) function Security.verifyPassword(password)
Config.load('os', config) local current = Security.getPassword()
return config.password and password == config.password return current and password == current
end end
function Security.hasPassword() function Security.hasPassword()
return not not config.password return not not Security.getPassword()
end end
function Security.getSecretKey() function Security.getSecretKey()
Config.load('os', config) local config = Config.load('os')
if not config.secretKey then if not config.secretKey then
config.secretKey = math.random(100000, 999999) config.secretKey = math.random(100000, 999999)
Config.update('os', config) Config.update('os', config)
@ -23,7 +21,6 @@ function Security.getSecretKey()
end end
function Security.getPublicKey() function Security.getPublicKey()
local exchange = { local exchange = {
base = 11, base = 11,
primeMod = 625210769 primeMod = 625210769
@ -47,14 +44,13 @@ function Security.getPublicKey()
end end
function Security.updatePassword(password) function Security.updatePassword(password)
Config.load('os', config) local config = Config.load('os')
config.password = password config.password = password
Config.update('os', config) Config.update('os', config)
end end
function Security.getPassword() function Security.getPassword()
Config.load('os', config) return Config.load('os').password
return config.password
end end
return Security return Security

View File

@ -105,7 +105,7 @@ end
function Socket.connect(host, port) function Socket.connect(host, port)
if not device.wireless_modem then if not device.wireless_modem then
return false, 'Wireless modem not found' return false, 'Wireless modem not found', 'NOMODEM'
end end
local socket = newSocket(host == os.getComputerID()) local socket = newSocket(host == os.getComputerID())
@ -138,15 +138,19 @@ function Socket.connect(host, port)
_G.transport.open(socket) _G.transport.open(socket)
return socket return socket
elseif msg.type == 'NOPASS' then
socket:close()
return false, 'Password not set on target', 'NOPASS'
elseif msg.type == 'REJE' then elseif msg.type == 'REJE' then
socket:close() socket:close()
return false, 'Password not set on target or not trusted' return false, 'Trust not established', 'NOTRUST'
end end
end end
until e == 'timer' and id == timerId until e == 'timer' and id == timerId
socket:close() socket:close()
return false, 'Connection timed out' return false, 'Connection timed out', 'TIMEOUT'
end end
local function trusted(msg, port) local function trusted(msg, port)
@ -190,7 +194,15 @@ function Socket.server(port)
socket.wseq = msg.wseq socket.wseq = msg.wseq
socket.rseq = msg.rseq socket.rseq = msg.rseq
if trusted(msg, port) then if not Security.hasPassword() then
socket.transmit(socket.dport, socket.sport, {
type = 'NOPASS',
dhost = socket.dhost,
shost = socket.shost,
})
socket:close()
elseif trusted(msg, port) then
socket.connected = true socket.connected = true
socket.transmit(socket.dport, socket.sport, { socket.transmit(socket.dport, socket.sport, {
type = 'CONN', type = 'CONN',
@ -201,8 +213,8 @@ function Socket.server(port)
_G.transport.open(socket) _G.transport.open(socket)
return socket return socket
end
else
socket.transmit(socket.dport, socket.sport, { socket.transmit(socket.dport, socket.sport, {
type = 'REJE', type = 'REJE',
dhost = socket.dhost, dhost = socket.dhost,
@ -212,5 +224,6 @@ function Socket.server(port)
end end
end end
end end
end
return Socket return Socket

View File

@ -1,4 +1,5 @@
local Ansi = require('ansi') local Ansi = require('ansi')
local Config = require('config')
local Security = require('security') local Security = require('security')
local SHA1 = require('sha1') local SHA1 = require('sha1')
local UI = require('ui') local UI = require('ui')
@ -53,7 +54,7 @@ local page = UI.Page {
}, },
password = UI.WizardPage { password = UI.WizardPage {
index = 3, index = 3,
labelText = UI.Text { passwordLabel = UI.Text {
x = 3, y = 2, x = 3, y = 2,
value = 'Password' value = 'Password'
}, },
@ -62,14 +63,22 @@ local page = UI.Page {
limit = 32, limit = 32,
mask = true, mask = true,
shadowText = 'password', shadowText = 'password',
accelerators = {
enter = 'new_password',
}, },
--[[
groupLabel = UI.Text {
x = 3, y = 3,
value = 'Group'
}, },
group = UI.TextEntry {
x = 12, ex = -3, y = 3,
limit = 32,
shadowText = 'network group',
},
]]
intro = UI.TextArea { intro = UI.TextArea {
textColor = colors.yellow, textColor = colors.yellow,
inactive = true, inactive = true,
x = 3, ex = -3, y = 4, ey = -3, x = 3, ex = -3, y = 5, ey = -3,
value = string.format(passwordIntro, Ansi.white), value = string.format(passwordIntro, Ansi.white),
}, },
}, },
@ -101,6 +110,11 @@ function page.wizard.pages.password:validate()
if #self.newPass.value > 0 then if #self.newPass.value > 0 then
Security.updatePassword(SHA1.sha1(self.newPass.value)) Security.updatePassword(SHA1.sha1(self.newPass.value))
end end
if #self.group.value > 0 then
local config = Config.load('os')
config.group = self.group.value
Config.update('os', config)
end
return true return true
end end

View File

@ -141,6 +141,7 @@ local function sendInfo()
infoTimer = os.clock() infoTimer = os.clock()
info.label = os.getComputerLabel() info.label = os.getComputerLabel()
info.uptime = math.floor(os.clock()) info.uptime = math.floor(os.clock())
info.group = network.getGroup()
if turtle then if turtle then
info.fuel = turtle.getFuelLevel() info.fuel = turtle.getFuelLevel()
info.status = turtle.getStatus() info.status = turtle.getStatus()

View File

@ -24,12 +24,23 @@ if multishell then
multishell.setTitle(multishell.getCurrent(), 'Telnet ' .. remoteId) multishell.setTitle(multishell.getCurrent(), 'Telnet ' .. remoteId)
end end
local socket, msg = Socket.connect(remoteId, 23) local socket, msg, reason
if not socket then while true do
socket, msg, reason = Socket.connect(remoteId, 23)
if socket then
break
elseif reason ~= 'NOTRUST' then
error(msg) error(msg)
end end
local s, m = shell.run('trust ' .. remoteId)
if not s then
error(m)
end
end
local ct = Util.shallowCopy(term.current()) local ct = Util.shallowCopy(term.current())
if not ct.isColor() then if not ct.isColor() then
Terminal.toGrayscale(ct) Terminal.toGrayscale(ct)

View File

@ -6,6 +6,7 @@ local Util = require('util')
local colors = _G.colors local colors = _G.colors
local multishell = _ENV.multishell local multishell = _ENV.multishell
local os = _G.os local os = _G.os
local shell = _ENV.shell
local term = _G.term local term = _G.term
local remoteId local remoteId
@ -26,7 +27,15 @@ if multishell then
end end
local function connect() local function connect()
local socket, msg = Socket.connect(remoteId, 5900) local socket, msg, reason = Socket.connect(remoteId, 5900)
if reason == 'NOTRUST' then
local s, m = shell.run('trust ' .. remoteId)
if not s then
return s, m
end
socket, msg = Socket.connect(remoteId, 5900)
end
if not socket then if not socket then
return false, msg return false, msg

View File

@ -5,6 +5,8 @@ end
_G.requireInjector(_ENV) _G.requireInjector(_ENV)
local Util = require('util') local Util = require('util')
-- TODO: support getDrive for virtual nodes
local fs = _G.fs local fs = _G.fs
fs.native = Util.shallowCopy(fs) fs.native = Util.shallowCopy(fs)
@ -88,6 +90,13 @@ function nativefs.exists(node, dir)
return fs.native.exists(dir) return fs.native.exists(dir)
end end
function nativefs.getDrive(node, dir)
if node.mountPoint == dir then
return fs.native.getDrive(dir) or 'virt'
end
return fs.native.getDrive(dir)
end
function nativefs.delete(node, dir) function nativefs.delete(node, dir)
if node.mountPoint == dir then if node.mountPoint == dir then
fs.unmount(dir) fs.unmount(dir)

View File

@ -6,7 +6,15 @@ local device = _G.device
local kernel = _G.kernel local kernel = _G.kernel
local os = _G.os local os = _G.os
_G.network = { } do
local config = Config.load('os')
_G.network = setmetatable({ }, { __index = {
getGroup = function() return config.group end,
setGroup = function(name)
config.group = name
end
}})
end
local function startNetwork() local function startNetwork()
kernel.run({ kernel.run({