- numerous bug fixes - wtv-mail system - user account updates - viewergen alpha (experimental webtv viewer patcher on pc_service) - implement wtv-favorites with huge help from @JarHead4 - add wtv-ticket store api - Bump vm2 from 3.9.5 to 3.9.7 in /zefie_wtvp_minisrv - fix bf0app default rom - Add wtv-1800 service to wtv-1800:/noflash - handle webtvism: - allow get/post variables to be the same name multiple times - rather than overwrite, the server will now change the variable from a string to an array. - Rewrite script processing a bit - Instead of using eval() we now use a proper VM Context - As a result, any scripting errors will now give a more useful filename and line number. - However, some things may break, if they are dependant on variables we are not allowing in the context. - BREAKING CHANGES: - `ssid_sessions[socket.ssid]` is now `session_data` - `require` is no longer allowed in user scripts - add star service - change how we handle modules for services in the VM - fixed wtv-disk:/sync always failed the first time - implement production-like wtv-star handling (when a service port becomes unavailable, it requests the url over the wtv-star port to show an error page) - renamed WTVDownloadList.js to WTVDisk.js - a bit more work on WTVNews (created class) - probably more stuff I can't remember
80 lines
3.1 KiB
JavaScript
80 lines
3.1 KiB
JavaScript
var minisrv_service_file = true;
|
|
var userSession = null;
|
|
|
|
session_data.loadSessionData();
|
|
|
|
var user_id = null;
|
|
if (request_headers.query.user_id) {
|
|
user_id = request_headers.query.user_id;
|
|
} else {
|
|
var errpage = doErrorPage(400, "User was not specified.");
|
|
headers = errpage[0];
|
|
data = errpage[1];
|
|
}
|
|
|
|
if (session_data.user_id != 0 && session_data.user_id != request_headers.query.user_id) {
|
|
user_id = null; // force unset
|
|
var errpage = doErrorPage(400, "You are not authorized to edit the selected user.");
|
|
headers = errpage[0];
|
|
data = errpage[1];
|
|
}
|
|
|
|
if (user_id && !errpage) {
|
|
headers = `200 OK
|
|
Connection: Keep-Alive
|
|
Content-Type: text/html`
|
|
var userSession = null;
|
|
if (session_data.user_id == request_headers.query.user_id) userSession = session_data;
|
|
else {
|
|
userSession = new WTVClientSessionData(minisrv_config, socket.ssid);
|
|
userSession.user_id = user_id;
|
|
}
|
|
|
|
if (!userSession.loadSessionData()) {
|
|
var errpage = doErrorPage(400, "Invalid user ID.");
|
|
headers = errpage[0];
|
|
data = errpage[1];
|
|
}
|
|
else {
|
|
if (request_headers.query.password.length == 0 && request_headers.query.verify.length == 0) {
|
|
userSession.disableUserPassword();
|
|
headers = `300 OK
|
|
Content-type: text/html
|
|
wtv-expire: wtv-setup:/setup
|
|
`;
|
|
if (request_headers.query.return_to) {
|
|
headers += `wtv-expire: ${request_headers.query.return_to}
|
|
Location: ${request_headers.query.return_to}`;
|
|
}
|
|
else headers += "Location: " + (session_data.user_id === user_id) ? 'wtv-setup:/setup' : 'wtv-setup:/accounts';
|
|
}
|
|
else if (request_headers.query.password.length < minisrv_config.config.passwords.min_length) errpage = wtvshared.doErrorPage(400, "Your password must contain at least " + minisrv_config.config.passwords.min_length + " characters.");
|
|
else if (request_headers.query.password.length > minisrv_config.config.passwords.max_length) errpage = wtvshared.doErrorPage(400, "Your password must contain no more than than " + minisrv_config.config.passwords.max_length + " characters.");
|
|
else if (request_headers.query.password !== request_headers.query.verify) errpage = wtvshared.doErrorPage(400, "The passwords you entered did not match. Please check them and try again.");
|
|
else {
|
|
if (errpage) {
|
|
headers = errpage[0];
|
|
data = errpage[1];
|
|
} else {
|
|
userSession.setUserPassword(request_headers.query.password);
|
|
userSession.setUserLoggedIn(true);
|
|
headers = `300 OK
|
|
Content-type: text/html
|
|
wtv-expire: wtv-setup:/setup
|
|
`;
|
|
if (request_headers.query.return_to) {
|
|
headers += `wtv-expire: ${request_headers.query.return_to}
|
|
Location: ${request_headers.query.return_to}`;
|
|
}
|
|
else headers += "Location: "+ (session_data.user_id === user_id) ? 'wtv-setup:/setup' : 'wtv-setup:/accounts';
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
if (errpage) {
|
|
headers = errpage[0];
|
|
data = errpage[1];
|
|
}
|
|
|
|
if (userSession) userSession = null; |