<?php
/*
* Jirafeau, your web file repository
- * Copyright (C) 2012 Jerome Jutteau <j.jutteau@gmail.com>
+ * Copyright (C) 2013
+ * Jerome Jutteau <j.jutteau@gmail.com>
+ * Jimmy Beauvois <jimmy.beauvois@gmail.com>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
*/
define ('JIRAFEAU_ROOT', dirname (__FILE__) . '/');
-require (JIRAFEAU_ROOT . 'lib/config.php');
+require (JIRAFEAU_ROOT . 'lib/config.original.php');
require (JIRAFEAU_ROOT . 'lib/settings.php');
require (JIRAFEAU_ROOT . 'lib/functions.php');
require (JIRAFEAU_ROOT . 'lib/lang.php');
require (JIRAFEAU_ROOT . 'lib/template/header.php');
-check_errors ();
+check_errors ($cfg);
if (has_error ())
{
show_errors ();
require (JIRAFEAU_ROOT . 'lib/template/footer.php');
exit;
}
+
+/* Ask password if upload password is set. */
+if (jirafeau_has_upload_password ($cfg))
+{
+ session_start();
+
+ /* Unlog if asked. */
+ if (isset ($_POST['action']) && (strcmp ($_POST['action'], 'logout') == 0))
+ session_unset ();
+
+ /* Auth. */
+ if (isset ($_POST['upload_password']))
+ {
+ if (jirafeau_challenge_upload_password ($cfg, $_POST['upload_password']))
+ {
+ $_SESSION['upload_auth'] = true;
+ $_SESSION['user_upload_password'] = $_POST['upload_password'];
+ }
+ else
+ {
+ $_SESSION['admin_auth'] = false;
+ echo '<div class="error"><p>' . t('Wrong password.') . '</p></div>';
+ require (JIRAFEAU_ROOT.'lib/template/footer.php');
+ exit;
+ }
+ }
+
+ /* Show auth page. */
+ if (!isset ($_SESSION['upload_auth']) || $_SESSION['upload_auth'] != true)
+ {
+ ?>
+ <form action = "<?php echo basename(__FILE__); ?>" method = "post">
+ <fieldset>
+ <table>
+ <tr>
+ <td class = "label"><label for = "enter_password">
+ <?php echo t('Upload password') . ':';?></label>
+ </td>
+ <td class = "field"><input type = "password"
+ name = "upload_password" id = "upload_password"
+ size = "40" />
+ </td>
+ </tr>
+ <tr class = "nav">
+ <td></td>
+ <td class = "nav next">
+ <input type = "submit" name = "key" value =
+ "<?php echo t('Login'); ?>" />
+ </td>
+ </tr>
+ </table>
+ </fieldset>
+ </form>
+ <?php
+ require (JIRAFEAU_ROOT.'lib/template/footer.php');
+ exit;
+ }
+}
+
?>
<div id="upload_finished">
<p>
</div>
<div id="upload">
+<fieldset>
<legend>
- <?php echo t('Select a file'); ?> :
+ <?php echo t('Select a file'); ?>
</legend>
<p>
<input type="file" id="file_select" size="30"
document.getElementById('send').style.display = '';
"/>
</p>
- <p class="config">
- <?php echo t('Maximum file size') . ': ' . jirafeau_get_max_upload_size (); ?>
- </p>
- <p>
- <input type="submit" id="send" value="<?php echo t('Send'); ?>"
- onclick="
- document.getElementById('upload').style.display = 'none';
- document.getElementById('uploading').style.display = '';
- start_upload('<?php echo $cfg['web_root']; ?>');
- "/>
- </p>
+
<div id="options">
<table id="option_table">
<tr>
<option value = "month"><?php echo t('One month');?></option>
</select></td>
</tr>
+ <p id="max_file_size" class="config"></p>
+ <p>
+ <?php
+ if (jirafeau_has_upload_password ($cfg) && $_SESSION['upload_auth'])
+ {
+ ?>
+ <input type="hidden" id="upload_password" name="upload_password" value="<?php echo $_SESSION['user_upload_password'] ?>"/>
+ <?php
+ }
+ else
+ {
+ ?>
+ <input type="hidden" id="upload_password" name="upload_password" value=""/>
+ <?php
+ }
+ ?>
+ <input type="submit" id="send" value="<?php echo t('Send'); ?>"
+ onclick="
+ document.getElementById('upload').style.display = 'none';
+ document.getElementById('uploading').style.display = '';
+ upload ('<?php echo $cfg['web_root']; ?>', <?php echo jirafeau_get_max_upload_size_bytes (); ?>);
+ "/>
+ </p>
</table>
- </div>
+ </div> </fieldset>
+
+ <?php
+ if (jirafeau_has_upload_password ($cfg))
+ {
+ ?>
+ <form action = "<?php echo basename(__FILE__); ?>" method = "post">
+ <input type = "hidden" name = "action" value = "logout"/>
+ <input type = "submit" value = "<?php echo t('Logout'); ?>" />
+ </form>
+ <?php
+ }
+ ?>
+
</div>
+
<script lang="Javascript">
document.getElementById('uploading').style.display = 'none';
document.getElementById('upload_finished').style.display = 'none';
document.getElementById('options').style.display = 'none';
document.getElementById('send').style.display = 'none';
+ if (!check_html5_file_api ())
+ document.getElementById('max_file_size').innerHTML = '<?php
+ echo t('You browser may not support HTML5 so the maximum file size is ') . jirafeau_get_max_upload_size ();
+ ?>';
</script>
<?php require (JIRAFEAU_ROOT . 'lib/template/footer.php'); ?>