typo + lock screen

This commit is contained in:
kepler155c@gmail.com
2019-11-01 16:36:47 -06:00
parent a36d54a372
commit 5c0ea3a2a2
23 changed files with 194 additions and 19 deletions

View File

@@ -6,5 +6,5 @@
title = 'Schematic Builder',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/builder',
description = [[Build structures from schematic files using a turtle or command computer. ]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -4,5 +4,5 @@
description = [[Peripheral management for CCEmuX
Adds a tab in the System application for configuring peripherals.]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -12,5 +12,5 @@
* Screen recorder
* and more...
]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'APIs used by various programs',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/core',
description = [[Provides APIs used by Opus applications.]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -10,5 +10,5 @@
* Cow/Sheep Rancher
* Farmer
]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Forestry mod applications',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/forestry',
description = [[WIP]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Games',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/games',
description = [[Games by various people]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -9,5 +9,5 @@
Uses 4 wireless modems connected to a single turtle or computer connected with network cables.
The turtle will also initially place all the modems in the correct locations.
]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -7,5 +7,5 @@ https://github.com/SquidDev-CC/mbs
MBS is a series of utilities for improving the default CraftOS experience.
]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -10,5 +10,5 @@
Includes: importing, exporting, autocrafting, replenish, limits and much more.
Includes over 200 standard Minecraft recipes.]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -5,5 +5,5 @@
title = 'Milo extra applications',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/miloApps',
description = [[Programs for turtles in a Milo network]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -7,5 +7,5 @@
description = [[Provides two types of automated mining:
* Scanning Miner: Uses a block scanner to very efficiently mine areas
* Simple Miner: A single or multi-turtle miner]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Various monitor related programs',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/monitor',
description = [[Mirror terminal to monitor, Monitor Window Manager (mwm), and more]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,7 +2,7 @@
title = 'Programs for the neural interface',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/neural',
description = [[ Applications using various plethora modules ]],
licence = 'MIT',
license = 'MIT',
required = {
'core',
},

View File

@@ -6,5 +6,5 @@
title = 'Move resources around with turtles',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/pickup',
description = [[ WiP ]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Recipe books for crafting programs',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/recipeBook',
description = [[ WIP ]],
licence = 'Recipes for crafting',
license = 'MIT',
}

6
secure/.package Normal file
View File

@@ -0,0 +1,6 @@
{
title = 'Security features for Opus OS',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/secure',
description = [[ Screen locking ]],
license = 'MIT',
}

106
secure/autorun/lock.lua Normal file
View File

@@ -0,0 +1,106 @@
local Config = require('opus.config')
local Util = require('opus.util')
local device = _G.device
local kernel = _G.kernel
local keyboard = device.keyboard
local multishell = _ENV.multishell
local config = Config.load('secure', {
enabled = false,
timeout = 60,
})
if not config.enabled then
return
end
local timer = os.startTimer(config.timeout)
local sandboxEnv = Util.shallowCopy(_ENV)
setmetatable(sandboxEnv, { __index = _G })
local function buildLockScreen()
_G.requireInjector(_ENV)
local Event = require('opus.event')
local Security = require('opus.security')
local SHA = require('opus.crypto.sha2')
local UI = require('opus.ui')
local counter = .1
local page = UI.Page {
pass = UI.TextEntry {
x = 10, ex = -10, y = "50%",
limit = 32,
mask = true,
shadowText = 'password',
accelerators = {
enter = 'password',
},
},
notification = UI.Notification(),
}
function page:eventHandler(event)
if event.type == 'password' then
if self.pass.value and
#self.pass.value > 0 and
Security.verifyPassword(SHA.compute(self.pass.value)) then
UI:exitPullEvents() -- valid
else
self.notification:error('Invalid password', math.max(counter, 2))
self:sync()
os.sleep(counter)
counter = counter * 2
self.pass:reset()
end
else
UI.Page.eventHandler(self, event)
end
end
Event.onTerminate(function() return false end)
UI:setPage(page)
UI:pullEvents()
-- restart lock timer
timer = os.startTimer(config.timeout)
end
local function showLockScreen()
timer = nil
multishell.openTab({
path = 'sys/apps/Lock.lua',
fn = buildLockScreen,
noTerminate = true,
pinned = true,
focused = true,
title = 'Lock',
env = sandboxEnv,
})
end
keyboard.addHotkey('control-l', function()
if timer then
os.cancelTimer(timer)
showLockScreen()
end
end)
kernel.hook({ 'mouse_click', 'mouse_up', 'mouse_drag', 'key_up' }, function(event, eventData)
if timer then
os.cancelTimer(timer)
timer = os.startTimer(config.timeout)
end
end)
kernel.hook('timer', function(_, eventData)
if timer and eventData[1] == timer then
showLockScreen()
end
end)

View File

@@ -0,0 +1,4 @@
local fs = _G.fs
-- add a System setup tab
fs.mount('sys/apps/system/secure.lua', 'linkfs', 'packages/secure/system/secure.lua')

59
secure/system/secure.lua Normal file
View File

@@ -0,0 +1,59 @@
local Config = require('opus.config')
local UI = require('opus.ui')
local config = Config.load('secure', {
enabled = false,
timeout = 60,
})
local tab = UI.Tab {
tabTitle = 'Secure',
description = 'Secure options',
label1 = UI.Text {
x = 2, y = 3,
value = 'Screen Locking',
},
checkbox = UI.Checkbox {
x = 20, y = 3,
value = config.enabled
},
label2 = UI.Text {
x = 2, y = 4,
value = 'Lock timeout',
},
timeout = UI.TextEntry {
x = 20, y = 4, width = 6,
limit = 4,
transform = 'number',
value = config.timeout,
accelerators = {
enter = 'update',
},
},
label3 = UI.Text {
ex = -2, y = -2, width = 20,
textColor = colors.yellow,
},
button = UI.Button {
x = 20, y = 6,
text = 'Update',
event = 'update',
},
}
function tab:eventHandler(event)
if event.type =='checkbox_change' then
config.enabled = not not event.checked
elseif event.type == 'update' then
config.timeout = self.timeout.value
Config.update('secure', config)
self:emit({ type = 'success_message', message = 'Settings updated' })
self.label3.value = 'Restart is required'
self.label3:draw()
end
return UI.Tab.eventHandler(self, event)
end
return tab

View File

@@ -8,5 +8,5 @@ Linux style shell commands:
grep, cat, touch, df, etc.
Linux style cp, ls]],
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Switchcraft basic shop',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/swshop',
description = 'Modification of the k store by Lemmmy\nRun installPlugin.lua after install',
licence = 'MIT',
license = 'MIT',
}

View File

@@ -2,5 +2,5 @@
title = 'Turtle programs and apis',
repository = 'kepler155c/opus-apps/{{OPUS_BRANCH}}/turtle',
description = [[Support programs and apis for turtles]],
licence = 'MIT',
license = 'MIT',
}