Code Search for Developers
 
 
  

view_attachment.html from AlphaMail at Krugle


Show view_attachment.html syntax highlighted

% # vim: set syntax=mason:
<%args>
$file => -1
$type => 'application'
$subtype => 'octet-stream'
$mode => "normal"
</%args>
<%init>
my $user;
my $prefix;
eval {
   $user = Apache2::SiteControl->getCurrentUser($r);
   $prefix = $config->getScratchDir($user);
};
if($@) {
   $logger->error("Unable to get attachment: $@");
   $m->redirect(build_url("$base/mail/index.html", { message => "Request failed" }));
}
my $sandbox = $config->get("sandbox_util");
my $sandbox_dir = $config->get("sandbox_dir");
my $sandbox_user = $config->get("sandbox_user", 'sandbox');
my $jpegtopnm = $config->get("jpegtopnm");
my $pnmtojpeg = $config->get("pnmtojpeg");
my $pnmscale = $config->get("pnmscale");
my $giftopnm = $config->get("giftopnm");
my $tifftopnm = $config->get("tifftopnm");
my $pngtopnm = $config->get("pngtopnm");
my $cat = $config->get("cat");
my $iconsize = $config->get("iconsize");
my $username = $user->getUsername();
my $cachetime = $config->get("message_tmpdir_cachetime", 10) . ' min';

$file =~ s/\\/\\\\/g; # Un-escape escapes
if($file == -1) {
   $m->redirect(build_url("$base/mail/index.html", { message => "No filename for attachment." }));
} elsif($file =~ m!(^|/)\.\./!) {
   $logger->error("Security Violation! $username attempted to view $file. Prefix was $prefix");
   $m->redirect(build_url("$base/mail/index.html", { message => "Security violation on filename $file" }));
}

$file = "$prefix/$file"; # Full path to tmp file.

# make sure the file is still there...
if(!-r $file) {
   # We probably renewed an old session (see bug 425)...force them to re-click
   # on the message.
   $m->redirect(build_url("$base/mail/index.html", { message => "Please try again (decoded attachment was cleaned up due to session inactivity). If it fails again then contact support." }));
}

$subtype = lc($subtype);
$subtype = "tiff" if $subtype eq 'tif';

my $line;
my %converters = ( jpeg => $jpegtopnm,
                   gif => $giftopnm,
                   tiff => $tifftopnm,
                   png => $pngtopnm,
                   pnm => $cat,
                 );
my $converter = $converters{$subtype};
$logger->debug("Running in $mode mode with $type/$subtype on $file");
if($mode eq "shrink" && $type eq "image" && $converter) {
   $r->content_type("$type/$subtype");
   # cache icons
   my $key = "${file}_${type}_${subtype}";
   my $icon = $m->cache->get($key);
   if(!defined($icon)) {
      $logger->debug("tring to convert using: $sandbox $sandbox_user $sandbox_dir $converter < '$file' | $sandbox $sandbox_user $sandbox_dir $pnmscale -ysize $iconsize | $sandbox $pnmtojpeg|");
      # The redirection happens before sandbox runs. That is OK, since the fds
      # are passed along for the ride...no need to use the tmp dir in sandbox.
      open DATA, "$sandbox '$sandbox_user' '$sandbox_dir' $converter < '$file' | $sandbox '$sandbox_user' '$sandbox_dir' $pnmscale -ysize $iconsize | $sandbox '$sandbox_user' '$sandbox_dir' $pnmtojpeg|" or $logger->error("problem running: $sandbox '$sandbox_user' '$sandbox_dir' $converter < $file | $sandbox '$sandbox_user' '$sandbox_dir' $pnmscale -ysize $iconsize | $sandbox '$sandbox_user' '$sandbox_dir' $pnmtojpeg|");
      while($line = <DATA>) {
         $icon .= $line;
         $m->print($line);
      }
      close DATA;
      $m->cache->set($key, $icon, $cachetime);
      $logger->debug("Cached $file icon for later use.");
   } else {
      $logger->debug("Using cached icon for $file.");
      $m->print($icon);
   }
} elsif($type eq "image" && $converter && $subtype =~ m/^(tiff|png)$/) {
   # Convert to better format for browser
   $logger->debug("Converting $file to JPEG for browser compatibility");
   $r->content_type("image/jpeg");
   open DATA, "$sandbox '$sandbox_user' '$sandbox_dir' $converter < '$file' | $sandbox '$sandbox_user' '$sandbox_dir' $pnmtojpeg|" or $logger->error("problem converting file: $sandbox '$sandbox_user' '$sandbox_dir' $converter < $file | $sandbox '$sandbox_user' '$sandbox_dir' $pnmtojpeg|");
   while($line = <DATA>) {
      $m->print($line);
   }
   close DATA;
} else {
   $logger->debug("Sending $file unmodified");
   $r->content_type("$type/$subtype");
   open DATA, "<$file" or $logger->error("No such file: $file");
   while($line = <DATA>) {
      $m->print($line);
   }
   close DATA;
}
</%init>
<%once>
our $logger = Log::Log4perl->get_logger('alphamail');
our $base = $config->get('base_uri');
</%once>




See more files for this project here

AlphaMail

AlphaMail is an accelerated web mail interface with a C++ middleware layer that is more effective than an IMAP proxy which is a highly scalable (10k+ users). The interface includes modern features, Section 508 compliance, and universal browser support.

Project homepage: http://sourceforge.net/projects/alphamail
Programming language(s): C++,Java,JavaScript,Perl
License: other

  addressbook/
    edit.mhtml
    import.mhtml
    import_complete.html
    import_csv.html
    import_csv_save.html
    import_fname.html
    import_imho.html
    import_lname.html
    index.html
    lists.mhtml
    process_edit.html
    process_lists.html
    process_take.html
    take.html
  admin/
    autohandler
    index.html
    show_stats.mhtml
    test.mhtml
  docs/
    faq/
      colors.gif
      dates1.gif
      drafts.gif
      filter.gif
      general.html
      index.html
      notrash1.gif
      notrash2.gif
      notrash3.gif
      other.html
      sort.gif
      timeout.gif
    new_features.html
  settings/
    add_filter.html
    altfolder_update.html
    altprefix_update.html
    edit_folders.html
    export.mhtml
    export_mail.html
    filters.mhtml
    folders.mhtml
    general.mhtml
    index.html
    share.mhtml
    sharing_agree.html
    signatures.mhtml
    update_folderlist.html
    update_general.html
    update_signatures.html
  viewers/
    excel.html
    html.html
    targz.html
    text.html
    word.html
    zip.html
  address_mail.html
  addresslist.html
  autohandler
  check_spelling.html
  compose.html
  feedback.html
  first_login.html
  fix_spelling.html
  folderlist.mhtml
  footer.mhtml
  get_attachment.html
  header.mhtml
  help.html
  index.html
  logout.html
  menu.mhtml
  other_folders.html
  process_compose.html
  process_first_login.html
  process_messages.html
  process_read_message.html
  process_search.html
  quota.html
  quota_graph.html
  raw.html
  read.html
  remove_attachment.html
  renew_session.html
  resume_compose.html
  sanitized.html
  share_options.html
  share_upload.html
  verify_password.html
  view_attachment.html