progressbar for New->From Url
This commit is contained in:
parent
59ab8b14c7
commit
a49c07cf88
|
@ -1,16 +1,23 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
// Init owncloud
|
// Init owncloud
|
||||||
|
global $eventSource;
|
||||||
|
|
||||||
|
if(!OC_User::isLoggedIn()){
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
OCP\JSON::checkLoggedIn();
|
session_write_close();
|
||||||
OCP\JSON::callCheck();
|
|
||||||
|
|
||||||
// Get the params
|
// Get the params
|
||||||
$dir = isset( $_POST['dir'] ) ? stripslashes($_POST['dir']) : '';
|
$dir = isset( $_REQUEST['dir'] ) ? stripslashes($_REQUEST['dir']) : '';
|
||||||
$filename = isset( $_POST['filename'] ) ? stripslashes($_POST['filename']) : '';
|
$filename = isset( $_REQUEST['filename'] ) ? stripslashes($_REQUEST['filename']) : '';
|
||||||
$content = isset( $_POST['content'] ) ? $_POST['content'] : '';
|
$content = isset( $_REQUEST['content'] ) ? $_REQUEST['content'] : '';
|
||||||
$source = isset( $_POST['source'] ) ? stripslashes($_POST['source']) : '';
|
$source = isset( $_REQUEST['source'] ) ? stripslashes($_REQUEST['source']) : '';
|
||||||
|
|
||||||
|
if($source){
|
||||||
|
$eventSource=new OC_EventSource();
|
||||||
|
}
|
||||||
|
|
||||||
if($filename == '') {
|
if($filename == '') {
|
||||||
OCP\JSON::error(array("data" => array( "message" => "Empty Filename" )));
|
OCP\JSON::error(array("data" => array( "message" => "Empty Filename" )));
|
||||||
|
@ -21,22 +28,49 @@ if(strpos($filename,'/')!==false){
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function progress($notification_code, $severity, $message, $message_code, $bytes_transferred, $bytes_max){
|
||||||
|
static $filesize = 0;
|
||||||
|
static $lastsize = 0;
|
||||||
|
global $eventSource;
|
||||||
|
|
||||||
|
switch($notification_code) {
|
||||||
|
case STREAM_NOTIFY_FILE_SIZE_IS:
|
||||||
|
$filesize = $bytes_max;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case STREAM_NOTIFY_PROGRESS:
|
||||||
|
if ($bytes_transferred > 0) {
|
||||||
|
if (!isset($filesize)) {
|
||||||
|
} else {
|
||||||
|
$progress = (int)(($bytes_transferred/$filesize)*100);
|
||||||
|
if($progress>$lastsize){//limit the number or messages send
|
||||||
|
$eventSource->send('progress',$progress);
|
||||||
|
}
|
||||||
|
$lastsize=$progress;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if($source){
|
if($source){
|
||||||
if(substr($source,0,8)!='https://' and substr($source,0,7)!='http://'){
|
if(substr($source,0,8)!='https://' and substr($source,0,7)!='http://'){
|
||||||
OCP\JSON::error(array("data" => array( "message" => "Not a valid source" )));
|
OCP\JSON::error(array("data" => array( "message" => "Not a valid source" )));
|
||||||
exit();
|
exit();
|
||||||
}
|
}
|
||||||
$sourceStream=fopen($source,'rb');
|
|
||||||
|
$ctx = stream_context_create(null, array('notification' =>'progress'));
|
||||||
|
$sourceStream=fopen($source,'rb', false, $ctx);
|
||||||
$target=$dir.'/'.$filename;
|
$target=$dir.'/'.$filename;
|
||||||
$result=OC_Filesystem::file_put_contents($target,$sourceStream);
|
$result=OC_Filesystem::file_put_contents($target,$sourceStream);
|
||||||
if($result){
|
if($result){
|
||||||
$mime=OC_Filesystem::getMimetype($target);
|
$mime=OC_Filesystem::getMimetype($target);
|
||||||
OCP\JSON::success(array("data" => array('mime'=>$mime)));
|
$eventSource->send('success',$mime);
|
||||||
exit();
|
|
||||||
}else{
|
}else{
|
||||||
OCP\JSON::error(array("data" => array( "message" => "Error while downloading ".$source. ' to '.$target )));
|
$eventSource->send('error',"Error while downloading ".$source. ' to '.$target);
|
||||||
exit();
|
|
||||||
}
|
}
|
||||||
|
$eventSource->close();
|
||||||
|
exit();
|
||||||
}else{
|
}else{
|
||||||
if($content){
|
if($content){
|
||||||
if(OC_Filesystem::file_put_contents($dir.'/'.$filename,$content)){
|
if(OC_Filesystem::file_put_contents($dir.'/'.$filename,$content)){
|
||||||
|
|
|
@ -497,23 +497,27 @@ $(document).ready(function() {
|
||||||
localName=(localName.match(/:\/\/(.[^/]+)/)[1]).replace('www.','');
|
localName=(localName.match(/:\/\/(.[^/]+)/)[1]).replace('www.','');
|
||||||
}
|
}
|
||||||
localName = getUniqueName(localName);
|
localName = getUniqueName(localName);
|
||||||
$.post(
|
$('#uploadprogressbar').progressbar({value:0});
|
||||||
OC.filePath('files','ajax','newfile.php'),
|
$('#uploadprogressbar').fadeIn();
|
||||||
{dir:$('#dir').val(),source:name,filename:localName},
|
|
||||||
function(result){
|
|
||||||
if(result.status == 'success'){
|
|
||||||
var date=new Date();
|
|
||||||
FileList.addFile(localName,0,date);
|
|
||||||
var tr=$('tr').filterAttr('data-file',localName);
|
|
||||||
tr.data('mime',result.data.mime);
|
|
||||||
getMimeIcon(result.data.mime,function(path){
|
|
||||||
tr.find('td.filename').attr('style','background-image:url('+path+')');
|
|
||||||
});
|
|
||||||
}else{
|
|
||||||
|
|
||||||
}
|
var eventSource=new OC.EventSource(OC.filePath('files','ajax','newfile.php'),{dir:$('#dir').val(),source:name,filename:localName});
|
||||||
}
|
eventSource.listen('progress',function(progress){
|
||||||
);
|
$('#uploadprogressbar').progressbar('value',progress);
|
||||||
|
});
|
||||||
|
eventSource.listen('success',function(mime){
|
||||||
|
$('#uploadprogressbar').fadeOut();
|
||||||
|
var date=new Date();
|
||||||
|
FileList.addFile(localName,0,date);
|
||||||
|
var tr=$('tr').filterAttr('data-file',localName);
|
||||||
|
tr.data('mime',mime);
|
||||||
|
getMimeIcon(mime,function(path){
|
||||||
|
tr.find('td.filename').attr('style','background-image:url('+path+')');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
eventSource.listen('error',function(error){
|
||||||
|
$('#uploadprogressbar').fadeOut();
|
||||||
|
alert(error);
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
var li=$(this).parent();
|
var li=$(this).parent();
|
||||||
|
|
Loading…
Reference in New Issue