17e631bc5e
Create OC_JSON class, for single point of creating json responses. No real logic change, this just cleans up the code a bit.
56 lines
1.1 KiB
PHP
56 lines
1.1 KiB
PHP
<?php
|
|
//provide auto completion of paths for use with jquer ui autocomplete
|
|
|
|
|
|
// Init owncloud
|
|
require_once('../../lib/base.php');
|
|
|
|
OC_JSON::checkLoggedIn();
|
|
|
|
// Get data
|
|
$query = $_GET['term'];
|
|
$dirOnly=(isset($_GET['dironly']))?($_GET['dironly']=='true'):false;
|
|
|
|
if($query[0]!='/'){
|
|
$query='/'.$query;
|
|
}
|
|
|
|
if(substr($query,-1,1)=='/'){
|
|
$base=$query;
|
|
}else{
|
|
$base=dirname($query);
|
|
}
|
|
|
|
$query=substr($query,strlen($base));
|
|
|
|
if($base!='/'){
|
|
$query=substr($query,1);
|
|
}
|
|
$queryLen=strlen($query);
|
|
$query=strtolower($query);
|
|
|
|
// echo "$base - $query";
|
|
|
|
$files=array();
|
|
|
|
if(OC_Filesystem::file_exists($base) and OC_Filesystem::is_dir($base)){
|
|
$dh = OC_Filesystem::opendir($base);
|
|
if($dh){
|
|
if(substr($base,-1,1)!='/'){
|
|
$base=$base.'/';
|
|
}
|
|
while (($file = readdir($dh)) !== false) {
|
|
if ($file != "." && $file != ".."){
|
|
if(substr(strtolower($file),0,$queryLen)==$query){
|
|
$item=$base.$file;
|
|
if((!$dirOnly or OC_Filesystem::is_dir($item))){
|
|
$files[]=(object)array('id'=>$item,'label'=>$item,'name'=>$item);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
OC_JSON::encodedPrint($files);
|
|
|
|
?>
|