liftinstall/ui/mock-server.js

152 lines
3.4 KiB
JavaScript
Raw Normal View History

2019-06-25 03:06:28 +00:00
'use strict'
const express = require('express')
const app = express()
const port = 3000
2019-12-10 04:08:49 +00:00
let showError = false
let maintenance = false
let launcher = false
2020-05-28 06:37:20 +00:00
let fileExists = false
let darkMode = false
2019-12-10 04:08:49 +00:00
2019-06-25 03:06:28 +00:00
function progressSimulation (res) {
2019-12-10 04:08:49 +00:00
if (showError) {
var resp = JSON.stringify({ Error: 'Simulated error.' }) + '\n'
res.write(resp)
res.status(200).end()
return
}
2019-06-25 03:06:28 +00:00
var progress = 0.0
var timer = setInterval(() => {
var resp = JSON.stringify({ Status: ['Processing...', progress] }) + '\n'
progress += 0.1
res.write(resp)
if (progress >= 1) {
res.status(200).end()
clearInterval(timer)
}
}, 500)
2019-06-25 03:06:28 +00:00
}
function returnConfig (res) {
2019-12-10 04:08:49 +00:00
if (showError) {
res.status(500).json({})
return
}
2019-06-25 03:06:28 +00:00
res.json({
installing_message:
'Test Banner <strong>Bold</strong>&nbsp;<pre>Code block</pre>&nbsp;<i>Italic</i>&nbsp;<del>Strike</del>',
new_tool: null,
packages: [
{
name: 'Test 1',
description: 'LiftInstall GUI Test 1',
default: true,
source: {
name: 'github',
match: '^test$',
config: { repo: 'j-selby/liftinstall' }
},
shortcuts: []
},
{
name: 'Test 2',
description:
'Different Banner <strong>Bold</strong>&nbsp;<pre>Code block</pre>&nbsp;<i>Italic</i>&nbsp;<del>Strike</del>',
default: null,
source: {
name: 'github',
match: '^test2$',
config: { repo: 'j-selby/liftinstall' }
},
shortcuts: []
}
],
hide_advanced: false
})
}
app.get('/api/attrs', (req, res) => {
2019-12-10 04:08:49 +00:00
console.log('-- Get attrs')
res.send(
2019-12-09 01:27:12 +00:00
{ name: 'yuzu', target_url: 'https://raw.githubusercontent.com/j-selby/test-installer/master/config.linux.v2.toml' }
)
})
app.get('/api/dark-mode', (req, res) => {
2020-05-28 06:37:20 +00:00
res.json(darkMode)
})
app.get('/api/installation-status', (req, res) => {
res.json({
database: { packages: [], shortcuts: [] },
install_path: null,
preexisting_install: maintenance,
is_launcher: launcher,
launcher_path: null
})
})
app.get('/api/default-path', (req, res) => {
res.json({ path: '/tmp/test/' })
})
app.get('/api/config', (req, res) => {
setTimeout(() => {
returnConfig(res)
}, 3000)
2019-06-25 03:06:28 +00:00
})
app.post('/api/start-install', (req, res) => {
console.log(`-- Install: ${req}`)
2019-06-25 03:06:28 +00:00
progressSimulation(res)
})
app.get('/api/exit', (req, res) => {
console.log('-- Exit')
2019-12-10 04:08:49 +00:00
if (showError) {
res.status(500).send('Simulated error: Nothing to see here.')
return
}
res.status(204).send()
2019-06-25 03:06:28 +00:00
})
2019-12-10 04:08:49 +00:00
app.get('/api/mock_error', (req, res) => {
console.log('-- Toggle error emulation')
showError = !showError
res.status(200).send(`Error emulation: ${showError}\n`)
})
2020-05-28 06:37:20 +00:00
app.post('/api/verify-path', (req, res) => {
console.log('-- Verify Path')
res.send({
exists: fileExists
})
})
process.argv.forEach((val, index) => {
switch (val) {
case 'maintenance':
maintenance = true
console.log('Simulating maintenance mode')
break
case 'launcher':
maintenance = true
launcher = true
console.log('Simulating launcher mode')
break
case 'exists':
fileExists = true
console.log('Simulating file exists situation')
break
case 'dark':
darkMode = true
console.log('Simulating dark mode')
break
}
})
2019-06-25 03:06:28 +00:00
console.log(`Listening on ${port}...`)
app.listen(port)