web: Switch from JSON.parse(xhr.responseText) to xhr.responseJSON.

This commit is contained in:
Alex Vandiver
2023-07-18 18:14:56 +00:00
committed by Tim Abbott
parent d05a1e9efa
commit 7efe989a72
17 changed files with 34 additions and 36 deletions

View File

@@ -80,7 +80,7 @@ export function create_ajax_request(
}, },
error(xhr) { error(xhr) {
$(form_loading).hide(); $(form_loading).hide();
$(form_error).show().text(JSON.parse(xhr.responseText).msg); $(form_error).show().text(xhr.responseJSON.msg);
$(form_input_section).show(); $(form_input_section).show();
$(zulip_limited_section).show(); $(zulip_limited_section).show();
$(free_trial_alert_message).show(); $(free_trial_alert_message).show();

View File

@@ -107,7 +107,7 @@ function call(args) {
} else if (xhr.status === 403) { } else if (xhr.status === 403) {
try { try {
if ( if (
JSON.parse(xhr.responseText).code === "CSRF_FAILED" && xhr.responseJSON.code === "CSRF_FAILED" &&
reload_state.csrf_failed_handler !== undefined reload_state.csrf_failed_handler !== undefined
) { ) {
reload_state.csrf_failed_handler(); reload_state.csrf_failed_handler();
@@ -192,7 +192,7 @@ export function xhr_error_message(message, xhr) {
if (xhr.status.toString().charAt(0) === "4") { if (xhr.status.toString().charAt(0) === "4") {
// Only display the error response for 4XX, where we've crafted // Only display the error response for 4XX, where we've crafted
// a nice response. // a nice response.
const server_response_html = _.escape(JSON.parse(xhr.responseText).msg); const server_response_html = _.escape(xhr.responseJSON.msg);
if (message) { if (message) {
message += ": " + server_response_html; message += ": " + server_response_html;
} else { } else {

View File

@@ -595,7 +595,7 @@ export function initialize() {
} }
function xhr_failure(xhr) { function xhr_failure(xhr) {
const error = JSON.parse(xhr.responseText); const error = xhr.responseJSON;
failure(error.msg); failure(error.msg);
} }

View File

@@ -114,16 +114,16 @@ function submit_invitation_form() {
} }
}, },
error(xhr) { error(xhr) {
const arr = JSON.parse(xhr.responseText); if (xhr.responseJSON.errors === undefined) {
if (arr.errors === undefined) {
// There was a fatal error, no partial processing occurred. // There was a fatal error, no partial processing occurred.
ui_report.error("", xhr, $invite_status); ui_report.error("", xhr, $invite_status);
} else { } else {
// Some users were not invited. // Some users were not invited.
const response_body = xhr.responseJSON;
const invitee_emails_errored = []; const invitee_emails_errored = [];
const error_list = []; const error_list = [];
let is_invitee_deactivated = false; let is_invitee_deactivated = false;
for (const value of arr.errors) { for (const value of response_body.errors) {
const [email, error_message, deactivated] = value; const [email, error_message, deactivated] = value;
error_list.push(`${email}: ${error_message}`); error_list.push(`${email}: ${error_message}`);
if (deactivated) { if (deactivated) {
@@ -133,17 +133,17 @@ function submit_invitation_form() {
} }
const error_response = render_invitation_failed_error({ const error_response = render_invitation_failed_error({
error_message: arr.msg, error_message: response_body.msg,
error_list, error_list,
is_admin: page_params.is_admin, is_admin: page_params.is_admin,
is_invitee_deactivated, is_invitee_deactivated,
license_limit_reached: arr.license_limit_reached, license_limit_reached: response_body.license_limit_reached,
has_billing_access: page_params.is_owner || page_params.is_billing_admin, has_billing_access: page_params.is_owner || page_params.is_billing_admin,
daily_limit_reached: arr.daily_limit_reached, daily_limit_reached: response_body.daily_limit_reached,
}); });
ui_report.message(error_response, $invite_status, "alert-warning"); ui_report.message(error_response, $invite_status, "alert-warning");
if (arr.sent_invitations) { if (response_body.sent_invitations) {
$invitee_emails.val(invitee_emails_errored.join("\n")); $invitee_emails.val(invitee_emails_errored.join("\n"));
} }
} }

View File

@@ -699,8 +699,7 @@ export function toggle_resolve_topic(message_id, old_topic_name, report_errors_i
} }
if (report_errors_in_global_banner) { if (report_errors_in_global_banner) {
const error_msg = JSON.parse(xhr.responseText).msg; ui_report.generic_embed_error(xhr.responseJSON.msg, 3500);
ui_report.generic_embed_error(error_msg, 3500);
} }
}, },
}); });

View File

@@ -207,10 +207,7 @@ function get_events({dont_block = false} = {}) {
get_events_xhr = undefined; get_events_xhr = undefined;
// If we're old enough that our message queue has been // If we're old enough that our message queue has been
// garbage collected, immediately reload. // garbage collected, immediately reload.
if ( if (xhr.status === 400 && xhr.responseJSON.code === "BAD_EVENT_QUEUE_ID") {
xhr.status === 400 &&
JSON.parse(xhr.responseText).code === "BAD_EVENT_QUEUE_ID"
) {
page_params.event_queue_expired = true; page_params.event_queue_expired = true;
reload.initiate({ reload.initiate({
immediate: true, immediate: true,

View File

@@ -119,7 +119,7 @@ function upload_avatar($file_input) {
$("#user-avatar-source").show(); $("#user-avatar-source").show();
} }
const $error = $("#user-avatar-upload-widget .image_file_input_error"); const $error = $("#user-avatar-upload-widget .image_file_input_error");
$error.text(JSON.parse(xhr.responseText).msg); $error.text(xhr.responseJSON.msg);
$error.show(); $error.show();
}, },
}); });
@@ -490,7 +490,7 @@ export function set_up() {
$("#api_key_value").text(data.api_key); $("#api_key_value").text(data.api_key);
}, },
error(xhr) { error(xhr) {
$("#user_api_key_error").text(JSON.parse(xhr.responseText).msg).show(); $("#user_api_key_error").text(xhr.responseJSON.msg).show();
}, },
}); });
e.preventDefault(); e.preventDefault();

View File

@@ -581,7 +581,7 @@ export function set_up() {
}, },
error(xhr) { error(xhr) {
const $row = $(e.currentTarget).closest("li"); const $row = $(e.currentTarget).closest("li");
$row.find(".api_key_error").text(JSON.parse(xhr.responseText).msg).show(); $row.find(".api_key_error").text(xhr.responseJSON.msg).show();
}, },
}); });
}); });

View File

@@ -73,7 +73,7 @@ function open_linkifier_edit_form(linkifier_id) {
}, },
error_continuation(xhr) { error_continuation(xhr) {
$change_linkifier_button.prop("disabled", false); $change_linkifier_button.prop("disabled", false);
const response_text = JSON.parse(xhr.responseText); const response_text = xhr.responseJSON;
if (response_text.errors !== undefined) { if (response_text.errors !== undefined) {
handle_linkifier_api_error( handle_linkifier_api_error(
xhr, xhr,
@@ -113,17 +113,17 @@ function handle_linkifier_api_error(xhr, pattern_status, template_status, linkif
// The endpoint uses the Django ValidationError system for error // The endpoint uses the Django ValidationError system for error
// handling, which returns somewhat complicated error // handling, which returns somewhat complicated error
// dictionaries. This logic parses them. // dictionaries. This logic parses them.
const errors = JSON.parse(xhr.responseText).errors; const errors = xhr.responseJSON.errors;
if (errors.pattern !== undefined) { if (errors.pattern !== undefined) {
xhr.responseText = JSON.stringify({msg: errors.pattern}); xhr.responseJSON.msg = errors.pattern;
ui_report.error($t_html({defaultMessage: "Failed"}), xhr, pattern_status); ui_report.error($t_html({defaultMessage: "Failed"}), xhr, pattern_status);
} }
if (errors.url_template !== undefined) { if (errors.url_template !== undefined) {
xhr.responseText = JSON.stringify({msg: errors.url_template}); xhr.responseJSON.msg = errors.url_template;
ui_report.error($t_html({defaultMessage: "Failed"}), xhr, template_status); ui_report.error($t_html({defaultMessage: "Failed"}), xhr, template_status);
} }
if (errors.__all__ !== undefined) { if (errors.__all__ !== undefined) {
xhr.responseText = JSON.stringify({msg: errors.__all__}); xhr.responseJSON.msg = errors.__all__;
ui_report.error($t_html({defaultMessage: "Failed"}), xhr, linkifier_status); ui_report.error($t_html({defaultMessage: "Failed"}), xhr, linkifier_status);
} }
} }

View File

@@ -1101,7 +1101,7 @@ function get_chart_data(data, callback) {
update_last_full_update(data.end_times); update_last_full_update(data.end_times);
}, },
error(xhr) { error(xhr) {
$("#id_stats_errors").show().text(JSON.parse(xhr.responseText).msg); $("#id_stats_errors").show().text(xhr.responseJSON.msg);
}, },
}); });
} }

View File

@@ -280,7 +280,7 @@ function create_stream() {
// The rest of the work is done via the subscribe event we will get // The rest of the work is done via the subscribe event we will get
}, },
error(xhr) { error(xhr) {
const msg = JSON.parse(xhr.responseText).msg; const msg = xhr.responseJSON.msg;
if (msg.includes("access")) { if (msg.includes("access")) {
// If we can't access the stream, we can safely // If we can't access the stream, we can safely
// assume it's a duplicate stream that we are not invited to. // assume it's a duplicate stream that we are not invited to.

View File

@@ -196,7 +196,7 @@ function subscribe_new_users({pill_user_ids}) {
} }
function invite_failure(xhr) { function invite_failure(xhr) {
const error = JSON.parse(xhr.responseText); const error = xhr.responseJSON;
show_stream_subscription_request_result({ show_stream_subscription_request_result({
message: error.msg, message: error.msg,
add_class: "text-error", add_class: "text-error",

View File

@@ -957,7 +957,7 @@ function ajaxSubscribe(stream, color, $stream_row) {
$("#create_stream_name").val(""); $("#create_stream_name").val("");
} }
const res = JSON.parse(xhr.responseText); const res = xhr.responseJSON;
if (!$.isEmptyObject(res.already_subscribed)) { if (!$.isEmptyObject(res.already_subscribed)) {
// Display the canonical stream capitalization. // Display the canonical stream capitalization.
true_stream_name = res.already_subscribed[people.my_current_email()][0]; true_stream_name = res.already_subscribed[people.my_current_email()][0];

View File

@@ -41,7 +41,7 @@ export function error(
if (xhr && xhr.status >= 400 && xhr.status < 500) { if (xhr && xhr.status >= 400 && xhr.status < 500) {
// Only display the error response for 4XX, where we've crafted // Only display the error response for 4XX, where we've crafted
// a nice response. // a nice response.
const server_response_html = _.escape(JSON.parse(xhr.responseText).msg); const server_response_html = _.escape(xhr.responseJSON.msg);
if (response_html) { if (response_html) {
response_html += ": " + server_response_html; response_html += ": " + server_response_html;
} else { } else {
@@ -79,7 +79,7 @@ export function generic_embed_error(error_html: string, remove_after: number): v
export function generic_row_button_error(xhr: JQuery.jqXHR, $btn: JQuery): void { export function generic_row_button_error(xhr: JQuery.jqXHR, $btn: JQuery): void {
if (xhr.status >= 400 && xhr.status < 500) { if (xhr.status >= 400 && xhr.status < 500) {
const $error = $("<p>").addClass("text-error").text(JSON.parse(xhr.responseText).msg); const $error = $("<p>").addClass("text-error").text(xhr.responseJSON.msg);
$btn.closest("td").empty().append($error); $btn.closest("td").empty().append($error);
} else { } else {
$btn.text($t({defaultMessage: "Failed!"})); $btn.text($t({defaultMessage: "Failed!"}));

View File

@@ -223,7 +223,7 @@ function add_new_members({pill_user_ids}) {
} }
function invite_failure(xhr) { function invite_failure(xhr) {
const error = JSON.parse(xhr.responseText); const error = xhr.responseJSON;
show_user_group_membership_request_result({ show_user_group_membership_request_result({
message: error.msg, message: error.msg,
add_class: "text-error", add_class: "text-error",

View File

@@ -160,7 +160,7 @@ run_test("create_ajax_request", ({override}) => {
assert.equal(state.free_trial_alert_message_show, 0); assert.equal(state.free_trial_alert_message_show, 0);
assert.ok(success_callback_called); assert.ok(success_callback_called);
error({responseText: '{"msg": "response_message"}'}); error({responseJSON: {msg: "response_message"}});
assert.equal(state.form_loading_hide, 2); assert.equal(state.form_loading_hide, 2);
assert.equal(state.form_error_show, 1); assert.equal(state.form_error_show, 1);

View File

@@ -9,7 +9,7 @@ const {page_params} = require("./lib/zpage_params");
const xhr_401 = { const xhr_401 = {
status: 401, status: 401,
responseText: '{"msg": "Use cannot access XYZ"}', responseJSON: {msg: "Use cannot access XYZ"},
}; };
let login_to_access_shown = false; let login_to_access_shown = false;
@@ -294,7 +294,7 @@ test("reload_on_403_error", () => {
test_with_mock_ajax({ test_with_mock_ajax({
xhr: { xhr: {
status: 403, status: 403,
responseText: '{"msg": "CSRF Fehler: etwas", "code": "CSRF_FAILED"}', responseJSON: {msg: "CSRF Fehler: etwas", code: "CSRF_FAILED"},
}, },
run_code() { run_code() {
@@ -317,6 +317,7 @@ test("unexpected_403_response", () => {
test_with_mock_ajax({ test_with_mock_ajax({
xhr: { xhr: {
status: 403, status: 403,
responseJSON: undefined,
responseText: "unexpected", responseText: "unexpected",
}, },
@@ -334,6 +335,7 @@ test("unexpected_403_response", () => {
test("xhr_error_message", () => { test("xhr_error_message", () => {
let xhr = { let xhr = {
status: "200", status: "200",
responseJSON: undefined,
responseText: "does not matter", responseText: "does not matter",
}; };
let msg = "data added"; let msg = "data added";
@@ -341,7 +343,7 @@ test("xhr_error_message", () => {
xhr = { xhr = {
status: "404", status: "404",
responseText: '{"msg": "file not found"}', responseJSON: {msg: "file not found"},
}; };
msg = "some message"; msg = "some message";
assert.equal(channel.xhr_error_message(msg, xhr), "some message: file not found"); assert.equal(channel.xhr_error_message(msg, xhr), "some message: file not found");