mirror of https://github.com/zulip/zulip.git
Kiosk mode [unsafe].
"Kiosk mode" is a "read-only" Zulip suitable for embedding into an iframe on another site. I say "read-only" in quotation marks, because the account is still a fully-fledged active account on the server, and we just tear out a bunch of stuff in Javascript (that a malicious user could easily re-enable). So in that sense, it's not actually safe in security-sensitive environments -- malicious users logged in via kiosk mode can do anything the kiosk-mode user can do. (We need this functionality for the customer3 realm specifically; we'll possibly just tear this code back out once that experiment has run its course.) (imported from commit deb035b4c702fcdb0e660ed549fe74c682abb6d9)
This commit is contained in:
parent
dbcbeb17d4
commit
0dcaf9ca3d
|
@ -7,6 +7,8 @@ exports.mark_read_at_bottom = page_params.staging;
|
|||
exports.summarize_read_while_narrowed = page_params.staging;
|
||||
exports.twenty_four_hour_time = _.contains([],
|
||||
page_params.email);
|
||||
exports.kiosk_mode = _.contains(['role-user@customer3.invalid'],
|
||||
page_params.email);
|
||||
return exports;
|
||||
|
||||
}());
|
||||
|
|
|
@ -0,0 +1,60 @@
|
|||
var kiosk = (function () {
|
||||
|
||||
var exports = {};
|
||||
|
||||
exports.enable = function () {
|
||||
exports.kiosk_mode_enabled = true;
|
||||
|
||||
// Make layout look correct
|
||||
$("body").css('padding', 5);
|
||||
$(".container-fluid").css('padding', 0);
|
||||
$(".message_area_padder").css('padding', 0);
|
||||
$(".tab-content").removeClass("span8");
|
||||
|
||||
// Firefox seems to require this, otherwise it draws a scrollbar.
|
||||
$("#home").css('overflow', 'hidden');
|
||||
|
||||
$(".hidden-phone").hide();
|
||||
$(".navbar").hide();
|
||||
$("#navbar-spacer").hide();
|
||||
|
||||
$("#compose").hide();
|
||||
$("#bottom_whitespace").hide();
|
||||
$("#tab_bar").parent().hide();
|
||||
|
||||
$("#floating_recipient_bar").css('top', 0);
|
||||
$(".message_area_padder").css('margin', 0);
|
||||
ui.resize_page_components();
|
||||
|
||||
// Disable message sending, narrowing, actions popover
|
||||
compose.start = function () { return; };
|
||||
narrow.activate = function () { return; };
|
||||
popovers.show_actions_popover = function () { return; };
|
||||
// Disable hotkeys? Seems like this is not necessary after the
|
||||
// above, and keeping them around lets us scroll nicely.
|
||||
|
||||
// TODO: Is it going to prompt for notifications?
|
||||
// My guess is that it probably won't if we disable notifications
|
||||
// for the iframe user, but who knows.
|
||||
};
|
||||
|
||||
exports.update_new_messages = function () {
|
||||
if (exports.kiosk_mode_enabled !== true) {
|
||||
return;
|
||||
}
|
||||
// Format messages properly & scroll to last message
|
||||
$(".message_controls").hide();
|
||||
$(".message_time").css('right', -65);
|
||||
navigate.to_end();
|
||||
};
|
||||
|
||||
exports.kiosk_mode_enabled = false;
|
||||
$(function () {
|
||||
if (feature_flags.kiosk_mode) {
|
||||
exports.enable();
|
||||
}
|
||||
});
|
||||
|
||||
return exports;
|
||||
|
||||
}());
|
|
@ -623,6 +623,7 @@ MessageList.prototype = {
|
|||
|
||||
// Re-add the fading of messages that is lost when we re-render.
|
||||
compose.update_faded_messages();
|
||||
kiosk.update_new_messages();
|
||||
|
||||
if (this === current_msg_list && messages_are_new) {
|
||||
this._maybe_autoscroll(rendered_elems);
|
||||
|
|
|
@ -26,6 +26,7 @@ var globals =
|
|||
+ ' invite ui util activity timerender MessageList blueslip unread stream_list'
|
||||
+ ' onboarding message_edit tab_bar emoji popovers navigate message_tour'
|
||||
+ ' avatar feature_flags search_suggestion referral stream_color Dict'
|
||||
+ ' kiosk'
|
||||
|
||||
// colorspace.js
|
||||
+ ' colorspace'
|
||||
|
|
|
@ -401,7 +401,8 @@ JS_SPECS = {
|
|||
'js/tab_bar.js',
|
||||
'js/metrics.js',
|
||||
'js/emoji.js',
|
||||
'js/referral.js'
|
||||
'js/referral.js',
|
||||
'js/kiosk.js'
|
||||
],
|
||||
'output_filename': 'min/app.js'
|
||||
},
|
||||
|
|
Loading…
Reference in New Issue