Closed bjornstar closed 6 years ago
It looks like 25% of the time we're getting unescaped HTML in the data-tumblr-popover attribute in the header. It's either a case of some A/B testing or an incomplete rollout.
<div class="post_info"><div class="post_info_fence has_follow_button"><a class="post_info_link" href="http://killipechika.tumblr.com/post/172366159332" data-tumblelog-popover="{"avatar_url":"https://78.media.tumblr.com/avatar_c2e7e6be4af7_128.gif","dashboard_url":"/blog/killipechika","url":"http://killipechika.tumblr.com","name":"killipechika","cname":"","description":"Twitter デザイナー求人 \n暗号通貨取引所coincheck","description_sanitized":" External image\n <a href=\"https://twitter.com/Gerobasil\">Twitter</a> <a href=\"http://cr-navi.jp\">デザイナー求人</a> \n<a href=\"https://coincheck.com/?c=cIGj-syN7mA\" target=\"_blank\">暗号通貨取引所coincheck</a>","title":"キ リ ペ チ カ","likes":false,"share_following":false,"is_blogless_advertiser":false,"is_private":false,"is_group":false,"customizable":false,"following":true,"premium_partner":false,"can_receive_messages":true,"can_send_messages":true,"uuid":"killipechika.tumblr.com","can_be_followed":true,"has_default_header":false,"can_pixelate_avatar":false,"nsfw":false,"is_subscribed":false,"can_subscribe":true,"is_blocking":false,"global_theme_params":{"avatar_shape":"square","background_color":"#FAFAFA","body_font":"Helvetica Neue","header_bounds":"0,640,360,0","header_image":"http://static.tumblr.com/1b24e607d9bbc2ec4f12a08cb9396b84/bzuei8s/nwjp3kfeo/tumblr_static_.jpg","header_image_dimens":"640,640;640,360","header_image_focused":"https://static.tumblr.com/1b24e607d9bbc2ec4f12a08cb9396b84/bzuei8s/v5cp3kfep/tumblr_static_tumblr_static__640.jpg","header_image_scaled":"http://static.tumblr.com/1b24e607d9bbc2ec4f12a08cb9396b84/bzuei8s/nwjp3kfeo/tumblr_static__2048_v2.jpg","header_stretch":true,"link_color":"#529ECC","show_avatar":true,"show_description":true,"show_header_image":true,"show_title":true,"title_color":"#444444","title_font":"Gibson","title_font_weight":"bold"}}" data-peepr="{"tumblelog":"killipechika"}">killipechika</a><span class="reblog_source"><span class="reblog_icon" title="killipechika reblogged 1041uuu">reblogged</span><a class="post_info_link" title="1041uuu" href="http://1041uuu.tumblr.com/post/172307746313" data-tumblelog-popover="{"avatar_url":"https://78.media.tumblr.com/avatar_87afe5afae4a_128.pnj","dashboard_url":"/blog/1041uuu","url":"http://1041uuu.tumblr.com","name":"1041uuu","cname":"","description":"","description_sanitized":"","title":"1041uuu","likes":false,"share_following":false,"is_blogless_advertiser":false,"is_private":false,"is_group":false,"customizable":false,"following":false,"premium_partner":false,"can_receive_messages":true,"can_send_messages":true,"uuid":"1041uuu.tumblr.com","can_be_followed":true,"has_default_header":false,"can_pixelate_avatar":false,"nsfw":false,"asks":true,"anonymous_asks":0,"is_subscribed":false,"can_subscribe":false,"is_blocking":false,"global_theme_params":{"avatar_shape":"square","background_color":"#FAFAFA","body_font":"Helvetica Neue","header_bounds":"30,474,286,20","header_image":"http://static.tumblr.com/2b0ec5e7d4763b0cc6aaba6982be379c/tuvncqz/ljfoco1nu/tumblr_static_2i5cn6zq5qw4c8ocss0csokkc.gif","header_image_dimens":"500,288;454,256","header_image_focused":"https://static.tumblr.com/2b0ec5e7d4763b0cc6aaba6982be379c/tuvncqz/6Ntoco1nx/tumblr_static_tumblr_static_2i5cn6zq5qw4c8ocss0csokkc_640.gif","header_image_scaled":"http://static.tumblr.com/2b0ec5e7d4763b0cc6aaba6982be379c/tuvncqz/ljfoco1nu/tumblr_static_2i5cn6zq5qw4c8ocss0csokkc_2048_v2.gif","header_stretch":true,"link_color":"#529ECC","show_avatar":true,"show_description":true,"show_header_image":true,"show_title":true,"title_color":"#444444","title_font":"Gibson","title_font_weight":"bold"}}" data-peepr="{"tumblelog":"1041uuu"}">1041uuu</a></span></div><a href="/follow/1041uuu" class="reblog_follow_button " data-tumblelog-name="1041uuu" title="Follow 1041uuu"><span class="follow-text">Follow</span></a></div>
<div class="post_info"><div class="post_info_fence has_follow_button"><a class="post_info_link" href="http://killipechika.tumblr.com/post/172366159332" data-tumblelog-popover="{"avatar_url":"https:\/\/78.media.tumblr.com\/avatar_c2e7e6be4af7_128.gif","dashboard_url":"\/blog\/killipechika","url":"http:\/\/killipechika.tumblr.com","name":"killipechika","cname":"","description":"Twitter \u30c7\u30b6\u30a4\u30ca\u30fc\u6c42\u4eba \n\u6697\u53f7\u901a\u8ca8\u53d6\u5f15\u6240coincheck","description_sanitized":" External image\n \u003Ca href=\u0022https:\/\/twitter.com\/Gerobasil\u0022\u003ETwitter\u003C\/a\u003E \u003Ca href=\u0022http:\/\/cr-navi.jp\u0022\u003E\u30c7\u30b6\u30a4\u30ca\u30fc\u6c42\u4eba\u003C\/a\u003E \n\u003Ca href=\u0022https:\/\/coincheck.com\/?c=cIGj-syN7mA\u0022 target=\u0022_blank\u0022\u003E\u6697\u53f7\u901a\u8ca8\u53d6\u5f15\u6240coincheck\u003C\/a\u003E","title":"\uff77\u3000\u3000\uff98\u3000\u3000\uff8d\uff9f\u3000\u3000\uff81\u3000\u3000\uff76","likes":false,"share_following":false,"is_blogless_advertiser":false,"is_private":false,"is_group":false,"customizable":false,"following":true,"premium_partner":false,"can_receive_messages":true,"can_send_messages":true,"uuid":"killipechika.tumblr.com","can_be_followed":true,"has_default_header":false,"can_pixelate_avatar":false,"nsfw":false,"is_subscribed":false,"can_subscribe":true,"is_blocking":false,"global_theme_params":{"avatar_shape":"square","background_color":"#FAFAFA","body_font":"Helvetica Neue","header_bounds":"0,640,360,0","header_image":"http:\/\/static.tumblr.com\/1b24e607d9bbc2ec4f12a08cb9396b84\/bzuei8s\/nwjp3kfeo\/tumblr_static_.jpg","header_image_dimens":"640,640;640,360","header_image_focused":"https:\/\/static.tumblr.com\/1b24e607d9bbc2ec4f12a08cb9396b84\/bzuei8s\/v5cp3kfep\/tumblr_static_tumblr_static__640.jpg","header_image_scaled":"http:\/\/static.tumblr.com\/1b24e607d9bbc2ec4f12a08cb9396b84\/bzuei8s\/nwjp3kfeo\/tumblr_static__2048_v2.jpg","header_stretch":true,"link_color":"#529ECC","show_avatar":true,"show_description":true,"show_header_image":true,"show_title":true,"title_color":"#444444","title_font":"Gibson","title_font_weight":"bold"}}" data-peepr="{"tumblelog":"killipechika"}">killipechika</a><span class="reblog_source"><span class="reblog_icon" title="killipechika reblogged 1041uuu">reblogged</span><a class="post_info_link" title="1041uuu" href="http://1041uuu.tumblr.com/post/172307746313" data-tumblelog-popover="{"avatar_url":"https:\/\/78.media.tumblr.com\/avatar_87afe5afae4a_128.pnj","dashboard_url":"\/blog\/1041uuu","url":"http:\/\/1041uuu.tumblr.com","name":"1041uuu","cname":"","description":"","description_sanitized":"","title":"1041uuu","likes":false,"share_following":false,"is_blogless_advertiser":false,"is_private":false,"is_group":false,"customizable":false,"following":false,"premium_partner":false,"can_receive_messages":true,"can_send_messages":true,"uuid":"1041uuu.tumblr.com","can_be_followed":true,"has_default_header":false,"can_pixelate_avatar":false,"nsfw":false,"asks":true,"anonymous_asks":0,"is_subscribed":false,"can_subscribe":false,"is_blocking":false,"global_theme_params":{"avatar_shape":"square","background_color":"#FAFAFA","body_font":"Helvetica Neue","header_bounds":"30,474,286,20","header_image":"http:\/\/static.tumblr.com\/2b0ec5e7d4763b0cc6aaba6982be379c\/tuvncqz\/ljfoco1nu\/tumblr_static_2i5cn6zq5qw4c8ocss0csokkc.gif","header_image_dimens":"500,288;454,256","header_image_focused":"https:\/\/static.tumblr.com\/2b0ec5e7d4763b0cc6aaba6982be379c\/tuvncqz\/6Ntoco1nx\/tumblr_static_tumblr_static_2i5cn6zq5qw4c8ocss0csokkc_640.gif","header_image_scaled":"http:\/\/static.tumblr.com\/2b0ec5e7d4763b0cc6aaba6982be379c\/tuvncqz\/ljfoco1nu\/tumblr_static_2i5cn6zq5qw4c8ocss0csokkc_2048_v2.gif","header_stretch":true,"link_color":"#529ECC","show_avatar":true,"show_description":true,"show_header_image":true,"show_title":true,"title_color":"#444444","title_font":"Gibson","title_font_weight":"bold"}}" data-peepr="{"tumblelog":"1041uuu"}">1041uuu</a></span></div><a href="/follow/1041uuu" class="reblog_follow_button " data-tumblelog-name="1041uuu" title="Follow 1041uuu"><span class="follow-text">Follow</span></a></div>
We are using a naive regex to strip out HTML tags: var noTags = /<[^>]*>/g;
var noTags = /<[^>]*>/g;
I'm thinking about just walking the children of the header and extracting textContent. Trying to sanitize that mess does not seem fun.
Decoding their _flags entry, I see a new one: enable_js_errors_log.
enable_js_errors_log
It looks like 25% of the time we're getting unescaped HTML in the data-tumblr-popover attribute in the header. It's either a case of some A/B testing or an incomplete rollout.
We are using a naive regex to strip out HTML tags:
var noTags = /<[^>]*>/g;
I'm thinking about just walking the children of the header and extracting textContent. Trying to sanitize that mess does not seem fun.