mirror of
https://github.com/MikaylaFischler/cc-mek-scada.git
synced 2024-08-30 18:22:34 +00:00
60 lines
1.6 KiB
Lua
60 lines
1.6 KiB
Lua
--
|
|
-- Nuclear Generation Facility SCADA Coordinator
|
|
--
|
|
|
|
require("/initenv").init_env()
|
|
|
|
local log = require("scada-common.log")
|
|
local ppm = require("scada-common.ppm")
|
|
local util = require("scada-common.util")
|
|
|
|
local config = require("coordinator.config")
|
|
local coordinator = require("coordinator.coordinator")
|
|
local renderer = require("coordinator.renderer")
|
|
|
|
local COORDINATOR_VERSION = "alpha-v0.1.2"
|
|
|
|
local print = util.print
|
|
local println = util.println
|
|
local print_ts = util.print_ts
|
|
local println_ts = util.println_ts
|
|
|
|
log.init(config.LOG_PATH, config.LOG_MODE)
|
|
|
|
log.info("========================================")
|
|
log.info("BOOTING coordinator.startup " .. COORDINATOR_VERSION)
|
|
log.info("========================================")
|
|
println(">> SCADA Coordinator " .. COORDINATOR_VERSION .. " <<")
|
|
|
|
-- mount connected devices
|
|
ppm.mount_all()
|
|
|
|
-- setup monitors
|
|
local configured, monitors = coordinator.configure_monitors(config.NUM_UNITS)
|
|
if not configured then
|
|
println("boot> monitor setup failed")
|
|
log.fatal("monitor configuration failed")
|
|
return
|
|
end
|
|
|
|
log.info("monitors ready, dmesg input incoming...")
|
|
|
|
-- init renderer
|
|
renderer.set_displays(monitors)
|
|
renderer.reset()
|
|
renderer.init_dmesg()
|
|
|
|
log.dmesg("displays connected and reset", "GRAPHICS", colors.green)
|
|
log.dmesg("system start on " .. os.date("%c"), "SYSTEM", colors.cyan)
|
|
log.dmesg("starting " .. COORDINATOR_VERSION, "BOOT", colors.blue)
|
|
|
|
-- get the communications modem
|
|
local modem = ppm.get_wireless_modem()
|
|
if modem == nil then
|
|
println("boot> wireless modem not found")
|
|
log.fatal("no wireless modem on startup")
|
|
return
|
|
end
|
|
|
|
log.dmesg("wireless modem connected", "COMMS", colors.purple)
|