From 0299beb05ee4af647fbb25ae113018e05aeb39ba Mon Sep 17 00:00:00 2001 From: Neil Drumm <drumm@3064.no-reply.drupal.org> Date: Sun, 6 Aug 2006 22:49:27 +0000 Subject: [PATCH] #72545 by pwolanin, validation for upload module administration. --- includes/file.inc | 36 +++++++++++++++++++ modules/upload/upload.module | 70 ++++++++++++++++++++++++++++++++---- 2 files changed, 99 insertions(+), 7 deletions(-) diff --git a/includes/file.inc b/includes/file.inc index d234bb9de68e..0d8f53ea23a4 100644 --- a/includes/file.inc +++ b/includes/file.inc @@ -712,4 +712,40 @@ function file_directory_path() { return variable_get('file_directory_path', 'files'); } +/** + * Helper function for file_upload_max_size(). + */ +function _file_convert_to_mb($val){ + $val = trim($val); + $last = strtolower($val[strlen($val) - 1]); + switch ($last) { + // The 'G' modifier is available since PHP 5.1.0 + case 'g': + $size = $val * 1024; + break; + case 'k': + $size = $val / 1024; + break; + default: + $size = (int) $val; + } + return $size; +} + +/** + * Determine the maximum file upload size by querying the PHP settings. + * + * @return + * A file size limit in MB based on the PHP upload_max_filesize and post_max_size + */ +function file_upload_max_size() { + static $max_size = -1; + if ($max_size < 0) { + $upload_max = _file_convert_to_mb(ini_get('upload_max_filesize')); + // sanity check- a single upload should not be more than 50% the size limit of the total post + $post_max = _file_convert_to_mb(ini_get('post_max_size')) / 2; + $max_size = ($upload_max < $post_max) ? $upload_max : $post_max; + } + return $max_size; +} diff --git a/modules/upload/upload.module b/modules/upload/upload.module index 99455281d9bc..6ad97cc53e59 100644 --- a/modules/upload/upload.module +++ b/modules/upload/upload.module @@ -112,6 +112,59 @@ function upload_menu($may_cache) { return $items; } +/** + * Form API callback to validate the upload settings form. + */ +function upload_admin_settings_validate($form_id, $form_values) { + if (($form_values['upload_max_resolution'] != '0')) { + if (!preg_match('/^[0-9]+x[0-9]+$/', $form_values['upload_max_resolution'])) { + form_set_error('upload_max_resolution', t('The maximum allowed image size expressed as WIDTHxHEIGHT (e.g. 640x480). Set to 0 for no restriction.')); + } + } + + $default_uploadsize = $form_values['upload_uploadsize_default']; + $default_usersize = $form_values['upload_usersize_default']; + + $exceed_max_msg = t('Your PHP settings limit the maximum file size per upload to %size MB.', array('%size' => file_upload_max_size())).'<br/>'; + $more_info = t("Depending on your sever environment, these settings may be changed in the system-wide php.ini file, a php.ini file in your Drupal root directory, in your Drupal site's settings.php file, or in the .htaccess file in your Drupal root directory."); + + if (!is_numeric($default_uploadsize) || ($default_uploadsize <= 0)) { + form_set_error('upload_uploadsize_default', t('The %role file size limit must be a number and greater than zero.', array('%role' => t('default')))); + } + if (!is_numeric($default_usersize) || ($default_usersize <= 0)) { + form_set_error('upload_usersize_default', t('The %role file size limit must be a number and greater than zero.', array('%role' => t('default')))); + } + if ($default_uploadsize > file_upload_max_size()) { + form_set_error('upload_uploadsize_default', $exceed_max_msg . $more_info); + $more_info = ''; + } + if ($default_uploadsize > $default_usersize) { + form_set_error('upload_uploadsize_default', t('The %role maximum file size per upload is greater than the total file size allowed per user', array('%role' => t('default')))); + } + + foreach ($form_values['roles'] as $rid => $role) { + $uploadsize = $form_values['upload_uploadsize_'. $rid]; + $usersize = $form_values['upload_usersize_'. $rid]; + + if (!is_numeric($uploadsize) || ($uploadsize <= 0)) { + form_set_error('upload_uploadsize_'. $rid, t('The %role file size limit must be a number and greater than zero.', array('%role' => theme('placeholder', $role)))); + } + if (!is_numeric($usersize) || ($usersize <= 0)) { + form_set_error('upload_usersize_'. $rid, t('The %role file size limit must be a number and greater than zero.', array('%role' => theme('placeholder', $role)))); + } + if ($uploadsize > file_upload_max_size()) { + form_set_error('upload_uploadsize_'. $rid, $exceed_max_msg . $more_info); + $more_info = ''; + } + if ($uploadsize > $usersize) { + form_set_error('upload_uploadsize_'. $rid, t('The %role maximum file size per upload is greater than the total file size allowed per user', array('%role' => theme('placeholder', $role)))); + } + } +} + +/** + * Menu callback for the upload settings form. + */ function upload_admin_settings() { $upload_extensions_default = variable_get('upload_extensions_default', 'jpg jpeg gif png txt html doc xls pdf ppt pps'); $upload_uploadsize_default = variable_get('upload_uploadsize_default', 1); @@ -162,34 +215,37 @@ function upload_admin_settings() { '#description' => t('The default maximum size of all files a user can have on the site (in megabytes).'), ); + $form['upload_max_size'] = array('#value' => '<p>'. t('Your PHP settings limit the maximum file size per upload to %size MB.', array('%size' => file_upload_max_size())).'</p>'); + $roles = user_roles(0, 'upload files'); + $form['roles'] = array('#type' => 'value', '#value' => $roles); foreach ($roles as $rid => $role) { - $form["settings_role_$rid"] = array( + $form['settings_role_'. $rid] = array( '#type' => 'fieldset', '#title' => t('Settings for %role', array('%role' => theme('placeholder', $role))), '#collapsible' => TRUE, '#collapsed' => TRUE, ); - $form["settings_role_$rid"]["upload_extensions_$rid"] = array( + $form['settings_role_'. $rid]['upload_extensions_'. $rid] = array( '#type' => 'textfield', '#title' => t('Permitted file extensions'), - '#default_value' => variable_get("upload_extensions_$rid", $upload_extensions_default), + '#default_value' => variable_get('upload_extensions_'. $rid, $upload_extensions_default), '#maxlength' => 255, '#description' => t('Extensions that users in this role can upload. Separate extensions with a space and do not include the leading dot.'), ); - $form["settings_role_$rid"]["upload_uploadsize_$rid"] = array( + $form['settings_role_'. $rid]['upload_uploadsize_'. $rid] = array( '#type' => 'textfield', '#title' => t('Maximum file size per upload'), - '#default_value' => variable_get("upload_uploadsize_$rid", $upload_uploadsize_default), + '#default_value' => variable_get('upload_uploadsize_'. $rid, $upload_uploadsize_default), '#size' => 5, '#maxlength' => 5, '#description' => t('The maximum size of a file a user can upload (in megabytes).'), ); - $form["settings_role_$rid"]["upload_usersize_$rid"] = array( + $form['settings_role_'. $rid]['upload_usersize_'. $rid] = array( '#type' => 'textfield', '#title' => t('Total file size per user'), - '#default_value' => variable_get("upload_usersize_$rid", $upload_usersize_default), + '#default_value' => variable_get('upload_usersize_'. $rid, $upload_usersize_default), '#size' => 5, '#maxlength' => 5, '#description' => t('The maximum size of all files a user can have on the site (in megabytes).'), -- GitLab