mirror of
https://github.com/ION606/web-to-fish.git
synced 2026-05-14 18:36:53 +00:00
migrated
This commit is contained in:
@@ -4,6 +4,7 @@ import { fileURLToPath } from 'url';
|
|||||||
import session from 'express-session';
|
import session from 'express-session';
|
||||||
import expressWs from 'express-ws';
|
import expressWs from 'express-ws';
|
||||||
import { spawn } from 'node-pty';
|
import { spawn } from 'node-pty';
|
||||||
|
import linuxpam from 'node-linux-pam';
|
||||||
import json from './secrets/config.json' with { type: 'json' };
|
import json from './secrets/config.json' with { type: 'json' };
|
||||||
|
|
||||||
const __dirname = path.dirname(fileURLToPath(import.meta.url)),
|
const __dirname = path.dirname(fileURLToPath(import.meta.url)),
|
||||||
@@ -43,41 +44,39 @@ app.get('/login', (req, res) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
// process login
|
app.post('/login', async (req, res) => {
|
||||||
app.post('/login', (req, res) => {
|
|
||||||
try {
|
try {
|
||||||
const username = req.body.username;
|
const username = req.body.username;
|
||||||
const password = req.body.password;
|
const password = req.body.password;
|
||||||
|
|
||||||
if (!username) return res.sendStatus(404);
|
// validate input
|
||||||
else if (!password) return res.sendStatus(401);
|
if (!username) return res.status(400).send('Username is required');
|
||||||
|
if (!password) return res.status(400).send('Password is required');
|
||||||
|
|
||||||
const shell = spawn('su', [`${username}`], {
|
// authenticate using PAM
|
||||||
cwd: process.env.HOME,
|
linuxpam.pamAuthenticate({
|
||||||
env: process.env
|
username,
|
||||||
});
|
password,
|
||||||
|
serviceName: 'login',
|
||||||
req.on('end', () => shell.kill());
|
}, (err, success) => {
|
||||||
|
console.log(err);
|
||||||
shell.onData((data) => {
|
if (err.message.includes('User not known')) res.sendStatus(404);
|
||||||
if (data?.toLowerCase().trim() === 'password:') shell.write(password + '\n');
|
else if (err.message.includes('Authentication failure')) res.sendStatus(401);
|
||||||
else if (data.includes('does not exist')) res.sendStatus(404);
|
else if (success) {
|
||||||
else if (data.includes('Authentication failure')) res.sendStatus(401);
|
|
||||||
else if (data.includes('Welcome to fish')) {
|
|
||||||
req.session.authenticated = true;
|
req.session.authenticated = true;
|
||||||
res.redirect('/shell');
|
req.session.username = username;
|
||||||
shell.kill();
|
return res.redirect('/shell');
|
||||||
}
|
}
|
||||||
else if (data.match(/\[\w+@\w+ \w+\]\$ ?/)) shell.write('fish\n');
|
else console.error("what?", err, success);
|
||||||
else console.error(`unknown terminal output:\n"${data}"`);
|
|
||||||
});
|
});
|
||||||
}
|
} catch (err) {
|
||||||
catch (err) {
|
|
||||||
console.error(err);
|
console.error(err);
|
||||||
|
res.status(500).send('Internal server error');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// shell interface
|
// shell interface
|
||||||
app.get('/shell', requireAuth, (req, res) => {
|
app.get('/shell', requireAuth, (req, res) => {
|
||||||
res.sendFile('shell.html', { root: path.join(__dirname, 'HTML') });
|
res.sendFile('shell.html', { root: path.join(__dirname, 'HTML') });
|
||||||
|
|||||||
Generated
+1039
File diff suppressed because it is too large
Load Diff
@@ -14,6 +14,7 @@
|
|||||||
"express": "^4.21.2",
|
"express": "^4.21.2",
|
||||||
"express-session": "^1.18.1",
|
"express-session": "^1.18.1",
|
||||||
"express-ws": "^5.0.2",
|
"express-ws": "^5.0.2",
|
||||||
|
"node-linux-pam": "^0.2.1",
|
||||||
"node-pty": "^1.0.0"
|
"node-pty": "^1.0.0"
|
||||||
},
|
},
|
||||||
"type": "module"
|
"type": "module"
|
||||||
|
|||||||
Reference in New Issue
Block a user