mirror of https://github.com/tycrek/ass
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
39 lines
1.2 KiB
39 lines
1.2 KiB
import { path } from '@tycrek/joint';
|
|
import { Router, json as BodyParserJson } from 'express';
|
|
import { log } from '../log';
|
|
import { UserConfig } from '../UserConfig';
|
|
import { setDataModeToSql } from '../data';
|
|
import { MySql } from '../sql/mysql';
|
|
|
|
const router = Router({ caseSensitive: true });
|
|
|
|
// Static routes
|
|
router.get('/', (req, res) => UserConfig.ready ? res.redirect('/') : res.render('setup'));
|
|
router.get('/ui.js', (req, res) => UserConfig.ready ? res.send('') : res.type('text/javascript').sendFile(path.join('dist-frontend/setup.mjs')));
|
|
|
|
// Setup route
|
|
router.post('/', BodyParserJson(), async (req, res) => {
|
|
if (UserConfig.ready)
|
|
return res.status(409).json({ success: false, message: 'User config already exists' });
|
|
|
|
log.debug('Setup initiated');
|
|
|
|
try {
|
|
// Parse body
|
|
new UserConfig(req.body);
|
|
|
|
// Save config
|
|
await UserConfig.saveConfigFile();
|
|
|
|
// Set data storage (not files) to SQL if required
|
|
if (UserConfig.config.sql?.mySql != null)
|
|
await Promise.all([MySql.configure(), setDataModeToSql()]);
|
|
|
|
return res.json({ success: true });
|
|
} catch (err: any) {
|
|
return res.status(400).json({ success: false, message: err.message });
|
|
}
|
|
});
|
|
|
|
export { router };
|