alecpl
2011-03-17 569701d7002e71fbf76e9acaa6c83e5bee90b411
- Handle properly situation when uploaded attachment file is too big


1 files modified
32 ■■■■■ changed files
program/steps/mail/attachments.inc 32 ●●●●● patch | view | raw | blame | history
program/steps/mail/attachments.inc
@@ -83,23 +83,28 @@
if (is_array($_FILES['_attachments']['tmp_name'])) {
  foreach ($_FILES['_attachments']['tmp_name'] as $i => $filepath) {
    $attachment = array(
      'path' => $filepath,
      'size' => $_FILES['_attachments']['size'][$i],
      'name' => $_FILES['_attachments']['name'][$i],
      'mimetype' => rc_mime_content_type($filepath, $_FILES['_attachments']['name'][$i], $_FILES['_attachments']['type'][$i]),
      'group' => $COMPOSE_ID,
    );
    // Process uploaded attachment if there is no error
    $err = $_FILES['_attachments']['error'][$i];
    $attachment = $RCMAIL->plugins->exec_hook('attachment_upload', $attachment);
    if (!$err) {
      $attachment = array(
        'path' => $filepath,
        'size' => $_FILES['_attachments']['size'][$i],
        'name' => $_FILES['_attachments']['name'][$i],
        'mimetype' => rc_mime_content_type($filepath, $_FILES['_attachments']['name'][$i], $_FILES['_attachments']['type'][$i]),
        'group' => $COMPOSE_ID,
      );
    if ($attachment['status'] && !$attachment['abort']) {
      $attachment = $RCMAIL->plugins->exec_hook('attachment_upload', $attachment);
    }
    if (!$err && $attachment['status'] && !$attachment['abort']) {
      $id = $attachment['id'];
      // store new attachment in session
      unset($attachment['status'], $attachment['abort']);
      $_SESSION['compose']['attachments'][$id] = $attachment;
      if (($icon = $_SESSION['compose']['deleteicon']) && is_file($icon)) {
        $button = html::img(array(
          'src' => $icon,
@@ -117,7 +122,7 @@
      ), $button);
      $content .= Q($attachment['name']);
      $OUTPUT->command('add2attachment_list', "rcmfile$id", array(
        'html' => $content,
        'name' => $attachment['name'],
@@ -125,7 +130,6 @@
        'complete' => true), $uploadid);
    }
    else {  // upload failed
      $err = $_FILES['_attachments']['error'][$i];
      if ($err == UPLOAD_ERR_INI_SIZE || $err == UPLOAD_ERR_FORM_SIZE) {
        $msg = rcube_label(array('name' => 'filesizeerror', 'vars' => array('size' => show_bytes(parse_bytes(ini_get('upload_max_filesize'))))));
      }
@@ -135,7 +139,7 @@
      else {
        $msg = rcube_label('fileuploaderror');
      }
      $OUTPUT->command('display_message', $msg, 'error');
      $OUTPUT->command('remove_from_attachment_list', $uploadid);
    }