2011-04-16 16:36:32 +04:00
|
|
|
|
<?php
|
|
|
|
|
/**
|
|
|
|
|
* ownCloud
|
|
|
|
|
*
|
|
|
|
|
* @author Frank Karlitschek
|
|
|
|
|
* @author Jakob Sack
|
2012-05-26 21:14:24 +04:00
|
|
|
|
* @copyright 2012 Frank Karlitschek frank@owncloud.org
|
2011-04-16 16:36:32 +04:00
|
|
|
|
*
|
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
|
*
|
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Affero General Public
|
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* This class provides an easy way for apps to store config values in the
|
|
|
|
|
* database.
|
|
|
|
|
*/
|
|
|
|
|
|
2011-07-29 23:36:03 +04:00
|
|
|
|
class OC_OCSClient{
|
2011-04-16 16:36:32 +04:00
|
|
|
|
|
2014-08-26 12:20:51 +04:00
|
|
|
|
/**
|
|
|
|
|
* Returns whether the AppStore is enabled (i.e. because the AppStore is disabled for EE)
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
protected static function isAppstoreEnabled() {
|
|
|
|
|
if(OC::$server->getConfig()->getSystemValue('appstoreenabled', true) === false OR OC_Util::getEditionString() !== '') {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2012-03-23 18:52:41 +04:00
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get the url of the OCS AppStore server.
|
2014-05-11 21:05:28 +04:00
|
|
|
|
* @return string of the AppStore server
|
2012-03-23 18:52:41 +04:00
|
|
|
|
*
|
2013-02-11 20:44:02 +04:00
|
|
|
|
* This function returns the url of the OCS AppStore server. It´s possible
|
|
|
|
|
* to set it in the config file or it will fallback to the default
|
2012-03-23 18:52:41 +04:00
|
|
|
|
*/
|
2012-09-07 17:22:01 +04:00
|
|
|
|
private static function getAppStoreURL() {
|
2014-08-26 12:20:51 +04:00
|
|
|
|
return OC::$server->getConfig()->getSystemValue('appstoreurl', 'https://api.owncloud.com/v1');
|
2012-03-23 18:52:41 +04:00
|
|
|
|
}
|
|
|
|
|
|
2012-10-08 17:58:50 +04:00
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get the content of an OCS url call.
|
2014-05-11 21:05:28 +04:00
|
|
|
|
* @return string of the response
|
2012-10-08 17:58:50 +04:00
|
|
|
|
* This function calls an OCS server and returns the response. It also sets a sane timeout
|
2014-02-06 19:30:58 +04:00
|
|
|
|
* @param string $url
|
2012-10-08 17:58:50 +04:00
|
|
|
|
*/
|
|
|
|
|
private static function getOCSresponse($url) {
|
2012-11-15 02:14:04 +04:00
|
|
|
|
$data = \OC_Util::getUrlContent($url);
|
2012-10-08 17:58:50 +04:00
|
|
|
|
return($data);
|
|
|
|
|
}
|
|
|
|
|
|
2013-01-14 23:30:28 +04:00
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get all the categories from the OCS server
|
2014-08-01 15:42:35 +04:00
|
|
|
|
* @return array|null an array of category ids or null
|
2012-09-18 19:51:55 +04:00
|
|
|
|
* @note returns NULL if config value appstoreenabled is set to false
|
2011-04-16 16:36:32 +04:00
|
|
|
|
* This function returns a list of all the application categories on the OCS server
|
|
|
|
|
*/
|
2012-09-07 17:22:01 +04:00
|
|
|
|
public static function getCategories() {
|
2014-08-26 12:20:51 +04:00
|
|
|
|
if(!self::isAppstoreEnabled()) {
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2012-06-22 18:06:46 +04:00
|
|
|
|
}
|
2012-03-23 18:52:41 +04:00
|
|
|
|
$url=OC_OCSClient::getAppStoreURL().'/content/categories';
|
2012-10-08 17:58:50 +04:00
|
|
|
|
$xml=OC_OCSClient::getOCSresponse($url);
|
2012-10-23 10:20:17 +04:00
|
|
|
|
if($xml==false) {
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
}
|
2014-03-10 20:49:47 +04:00
|
|
|
|
$loadEntities = libxml_disable_entity_loader(true);
|
|
|
|
|
$data = simplexml_load_string($xml);
|
|
|
|
|
libxml_disable_entity_loader($loadEntities);
|
2012-08-29 10:38:33 +04:00
|
|
|
|
|
2011-04-17 18:04:46 +04:00
|
|
|
|
$tmp=$data->data;
|
2011-04-17 01:07:18 +04:00
|
|
|
|
$cats=array();
|
2011-04-17 18:04:46 +04:00
|
|
|
|
|
2012-07-20 19:51:50 +04:00
|
|
|
|
foreach($tmp->category as $value) {
|
2011-04-17 18:04:46 +04:00
|
|
|
|
|
|
|
|
|
$id= (int) $value->id;
|
|
|
|
|
$name= (string) $value->name;
|
|
|
|
|
$cats[$id]=$name;
|
|
|
|
|
|
2011-04-16 21:42:58 +04:00
|
|
|
|
}
|
2011-04-17 18:04:46 +04:00
|
|
|
|
|
2011-04-16 21:42:58 +04:00
|
|
|
|
return $cats;
|
2011-04-16 16:36:32 +04:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get all the applications from the OCS server
|
2014-08-01 15:42:35 +04:00
|
|
|
|
* @return array|null an array of application data or null
|
2011-04-16 16:36:32 +04:00
|
|
|
|
*
|
|
|
|
|
* This function returns a list of all the applications on the OCS server
|
2014-05-12 00:51:30 +04:00
|
|
|
|
* @param array|string $categories
|
2014-04-21 17:44:54 +04:00
|
|
|
|
* @param int $page
|
2014-02-06 19:30:58 +04:00
|
|
|
|
* @param string $filter
|
2011-04-16 16:36:32 +04:00
|
|
|
|
*/
|
2012-11-02 22:53:02 +04:00
|
|
|
|
public static function getApplications($categories, $page, $filter) {
|
2014-08-26 12:20:51 +04:00
|
|
|
|
if(!self::isAppstoreEnabled()) {
|
2012-03-23 18:52:41 +04:00
|
|
|
|
return(array());
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-19 00:02:45 +04:00
|
|
|
|
if(is_array($categories)) {
|
2012-11-02 22:53:02 +04:00
|
|
|
|
$categoriesstring=implode('x', $categories);
|
2011-04-17 01:07:18 +04:00
|
|
|
|
}else{
|
|
|
|
|
$categoriesstring=$categories;
|
|
|
|
|
}
|
2012-08-31 22:22:03 +04:00
|
|
|
|
|
2012-11-02 22:53:02 +04:00
|
|
|
|
$version='&version='.implode('x', \OC_Util::getVersion());
|
2012-08-31 22:22:03 +04:00
|
|
|
|
$filterurl='&filter='.urlencode($filter);
|
2013-02-11 20:44:02 +04:00
|
|
|
|
$url=OC_OCSClient::getAppStoreURL().'/content/data?categories='.urlencode($categoriesstring)
|
|
|
|
|
.'&sortmode=new&page='.urlencode($page).'&pagesize=100'.$filterurl.$version;
|
2011-04-16 21:42:58 +04:00
|
|
|
|
$apps=array();
|
2012-10-08 17:58:50 +04:00
|
|
|
|
$xml=OC_OCSClient::getOCSresponse($url);
|
2012-10-08 14:00:29 +04:00
|
|
|
|
|
2012-10-23 10:20:17 +04:00
|
|
|
|
if($xml==false) {
|
|
|
|
|
return null;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
}
|
2014-03-10 20:49:47 +04:00
|
|
|
|
$loadEntities = libxml_disable_entity_loader(true);
|
|
|
|
|
$data = simplexml_load_string($xml);
|
|
|
|
|
libxml_disable_entity_loader($loadEntities);
|
2011-06-19 00:02:45 +04:00
|
|
|
|
|
2011-04-16 21:42:58 +04:00
|
|
|
|
$tmp=$data->data->content;
|
|
|
|
|
for($i = 0; $i < count($tmp); $i++) {
|
|
|
|
|
$app=array();
|
2011-08-11 17:11:06 +04:00
|
|
|
|
$app['id']=(string)$tmp[$i]->id;
|
|
|
|
|
$app['name']=(string)$tmp[$i]->name;
|
2013-01-30 16:39:53 +04:00
|
|
|
|
$app['label']=(string)$tmp[$i]->label;
|
2013-01-21 23:40:23 +04:00
|
|
|
|
$app['version']=(string)$tmp[$i]->version;
|
2011-08-11 17:11:06 +04:00
|
|
|
|
$app['type']=(string)$tmp[$i]->typeid;
|
|
|
|
|
$app['typename']=(string)$tmp[$i]->typename;
|
|
|
|
|
$app['personid']=(string)$tmp[$i]->personid;
|
2011-08-28 01:56:22 +04:00
|
|
|
|
$app['license']=(string)$tmp[$i]->license;
|
2011-08-11 17:11:06 +04:00
|
|
|
|
$app['detailpage']=(string)$tmp[$i]->detailpage;
|
|
|
|
|
$app['preview']=(string)$tmp[$i]->smallpreviewpic1;
|
2014-08-14 17:48:38 +04:00
|
|
|
|
$app['preview-full']=(string)$tmp[$i]->previewpic1;
|
2011-04-16 22:34:18 +04:00
|
|
|
|
$app['changed']=strtotime($tmp[$i]->changed);
|
2011-08-11 17:11:06 +04:00
|
|
|
|
$app['description']=(string)$tmp[$i]->description;
|
2012-10-08 17:49:48 +04:00
|
|
|
|
$app['score']=(string)$tmp[$i]->score;
|
2014-08-14 17:48:38 +04:00
|
|
|
|
$app['downloads'] = $tmp[$i]->downloads;
|
2012-08-29 10:38:33 +04:00
|
|
|
|
|
2011-04-16 21:42:58 +04:00
|
|
|
|
$apps[]=$app;
|
2012-08-29 10:38:33 +04:00
|
|
|
|
}
|
2011-04-16 21:42:58 +04:00
|
|
|
|
return $apps;
|
2011-04-16 16:36:32 +04:00
|
|
|
|
}
|
|
|
|
|
|
2011-04-17 01:07:18 +04:00
|
|
|
|
|
2011-06-19 00:02:45 +04:00
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get an the applications from the OCS server
|
2014-04-21 17:44:54 +04:00
|
|
|
|
* @param string $id
|
2014-08-01 15:42:35 +04:00
|
|
|
|
* @return array|null an array of application data or null
|
2011-06-19 00:02:45 +04:00
|
|
|
|
*
|
2014-08-01 15:42:35 +04:00
|
|
|
|
* This function returns an applications from the OCS server
|
2011-06-19 00:02:45 +04:00
|
|
|
|
*/
|
2012-09-07 17:22:01 +04:00
|
|
|
|
public static function getApplication($id) {
|
2014-08-26 12:20:51 +04:00
|
|
|
|
if(!self::isAppstoreEnabled()) {
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2012-06-22 18:06:46 +04:00
|
|
|
|
}
|
2012-03-23 18:52:41 +04:00
|
|
|
|
$url=OC_OCSClient::getAppStoreURL().'/content/data/'.urlencode($id);
|
2012-10-08 17:58:50 +04:00
|
|
|
|
$xml=OC_OCSClient::getOCSresponse($url);
|
2011-06-19 00:02:45 +04:00
|
|
|
|
|
2012-10-23 10:01:09 +04:00
|
|
|
|
if($xml==false) {
|
2014-08-01 11:54:32 +04:00
|
|
|
|
OC_Log::write('core', 'Unable to parse OCS content for app ' . $id, OC_Log::FATAL);
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
}
|
2014-03-10 20:49:47 +04:00
|
|
|
|
$loadEntities = libxml_disable_entity_loader(true);
|
|
|
|
|
$data = simplexml_load_string($xml);
|
|
|
|
|
libxml_disable_entity_loader($loadEntities);
|
2011-06-19 00:02:45 +04:00
|
|
|
|
|
|
|
|
|
$tmp=$data->data->content;
|
2014-08-01 11:54:32 +04:00
|
|
|
|
if (is_null($tmp)) {
|
|
|
|
|
OC_Log::write('core', 'Invalid OCS content returned for app ' . $id, OC_Log::FATAL);
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2011-06-19 00:02:45 +04:00
|
|
|
|
$app=array();
|
|
|
|
|
$app['id']=$tmp->id;
|
|
|
|
|
$app['name']=$tmp->name;
|
2013-01-21 23:40:23 +04:00
|
|
|
|
$app['version']=$tmp->version;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
$app['type']=$tmp->typeid;
|
2013-01-30 16:39:53 +04:00
|
|
|
|
$app['label']=$tmp->label;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
$app['typename']=$tmp->typename;
|
|
|
|
|
$app['personid']=$tmp->personid;
|
|
|
|
|
$app['detailpage']=$tmp->detailpage;
|
|
|
|
|
$app['preview1']=$tmp->smallpreviewpic1;
|
|
|
|
|
$app['preview2']=$tmp->smallpreviewpic2;
|
|
|
|
|
$app['preview3']=$tmp->smallpreviewpic3;
|
|
|
|
|
$app['changed']=strtotime($tmp->changed);
|
|
|
|
|
$app['description']=$tmp->description;
|
2012-04-21 17:30:58 +04:00
|
|
|
|
$app['detailpage']=$tmp->detailpage;
|
2012-10-08 17:49:48 +04:00
|
|
|
|
$app['score']=$tmp->score;
|
2011-06-19 00:02:45 +04:00
|
|
|
|
|
|
|
|
|
return $app;
|
|
|
|
|
}
|
|
|
|
|
|
2012-06-22 18:06:46 +04:00
|
|
|
|
/**
|
2014-05-19 19:50:53 +04:00
|
|
|
|
* Get the download url for an application from the OCS server
|
2014-08-01 15:42:35 +04:00
|
|
|
|
* @return array|null an array of application data or null
|
2014-04-21 17:44:54 +04:00
|
|
|
|
*
|
|
|
|
|
* This function returns an download url for an applications from the OCS server
|
|
|
|
|
* @param string $id
|
|
|
|
|
* @param integer $item
|
|
|
|
|
*/
|
2012-11-02 22:53:02 +04:00
|
|
|
|
public static function getApplicationDownload($id, $item) {
|
2014-08-26 12:20:51 +04:00
|
|
|
|
if(!self::isAppstoreEnabled()) {
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2012-06-22 18:06:46 +04:00
|
|
|
|
}
|
|
|
|
|
$url=OC_OCSClient::getAppStoreURL().'/content/download/'.urlencode($id).'/'.urlencode($item);
|
2012-10-08 17:58:50 +04:00
|
|
|
|
$xml=OC_OCSClient::getOCSresponse($url);
|
2012-10-08 14:00:29 +04:00
|
|
|
|
|
2012-10-23 10:01:09 +04:00
|
|
|
|
if($xml==false) {
|
2012-11-04 21:28:29 +04:00
|
|
|
|
OC_Log::write('core', 'Unable to parse OCS content', OC_Log::FATAL);
|
2012-10-23 10:01:09 +04:00
|
|
|
|
return null;
|
2012-06-22 18:06:46 +04:00
|
|
|
|
}
|
2014-03-10 20:49:47 +04:00
|
|
|
|
$loadEntities = libxml_disable_entity_loader(true);
|
|
|
|
|
$data = simplexml_load_string($xml);
|
|
|
|
|
libxml_disable_entity_loader($loadEntities);
|
2012-06-22 18:06:46 +04:00
|
|
|
|
|
|
|
|
|
$tmp=$data->data->content;
|
|
|
|
|
$app=array();
|
2012-08-29 10:38:33 +04:00
|
|
|
|
if(isset($tmp->downloadlink)) {
|
2012-06-22 18:06:46 +04:00
|
|
|
|
$app['downloadlink']=$tmp->downloadlink;
|
2012-01-06 22:08:35 +04:00
|
|
|
|
}else{
|
2012-08-29 22:34:44 +04:00
|
|
|
|
$app['downloadlink']='';
|
2012-01-06 22:08:35 +04:00
|
|
|
|
}
|
2012-06-22 18:06:46 +04:00
|
|
|
|
return $app;
|
|
|
|
|
}
|
2012-01-06 22:08:35 +04:00
|
|
|
|
|
2011-04-16 16:36:32 +04:00
|
|
|
|
}
|