From e45ffb8592cacecb90443dc77f09f9a9823a029f Mon Sep 17 00:00:00 2001 From: Michael Foster Date: Mon, 19 Aug 2013 18:54:10 +1000 Subject: [PATCH 1/7] custom timeouet for curl'ing upload urls --- inc/config.php | 2 ++ post.php | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/inc/config.php b/inc/config.php index fbe20d3e..ae45a746 100644 --- a/inc/config.php +++ b/inc/config.php @@ -355,6 +355,8 @@ // Allow "uploading" images via URL as well. Users can enter the URL of the image and then Tinyboard will // download it. Not usually recommended. $config['allow_upload_by_url'] = false; + // The timeout for the above, in seconds. + $config['upload_by_url_timeout'] = 15; // A wordfilter (sometimes referred to as just a "filter" or "censor") automatically scans users’ posts // as they are submitted and changes or censors particular words or phrases. diff --git a/post.php b/post.php index 02d97e24..df7fe435 100644 --- a/post.php +++ b/post.php @@ -291,7 +291,7 @@ if (isset($_POST['delete'])) { curl_setopt($curl, CURLOPT_FAILONERROR, true); curl_setopt($curl, CURLOPT_FOLLOWLOCATION, false); curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, 5); - curl_setopt($curl, CURLOPT_TIMEOUT, 15); + curl_setopt($curl, CURLOPT_TIMEOUT, $config['upload_by_url_timeout']); curl_setopt($curl, CURLOPT_USERAGENT, 'Tinyboard'); curl_setopt($curl, CURLOPT_BINARYTRANSFER, true); curl_setopt($curl, CURLOPT_FILE, $fp); From 69741e6c08c86e24fd4d90efc34c9d269a458201 Mon Sep 17 00:00:00 2001 From: Michael Foster Date: Mon, 19 Aug 2013 20:00:16 +1000 Subject: [PATCH 2/7] deleting boards: cache purging, delete directory after sql queries (in case we have permission errors, etc.) --- inc/mod/pages.php | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/inc/mod/pages.php b/inc/mod/pages.php index 887be16b..63e7266e 100644 --- a/inc/mod/pages.php +++ b/inc/mod/pages.php @@ -359,10 +359,12 @@ function mod_edit_board($boardName) { $query->bindValue(':uri', $board['uri']); $query->execute() or error(db_error($query)); - modLog('Deleted board: ' . sprintf($config['board_abbreviation'], $board['uri']), false); + if ($config['cache']['enabled']) { + cache::delete('board_' . $board['uri']); + cache::delete('all_boards'); + } - // Delete entire board directory - rrmdir($board['uri'] . '/'); + modLog('Deleted board: ' . sprintf($config['board_abbreviation'], $board['uri']), false); // Delete posting table $query = query(sprintf('DROP TABLE IF EXISTS ``posts_%s``', $board['uri'])) or error(db_error()); @@ -409,6 +411,9 @@ function mod_edit_board($boardName) { $_query->execute() or error(db_error($_query)); } } + + // Delete entire board directory + rrmdir($board['uri'] . '/'); } else { $query = prepare('UPDATE ``boards`` SET `title` = :title, `subtitle` = :subtitle WHERE `uri` = :uri'); $query->bindValue(':uri', $board['uri']); From 5438d7cf64cb1dc686dcd1ebb8ba38cc0c5e4ca1 Mon Sep 17 00:00:00 2001 From: Michael Foster Date: Mon, 19 Aug 2013 20:31:15 +1000 Subject: [PATCH 3/7] add alt="" to flags to make it standards-compliant --- templates/post_reply.html | 2 +- templates/post_thread.html | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/templates/post_reply.html b/templates/post_reply.html index 28cbd7f8..a1feb005 100644 --- a/templates/post_reply.html +++ b/templates/post_reply.html @@ -31,7 +31,7 @@ {% if config.display_flags and post.modifiers.flag %} + {% if post.modifiers['flag alt'] %}alt="{{ post.modifiers['flag alt'] | e('html_attr') }}" title="{{ post.modifiers['flag alt'] | e('html_attr') }}"{% endif %}> {% endif %} diff --git a/templates/post_thread.html b/templates/post_thread.html index 0ee3f6fa..5910bb74 100644 --- a/templates/post_thread.html +++ b/templates/post_thread.html @@ -85,7 +85,7 @@ {% if config.display_flags and post.modifiers.flag %} + {% if post.modifiers['flag alt'] %}alt="{{ post.modifiers['flag alt'] | e('html_attr') }}" title="{{ post.modifiers['flag alt'] | e('html_attr') }}"{% endif %}> {% endif %} From abfdd38e59458d871f466952776675238f3179fb Mon Sep 17 00:00:00 2001 From: Michael Foster Date: Mon, 19 Aug 2013 23:47:56 +1000 Subject: [PATCH 4/7] Unicode bi-directional text: Finally a working fix --- inc/display.php | 45 ++++++++++++++++++++++++++++++++++++++++++--- stylesheets/style.css | 7 +++++-- templates/post_reply.html | 2 +- templates/post_thread.html | 2 +- 4 files changed, 49 insertions(+), 7 deletions(-) diff --git a/inc/display.php b/inc/display.php index 6fa97f4f..81f8c53d 100644 --- a/inc/display.php +++ b/inc/display.php @@ -218,11 +218,50 @@ function truncate($body, $url, $max_lines = false, $max_chars = false) { return $body; } -function bidi_cleanup($str) { - // Removes all embedded RTL and LTR unicode formatting blocks in a string so that +function bidi_cleanup($data) { + // Closes all embedded RTL and LTR unicode formatting blocks in a string so that // it can be used inside another without controlling its direction. - return "$str"; + $explicits = '\xE2\x80\xAA|\xE2\x80\xAB|\xE2\x80\xAD|\xE2\x80\xAE'; + $pdf = '\xE2\x80\xAC'; + + preg_match_all("!$explicits!", $data, $m1, PREG_OFFSET_CAPTURE | PREG_SET_ORDER); + preg_match_all("!$pdf!", $data, $m2, PREG_OFFSET_CAPTURE | PREG_SET_ORDER); + + if (count($m1) || count($m2)){ + + $p = array(); + foreach ($m1 as $m){ $p[$m[0][1]] = 'push'; } + foreach ($m2 as $m){ $p[$m[0][1]] = 'pop'; } + ksort($p); + + $offset = 0; + $stack = 0; + foreach ($p as $pos => $type){ + + if ($type == 'push'){ + $stack++; + }else{ + if ($stack){ + $stack--; + }else{ + # we have a pop without a push - remove it + $data = substr($data, 0, $pos-$offset) + .substr($data, $pos+3-$offset); + $offset += 3; + } + } + } + + # now add some pops if your stack is bigger than 0 + for ($i=0; $i<$stack; $i++){ + $data .= "\xE2\x80\xAC"; + } + + return $data; + } + + return $data; } function secure_link_confirm($text, $title, $confirm_message, $href) { diff --git a/stylesheets/style.css b/stylesheets/style.css index e62891e2..c1725e35 100644 --- a/stylesheets/style.css +++ b/stylesheets/style.css @@ -37,6 +37,10 @@ p.intro a.email:hover span.name { p.intro label { display: inline; } +p.intro time, p.intro a.ip-link, p.intro a.capcode { + direction: ltr; + unicode-bidi: embed; +} h2 { color: #AF0A0F; font-size: 11pt; @@ -406,5 +410,4 @@ table.mod.config-editor input[type="text"] { p.intro.thread-hidden { margin: 0px; padding: 0px; -} - +} \ No newline at end of file diff --git a/templates/post_reply.html b/templates/post_reply.html index a1feb005..c5d24247 100644 --- a/templates/post_reply.html +++ b/templates/post_reply.html @@ -26,7 +26,7 @@ {{ capcode.cap }} {% endif %} {% if post.mod and post.mod|hasPermission(config.mod.show_ip, board.uri) %} - [{{ post.ip }}] + [{{ post.ip }}] {% endif %} {% if config.display_flags and post.modifiers.flag %} {{ post.ip }}] + [{{ post.ip }}] {% endif %} {% if config.display_flags and post.modifiers.flag %} Date: Tue, 20 Aug 2013 17:43:21 +1000 Subject: [PATCH 5/7] safer installation --- install.php | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/install.php b/install.php index a510631e..a6937028 100644 --- a/install.php +++ b/install.php @@ -645,18 +645,18 @@ if ($step == 0) { $sql_errors .= '
  • ' . db_error() . '
  • '; } - $boards = listBoards(); - foreach ($boards as &$_board) { - setupBoard($_board); - buildIndex(); - } - $page['title'] = 'Installation complete'; $page['body'] = '

    Thank you for using Tinyboard. Please remember to report any bugs you discover. How do I edit the config files?

    '; if (!empty($sql_errors)) { $page['body'] .= '

    SQL errors

    SQL errors were encountered when trying to install the database. This may be the result of using a database which is already occupied with a Tinyboard installation; if so, you can probably ignore this.

    The errors encountered were:

      ' . $sql_errors . '

    Ignore errors and complete installation.

    '; } else { + $boards = listBoards(); + foreach ($boards as &$_board) { + setupBoard($_board); + buildIndex(); + } + file_write($config['has_installed'], VERSION); if (!file_unlink(__FILE__)) { $page['body'] .= '

    Delete install.php!

    I couldn\'t remove install.php. You will have to remove it manually.

    '; @@ -668,6 +668,12 @@ if ($step == 0) { $page['title'] = 'Installation complete'; $page['body'] = '

    Thank you for using Tinyboard. Please remember to report any bugs you discover.

    '; + $boards = listBoards(); + foreach ($boards as &$_board) { + setupBoard($_board); + buildIndex(); + } + file_write($config['has_installed'], VERSION); if (!file_unlink(__FILE__)) { $page['body'] .= '

    Delete install.php!

    I couldn\'t remove install.php. You will have to remove it manually.

    '; From c3434d29fd7421f11d1e2e225e5c417bcee70556 Mon Sep 17 00:00:00 2001 From: Czterooki Date: Mon, 19 Aug 2013 10:07:13 -0400 Subject: [PATCH 6/7] Initial release of Dark Roach optimised for midnight lurking and compability with 8bit displays (which is used in software for blind people) --- stylesheets/dark_roach.css | 471 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 471 insertions(+) create mode 100644 stylesheets/dark_roach.css diff --git a/stylesheets/dark_roach.css b/stylesheets/dark_roach.css new file mode 100644 index 00000000..cff616b6 --- /dev/null +++ b/stylesheets/dark_roach.css @@ -0,0 +1,471 @@ +@font-face { + font-family: 'Ubuntu'; + font-style: normal; + font-weight: 300; + src: local('Ubuntu Light'), local('Ubuntu-Light'), url(http://themes.googleusercontent.com/static/fonts/ubuntu/v4/_aijTyevf54tkVDLy-dlnD8E0i7KZn-EPnyo3HZu7kw.woff) format('woff'); +} +body { + background: #000000; + background-image: url(), url(); + background-repeat: repeat-x, no-repeat; + background-attachment: fixed, fixed; + background-position: top, right bottom; + color: #999999; + font-family: Ubuntu; + font-size: 10pt; + margin: 0 8px; + padding-left: 5px; + padding-right: 5px; +} +table * { + margin: 0; +} +a, a:visited { + text-decoration: none; + color: #9999CC; +} +a:hover, p.intro a.post_no:hover { + color: #996699 +} +a.post_no { + text-decoration: none; + margin: 0; + padding: 0; +} +p.intro a.post_no { + color: inherit; +} +p.intro a.post_no, p.intro a.email { + margin: 0; +} +p.intro a.email span.name { + color: #666699; +} +p.intro a.email:hover span.name { + color: #663366; +} +p.intro label { + display: inline; +} +h2 { + color: #CC0000; + font-size: 11pt; + margin: 0; + padding: 0; +} +header { + margin: 1em 0; +} +h1 { + font-family: Ubuntu; + letter-spacing: -2px; + font-size: 20pt; + margin: 0; +} +header div.subtitle, h1 { + color: #990000; + text-align: center; +} +header div.subtitle { + font-size: 8pt; +} +form { + margin-bottom: 4em; +} +form table { + margin: auto; +} +form table input { + height: auto; +} +input[type="text"], input[type="password"], textarea { + border: 1px solid #000000; + text-indent: 0; + text-shadow: none; + text-transform: none; + word-spacing: normal; +} +form table tr td { + text-align: left; + margin: 0; + padding: 0; +} +form table.mod tr td { + padding: 2px; +} +form table tr th { + text-align: left; + padding: 4px; +} +form table tr th { + background: #333333; +} +form table tr td div { + text-align: center; + float: left; + padding-left: 3px; +} +form table tr td div input { + display: block; + margin: 2px auto 0 auto; +} +form table tr td div label { + font-size: 10px; +} +.unimportant, .unimportant * { + font-size: 10px; +} +p.fileinfo { + display: block; + margin: 0; + padding-right: 7em; +} +div.banner { + background-color: #000000; + font-size: 12pt; + font-weight: bold; + text-align: center; + margin: 1em 0; +} +div.banner, div.banner a { + color: white; +} +div.banner a:hover { + color: #000000; + text-decoration: none; +} +img.banner { + display: block; + border: 1px solid #000000; + margin: 12px auto 0 auto; +} +img.post-image { + display: block; + float: left; + margin: 10px 20px; + border: none; +} +div.post img.post-image { + padding: 5px; + margin: 5px 20px 0 0; +} +div.post img.icon { + display: inline; + margin: 0 5px; + padding: 0; +} +div.post i.icon { + margin: 0 4px; + font-size: 16px; +} +div.post.op { + margin-right: 20px; + margin-bottom: 5px; +} +div.post.op hr { + border-color: #000000; +} +p.intro { + margin: 0.5em 0; + padding: 0; + padding-bottom: 0.2em; +} +input.delete { + float: left; + margin: 1px 6px 0 0; +} +p.intro span.subject { + color: #336699; + font-weight: bold; +} +p.intro span.name { + color: #336600; + font-weight: bold; +} +p.intro span.capcode, p.intro a.capcode, p.intro a.nametag { + color: #CC0000; + margin-left: 0; +} +p.intro a { + margin-left: 8px; +} +div.delete { + float: right; +} +div.post.reply p { + margin: 0.3em 0 0 0; +} +div.post.reply div.body { + margin-left: 1.8em; + margin-top: 0.8em; + padding-right: 3em; + padding-bottom: 0.3em; +} +div.post.reply.highlighted { + background: #333366; +} +div.post.reply div.body a { + color: #669900; +} +div.post { + max-width: 97%; +} +div.post div.body { + word-wrap: break-word; + white-space: pre-wrap; +} +div.post.reply { + background: #333333; + margin: 0.2em 16px; + padding: 0.2em 0.3em 0.5em 0.6em; + border-width: 0px; + border-style: none solid solid none; + border-color: #333333; + display: inline-block; +} +span.trip { + color: #CC0000; +} +span.quote { + color: #669900; +} +span.omitted { + display: block; + margin-top: 1em; +} +br.clear { + clear: left; + display: block; +} +span.controls { + float: right; + margin: 0; + padding: 0; + font-size: 80%; +} +span.controls.op { + float: none; + margin-left: 10px; +} +span.controls a { + margin: 0; +} +div#wrap { + width: 900px; + margin:0 auto; +} +div.ban { + background: #333333; + border: 1px solid #333366; + max-width: 700px; + margin: 30px auto; +} +div.ban p, div.ban h2 { + padding: 3px 7px; +} +div.ban h2 { + background: #333366; + color: #999999; + font-size: 12pt; +} +div.ban p { + font-size: 12px; + margin-bottom: 12px; +} +div.ban p.reason { + font-weight: bold; +} +span.heading { + color: #CC0000; + font-size: 11pt; + font-weight: bold; +} +span.spoiler { + background: #000033; + color: #000033; + padding: 0px 1px; +} +div.post.reply div.body span.spoiler a { + color: #000033; +} +span.spoiler:hover, div.post.reply div.body span.spoiler:hover a { + color: #999999; +} +div.styles { + float: right; + padding-bottom: 20px; + +} +div.styles a { + margin: 0 10px; +} +div.styles a.selected { + text-decoration: none; +} +table.test { + width: 100%; +} +table.test td, table.test th { + text-align: left; + padding: 5px; +} +table.test tr.h th { + background: #669900; +} +table.test td img { + margin: 0; +} +fieldset label { + display: block; +} +div.pages { + color: #999999; + background: #333333; + display: inline; + padding: 8px; + border-right: 0px; + border-bottom: 0px; +} +div.pages a.selected { + color: #996699; + font-weight: bolder; +} +div.pages a { + text-decoration: none; +} +div.pages form { + margin: 0; + padding: 0; + display: inline; +} +div.pages form input { + margin: 0 5px; + display: inline; +} +hr { + border: none; + border-top: 1px solid #333333; + height: 0; + clear: left; +} +div.boardlist { + color: #999999; + font-size: 9pt; + margin-top: 3px; +} +div.boardlist.bottom { + margin-top: 20px; +} +div.boardlist a { + text-decoration: none; +} +div.report { + color: #999999; +} +table.modlog { + margin: auto; + width: 100%; +} +table.modlog tr td { + text-align: left; + margin: 0; + padding: 4px 15px 0 0; +} +table.modlog tr th { + text-align: left; + padding: 4px 15px 5px 5px; + white-space: nowrap; +} +table.modlog tr th { + background: #333333; +} +td.minimal, th.minimal { + width: 1%; + white-space: nowrap; +} +div.top_notice { + text-align: center; + margin: 5px auto; +} +span.public_ban { + display: block; + color: #FF0000; + font-weight: bold; + margin-top: 15px; +} +span.toolong { + display: block; + margin-top: 15px; +} +div.blotter { + color: #FF0000; + font-weight: bold; + text-align: center; +} +table.mod.config-editor { + font-size: 9pt; + width: 100%; +} +table.mod.config-editor td { + text-align: left; + padding: 5px; + border-bottom: 1px solid #333333; +} +table.mod.config-editor input[type="text"] { + width: 98%; +} +.desktop-style div.boardlist:nth-child(1) { + position: fixed; + top: 0px; + left: 0px; + right: 0px; + /*text-shadow: white 1px 0px 6px, white 1px 0px 6px, black 1px 0px 3px;*/ + margin-top: 0px; + z-index: 30; + background-color: rgba(0, 0, 0, 0.5); +} +.desktop-style div.boardlist:nth-child(1):hover { + background-color: rgba(0, 0, 0, 1); +} + +.desktop-style body { + padding-top: 20px; +} + +.desktop-style .sub { + background: inherit; +} +.desktop-style .sub .sub { + display: inline-block; + text-indent: -9000px; + width: 7px; + background: url('img/arrow.png') right center no-b .sub:hover, .desktop-style .sub .sub.hover { + display: inline; + text-indent: 0px; + background: inherit; +} + +#attention_bar { + height: 1.5em; + width: 100%; + text-align: center; +} +#attention_bar_form { + display: none; + padding: 0; + margin: 0; +} +#attention_bar_input { + width: 100%; + padding: 0; + margin: 0; + text-align: center; +} +#attention_bar:hover { + background-color: #333333; + opacity: 0.8; +} +p.intro.thread-hidden { + margin: 0px; + padding: 0px; +} From db8173fe62829644a6cdf2e6a787b2ec2244c15b Mon Sep 17 00:00:00 2001 From: Michael Foster Date: Tue, 20 Aug 2013 23:34:41 +1000 Subject: [PATCH 7/7] Remember post password if entered manually --- templates/main.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/templates/main.js b/templates/main.js index 78054a3b..144c5f62 100644 --- a/templates/main.js +++ b/templates/main.js @@ -168,6 +168,9 @@ function dopost(form) { if (form.elements['name']) { localStorage.name = form.elements['name'].value.replace(/( |^)## .+$/, ''); } + if (form.elements['password']) { + localStorage.password = form.elements['password'].value; + } if (form.elements['email'] && form.elements['email'].value != 'sage') { localStorage.email = form.elements['email'].value; }