aboutsummaryrefslogtreecommitdiffstats
path: root/Zotlabs
diff options
context:
space:
mode:
Diffstat (limited to 'Zotlabs')
-rw-r--r--Zotlabs/Module/Admin.php84
-rw-r--r--Zotlabs/Storage/Git.php19
2 files changed, 103 insertions, 0 deletions
diff --git a/Zotlabs/Module/Admin.php b/Zotlabs/Module/Admin.php
index e1eaa6e0e..ddec02916 100644
--- a/Zotlabs/Module/Admin.php
+++ b/Zotlabs/Module/Admin.php
@@ -1,5 +1,8 @@
<?php
namespace Zotlabs\Module;
+
+use PHPGit\Git as Git;
+
/**
* @file mod/admin.php
* @brief Hubzilla's admin controller.
@@ -36,6 +39,10 @@ class Admin extends \Zotlabs\Web\Controller {
$this->admin_page_channels_post($a);
break;
case 'plugins':
+ if (argc() > 2 && argv(2) === 'addrepo') {
+ $this->admin_page_plugins_post('addrepo');
+ break;
+ }
if (argc() > 2 &&
is_file("addon/" . argv(2) . "/" . argv(2) . ".php")){
@include_once("addon/" . argv(2) . "/" . argv(2) . ".php");
@@ -1343,6 +1350,16 @@ class Admin extends \Zotlabs\Web\Controller {
usort($plugins,'self::plugin_sort');
+
+ $admin_plugins_add_repo_form= replace_macros(
+ get_markup_template('admin_plugins_addrepo.tpl'), array(
+ '$post' => 'admin/plugins/addrepo',
+ '$desc' => t('Enter the public git repository URL of the plugin repo.'),
+ '$repoURL' => array('repoURL', t('Plugin repo git URL'), '', ''),
+ '$submit' => t('Download Plugin Repo')
+ )
+ );
+
$t = get_markup_template('admin_plugins.tpl');
return replace_macros($t, array(
'$title' => t('Administration'),
@@ -1353,6 +1370,9 @@ class Admin extends \Zotlabs\Web\Controller {
'$plugins' => $plugins,
'$disabled' => t('Disabled - version incompatibility'),
'$form_security_token' => get_form_security_token('admin_plugins'),
+ '$addrepo' => t('Add Plugin Repo'),
+ '$expandform' => false,
+ '$form' => $admin_plugins_add_repo_form
));
}
@@ -1647,6 +1667,70 @@ class Admin extends \Zotlabs\Web\Controller {
));
}
+ function admin_page_plugins_post($action) {
+ switch($action) {
+ case 'addrepo':
+
+ require_once('library/markdown.php');
+ if(array_key_exists('repoURL',$_REQUEST)) {
+ require __DIR__ . '/../../library/PHPGit.autoload.php'; // Load PHPGit dependencies
+ logger('Repo URL submitted: ' . $_REQUEST['repoURL']);
+ $repoURL = $_REQUEST['repoURL'];
+ $urlpath = parse_url($repoURL, PHP_URL_PATH);
+ $lastslash = strrpos($urlpath, '/') + 1;
+ $gitext = strrpos($urlpath, '.');
+ if ($gitext) {
+ $reponame = substr($urlpath, $lastslash, $gitext - $lastslash);
+ } else {
+ logger('invalid git repo URL');
+ notice('Invalid git repo URL');
+ break;
+ }
+ $storepath = realpath(__DIR__ . '/../../store/');
+ //logger('storepath: ' . $storepath);
+ $repopath = $storepath . '/pluginrepos/' . $reponame;
+ $git = new Git();
+ if (!file_exists($repopath)) {
+ //logger('repopath does not exist');
+ if (mkdir($repopath, 0770, true)) {
+ $cloned = $git->clone($repoURL, $repopath);
+ if (!$cloned) {
+ logger('git clone failed');
+ notice('Repo coule not be cloned. Filesystem path error.');
+ json_return_and_die(array('message' => 'Repo could not be cloned. Filesystem path error.', 'success' => false));
+ }
+ //json_return_and_die(array('repo'=> $repo, 'message' => 'Successfully cloned to: ' . $repopath , 'success' => true));
+ } else {
+ logger('repopath could not be created');
+ notice('Repo coule not be cloned. Filesystem path error.');
+ json_return_and_die(array('message' => 'Repo could not be cloned. Filesystem path error', 'success' => false));
+ }
+ }
+ $git->setRepository($repopath);
+ $repo = array();
+ $repo['url'] = $repoURL;
+ $repo['branches'] = $git->branch(['all' => true]);
+ $repo['objects'] = array();
+ $repo['readme'] = $repo['manifest'] = null;
+ foreach ($git->tree('master') as $object) {
+ if ($object['type'] == 'blob' && (strtolower($object['file']) === 'readme.md' || strtolower($object['file']) === 'readme')) {
+ $repo['readme'] = Markdown($git->cat->blob($object['hash']));
+ } else if ($object['type'] == 'blob' && strtolower($object['file']) === 'manifest.json') {
+ $repo['manifest'] = $git->cat->blob($object['hash']);
+ }
+ }
+ //logger('repo: ' . json_encode($repo));
+ json_return_and_die(array('repo'=> $repo, 'message' => '', 'success' => true));
+
+ } else {
+ json_return_and_die(array('message' => 'No repo URL provided', 'success' => false));
+ }
+ break;
+ default:
+ break;
+ }
+ }
+
function admin_page_profs_post(&$a) {
if(array_key_exists('basic',$_REQUEST)) {
diff --git a/Zotlabs/Storage/Git.php b/Zotlabs/Storage/Git.php
new file mode 100644
index 000000000..f9b5a6c79
--- /dev/null
+++ b/Zotlabs/Storage/Git.php
@@ -0,0 +1,19 @@
+<?php
+
+/*
+ * To change this license header, choose License Headers in Project Properties.
+ * To change this template file, choose Tools | Templates
+ * and open the template in the editor.
+ */
+
+namespace Zotlabs\Storage;
+
+
+require __DIR__ . '/../../library/PHPGit.autoload.php'; // Load PHPGit dependencies
+
+/**
+ * Description of Git
+ *
+ * @author andrew
+ */
+class Git {}