X-Git-Url: https://git.p6c8.net/jirafeau_project.git/blobdiff_plain/a80b0189a72e4d5e3982ed7c4f47bdda09e3def2..c4e741fcf19f57e832f239f56b3829f9e15e8ec0:/f.php diff --git a/f.php b/f.php index 9bbe4d9..a272ad5 100644 --- a/f.php +++ b/f.php @@ -49,6 +49,13 @@ if (!preg_match ('/[0-9a-zA-Z_-]+$/', $link_name)) $link = jirafeau_get_link ($link_name); if (count ($link) == 0) +{ + /* Try alias. */ + $alias = jirafeau_get_alias (md5 ($link_name)); + if (count ($alias) > 0) + $link = jirafeau_get_link ($alias["destination"]); +} +if (count ($link) == 0) { require (JIRAFEAU_ROOT.'lib/template/header.php'); echo '<div class="error"><p>' . t('Sorry, the requested file is not found') . @@ -135,17 +142,24 @@ if (!empty ($link['key'])) '</td></tr>' . '<tr><td>' . t('By using our services, you accept our'). ' <a href="' . $cfg['web_root'] . '/tos.php' . '">' . t('Term Of Service') . '</a>' . - '</td></tr>' . - '<tr><td>'; - ?><input type="submit" id = "submit_download" value="<?php echo t('Download'); ?>" - onclick="document.getElementById('submit_post').action=' + '</td></tr>'; + + if ($link['onetime'] == 'O') + { + echo '<tr><td id="self_destruct">' . + t('Warning, this file will self-destruct after being read') . + '</td></tr>'; + } + + ?><tr><td><input type="submit" id = "submit_download" value="<?php echo t('Download'); ?>" + onclick="document.getElementById('submit_post').action=' <?php echo $cfg['web_root'] . '/f.php?h=' . $link_name . '&d=1'; if (!empty($crypt_key)) echo '&k=' . urlencode($crypt_key); ?>'; document.getElementById('submit_download').submit ();"/><?php - if ($cfg['download_page'] && $cfg['preview'] && jirafeau_is_viewable($link['mime_type'])) + if ($cfg['preview'] && jirafeau_is_viewable($link['mime_type'])) { ?><input type="submit" id = "submit_preview" value="<?php echo t('Preview'); ?>" onclick="document.getElementById('submit_post').action=' @@ -166,7 +180,6 @@ if (!empty ($link['key'])) $password_challenged = true; else { - header ("Access denied"); require (JIRAFEAU_ROOT.'lib/template/header.php'); echo '<div class="error"><p>' . t('Access denied') . '</p></div>'; @@ -176,7 +189,7 @@ if (!empty ($link['key'])) } } -if ($cfg['download_page'] && !$password_challenged && !$do_download && !$do_preview) +if (!$password_challenged && !$do_download && !$do_preview) { require (JIRAFEAU_ROOT.'lib/template/header.php'); echo '<div>' . @@ -185,22 +198,32 @@ if ($cfg['download_page'] && !$password_challenged && !$do_download && !$do_prev echo '" ' . 'method = "post" id = "submit_post">'; ?> <input type = "hidden" name = "jirafeau" value = "<?php echo JIRAFEAU_VERSION ?>"/><?php - echo '<fieldset><legend>' . $link['file_name'] . '</legend><table>' . + echo '<fieldset><legend>' . htmlspecialchars($link['file_name']) . '</legend><table>' . '<tr><td>' . - t('You are about to download') . ' "' . $link['file_name'] . '" (' . jirafeau_human_size($link['file_size']) . ')' . + t('You are about to download') . ' "' . htmlspecialchars($link['file_name']) . '" (' . jirafeau_human_size($link['file_size']) . ')' . '</td></tr>' . '<tr><td>' . - t('By using our services, you accept our'). ' <a href="' . $cfg['web_root'] . '/tos.php' . '">' . t('Term Of Service') . '</a>'; - ?></td></tr><tr><td><input type="submit" id = "submit_download" value="<?php echo t('Download'); ?>" - onclick="document.getElementById('submit_post').action=' + t('By using our services, you accept our'). ' <a href="' . $cfg['web_root'] . '/tos.php' . '">' . t('Term Of Service') . '</a>' . + '</td></tr>'; + + if ($link['onetime'] == 'O') + { + echo '<tr><td id="self_destruct">' . + t('Warning, this file will self-destruct after being read') . + '</td></tr>'; + } + + ?> + <tr><td><input type="submit" id = "submit_download" value="<?php echo t('Download'); ?>" + onclick="document.getElementById('submit_post').action=' <?php echo $cfg['web_root'] . '/f.php?h=' . $link_name . '&d=1'; if (!empty($crypt_key)) echo '&k=' . urlencode($crypt_key); ?>'; - document.getElementById('submit_download').submit ();"/><?php + document.getElementById('submit_post').submit ();"/><?php - if ($cfg['download_page'] && $cfg['preview'] && jirafeau_is_viewable($link['mime_type'])) + if ($cfg['preview'] && jirafeau_is_viewable($link['mime_type'])) { ?><input type="submit" id = "submit_preview" value="<?php echo t('Preview'); ?>" onclick="document.getElementById('submit_post').action=' @@ -209,7 +232,7 @@ if ($cfg['download_page'] && !$password_challenged && !$do_download && !$do_prev if (!empty($crypt_key)) echo '&k=' . urlencode($crypt_key); ?>'; - document.getElementById('submit_preview').submit ();"/><?php + document.getElementById('submit_post').submit ();"/><?php } echo '</td></tr>'; echo '</table></fieldset></form></div>'; @@ -224,6 +247,7 @@ if (!jirafeau_is_viewable ($link['mime_type']) || !$cfg['preview'] || $do_downlo else header ('Content-Disposition: filename="' . $link['file_name'] . '"'); header ('Content-Type: ' . $link['mime_type']); +header ('Content-MD5: ' . hex_to_base64($link['md5'])); /* Read encrypted file. */ if ($link['crypted'])