Apache2-ASP
view release on metacpan or search on metacpan
lib/Apache2/ASP/MediaManager.pm view on Meta::CPAN
<%
}# end while()
%>
</o>
</body>
</html>
B<REALLY IMPORTANT!>: Notice the C<?mode=create&uploadID=2kj4hkj234h> in the C<action>
attribute of the C<form> tag. The C<mode> tells the MediaManager that we are B<creating>
a file, and the C<uploadID> will allow us to track the progress of the upload.
B<IMPORTANT>: Check your configuration, where you see:
<config>
...
<web>
...
<media_manager_upload_root>@ServerRoot@/MEDIA</media_manager_upload_root>
...
</web>
...
</config>
Make B<*sure*> that your webserver has ownership or read/write access to that folder
and all of its contents.
When you access http://yoursite.com/mm-test.asp in your browser and submit the form,
C<Apache2::ASP::MediaManager> will save it under your C<media_manager_upload_root>
folder for you.
=head1 DESCRIPTION
Handling file uploads can be a real pain. Restricting file uploads and downloads
to a select group of users is also problematic.
B<And Then...>
And then there was C<Apache2::ASP::MediaManager>. Now you can have fully-functional
file uploads in seconds.
=head1 UPLOAD PROGRESS INDICATORS
C<Apache2::ASP::MediaManager> makes it easy to provide upload progress indicators.
Remember that C<uploadID> parameter in the C<action> attribute of your form? While
the upload is taking place, the C<$Session> object is getting updated with the
status of the upload. If you were to make another handler - C</handlers/UploadProgress.pm> -
and insert the following code:
package UploadProgress;
use strict;
use base 'Apache2::ASP::FormHandler';
use vars __PACKAGE__->VARS;
sub run {
my ($s, $context) = @_;
my $uploadID = $Form->{uploadID};
$Session->{"upload$uploadID" . "percent_complete"} ||= 0;
$Response->Expires( -30 );
$Response->Write( $Session->{"upload$uploadID" . "percent_complete"} );
}# end run()
1;# return true:
And add call out to it via AJAX - you can get real-time upload progress information
about the current upload.
Example:
window.setInterval(function() {
httpOb.open("GET", "/handlers/UploadProgress?uploadID=2kj4hkj234h", true);
httpOb.onreadystatechange = function() {
if( httpOb.readyState == 4 ) {
document.getElementById("percent_complete").innerHTML = httpOb.responseText + '%';
}// end if()
};
}, 1000);
You should also add an element with an id of "percent_complete" to he form:
<div id="percent_complete">0%</div>
=head1 PUBLIC PROPERTIES
None.
=head1 PUBLIC METHODS
Nothing you need to worry about.
=head1 EVENTS
B<About the C<$Upload> argument>:
The C<$Upload> argument is an instance of L<Apache2::ASP::UploadHookArgs>.
=head2 before_download( $self, $context )
Called before allowing a file to be downloaded from the server.
B<NOTE>: This method must return true, or the file will not be downloaded.
=head2 after_download( $self, $context )
Called after allowing a file to be downloaded from the server.
=head2 before_create( $self, $context, $Upload )
Called before allowing a new file to be uploaded to the server.
B<NOTE>: This method must return true, or the file will not be created.
=head2 after_create( $self, $context, $Upload )
Called after allowing a new file to be uploaded to the server.
=head2 before_update( $self, $context, $Upload )
Called before allowing a new file to be uploaded to replace an existing file.
B<NOTE>: This method must return true, or the file will not be updated.
=head2 after_update( $self, $context, $Upload )
Called after a new file has been uploaded to replace an existing file.
=head2 before_delete( $self, $context, $filename )
Called before deleting a file.
B<NOTE>: This method must return true, or the file will not be deleted.
=head2 after_delete( $self, $context, $filename )
Called after deleting a file.
=head1 BUGS
It's possible that some bugs have found their way into this release.
Use RT L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=Apache2-ASP> to submit bug reports.
( run in 2.188 seconds using v1.01-cache-2.11-cpan-39bf76dae61 )