Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:12173 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 78305 invoked by uid 1010); 15 Aug 2004 15:32:42 -0000 Delivered-To: ezmlm-scan-internals@lists.php.net Delivered-To: ezmlm-internals@lists.php.net Received: (qmail 75549 invoked from network); 15 Aug 2004 15:32:20 -0000 Received: from unknown (HELO mail.troja.net) (80.190.230.99) by pb1.pair.com with SMTP; 15 Aug 2004 15:32:20 -0000 Received: from localhost (localhost [127.0.0.1]) by mail.troja.net (Postfix) with ESMTP id 2572D771C for ; Sun, 15 Aug 2004 17:32:18 +0200 (CEST) Received: from mail.troja.net ([127.0.0.1]) by localhost (cyca [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id 10612-05 for ; Sun, 15 Aug 2004 17:32:15 +0200 (CEST) Received: from vega.php.net (p50847427.dip.t-dialin.net [80.132.116.39]) (using SSLv3 with cipher EDH-RSA-DES-CBC3-SHA (168/168 bits)) (No client certificate requested) by mail.troja.net (Postfix) with ESMTP id 2D3AF7708 for ; Sun, 15 Aug 2004 17:32:14 +0200 (CEST) Message-ID: <6.1.2.0.0.20040815173220.03a33548@bla> X-Sender: thetaphi.troja.net@bla X-Mailer: QUALCOMM Windows Eudora Version 6.1.2.0 Date: Sun, 15 Aug 2004 17:32:25 +0200 To: internals@lists.php.net Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii"; format=flowed X-Virus-Scanned: by amavisd-new at troja.net X-Spam-Status: Yes, hits=5.6 tagged_above=0.0 required=4.0 tests=AWL, RCVD_IN_DYNABLOCK, RCVD_IN_NJABL, RCVD_IN_NJABL_DIALUP, RCVD_IN_SORBS X-Spam-Level: ***** X-Spam-Flag: YES Subject: Re: [PHP-DEV] [PATCH] PHP_IMAP New Function "imap_partialbody" to fetch chunks of a MIME attachment From: thetaphi@php.net (Uwe Schindler) How about the idea to make a function like "imap_getbodystream(...)" that returns a PHP stream that can be read with fread() etc. and then closed by fclose()?. This could be done by using Wez's PHP stream wrappers in PHP5 (even in PHP4.3). Uwe At 00:47 15.08.2004, you wrote: >This new function is intended to add "chunking" capability to fetching >attachments from an email using the IMAP library. Currently the attachment >fetch is done with imap_fetchbody , and is placed entirely in memory, ergo >- if the attachment is larger than the available memory it will fail. > >This function has the following prototype - string >imap_partialbody(resource stream_id, int msg_no, int section, int start, >int len [, int options]) >It's exactly like imap_fetchbody, except it adds the parameters start >(for the start position offset) and len (for the number of bytes to >retrieve). I've also made sure that the correct checks for message number >are in the code (as per the recent change to imap_fetchbody). > >It uses the function "mail_partial_body" in the C Client, which doesn't >appear in any of the very dated documentation, but I found a few postings >by Mark Crispin explaining how to use it, and it's also been used in pine. >One complication is that it uses a callback to populate the buffer, but I >found some hints on how to use a "spare pointer " element in the IMAP >stream structure from a post by him in one of the online IMAP forums here >- http://www.webservertalk.com/message299504.html > >Obviously the benefit is that a new attachment retrieval could be >implemented in webmail such as IMP that doesn't require the memlimit on >the server to be set to some absurd value, and would be less likely bring >the server to its knees when some idiot mails a 50M video to a group of >his friends. Note however c-client is still greedy about memory for its >cache (theres nothing that can be done about that) - but this doesn't >figure in the PHP memlimit. >A snippet of some resulting PHP using the function (struct is the return >from imap_fetchstructure - note I haven't put anything in to decode the >structure or errorcheck the return for brevity). CHUNKSIZE is how much to >fetch at a time (100K works quite well) >$size=$struct->parts[$partindex]->bytes; >$fp=fopen($attachfile,"w"); >for ($i=0;$i<$size;$i+=CHUNKSIZE) >{ > $len = (($size-$i) $pbody = imap_partialbody($imap,$msgno,$partno,$i,$len); > fwrite($fp,$pbody); >} > >You will find this code works fine on a large attachment, and doesn't blow >the memlimit when its set to the default of 8M. >The next problem of course is that php/php_imap doesn't have a streamed >Base64 decoder - though I've used a simple command line one quite effectively. > >I'm guessing if this is of interest, it will be of most interest to the >HORDE/IMP team? > >Crispin Olson ----- Uwe Schindler thetaphi@php.net - http://www.php.net NSAPI SAPI developer Erlangen, Germany