]> git.mxchange.org Git - friendica.git/blobdiff - mod/nodeinfo.php
photos-albms widget: add some classes
[friendica.git] / mod / nodeinfo.php
index b4f0428f9bc42120d7ae1c933c97f9bcce0be476..ba310a10514151c6cac11a507709164a6b4046c6 100644 (file)
@@ -1,15 +1,19 @@
 <?php
-/*
-Documentation: http://nodeinfo.diaspora.software/schema.html
+/**
+ * @file mod/nodeinfo.php
+ * 
+ * Documentation: http://nodeinfo.diaspora.software/schema.html
 */
 
+require_once("include/plugin.php");
+
 function nodeinfo_wellknown(&$a) {
        if (!get_config("system", "nodeinfo")) {
                http_status_exit(404);
                killme();
        }
-       $nodeinfo = array("links" => array("rel" => "http://nodeinfo.diaspora.software/ns/schema/1.0",
-                                       "href" => $a->get_baseurl()."/nodeinfo/1.0"));
+       $nodeinfo = array("links" => array(array("rel" => "http://nodeinfo.diaspora.software/ns/schema/1.0",
+                                       "href" => $a->get_baseurl()."/nodeinfo/1.0")));
 
        header('Content-type: application/json; charset=utf-8');
        echo json_encode($nodeinfo, JSON_PRETTY_PRINT|JSON_UNESCAPED_SLASHES);
@@ -50,96 +54,122 @@ function nodeinfo_init(&$a){
                $nodeinfo["protocols"]["outbound"][] = "gnusocial";
        }
 
-       //if ($smtp) {
-       //      $nodeinfo["protocols"]["inbound"][] = "smtp";
-       //      $nodeinfo["protocols"]["outbound"][] = "smtp";
-       //}
+       $nodeinfo["services"] = array();
+       $nodeinfo["services"]["inbound"] = array();
+       $nodeinfo["services"]["outbound"] = array();
 
+       $nodeinfo["openRegistrations"] = ($a->config['register_policy'] != 0);
 
-       $nodeinfo["services"] = array();
+       $nodeinfo["usage"] = array();
+       $nodeinfo["usage"]["users"] = array("total" => (int)get_config("nodeinfo","total_users"),
+                               "activeHalfyear" => (int)get_config("nodeinfo","active_users_halfyear"),
+                               "activeMonth" => (int)get_config("nodeinfo","active_users_monthly"));
+       $nodeinfo["usage"]["localPosts"] = (int)get_config("nodeinfo","local_posts");
+       $nodeinfo["usage"]["localComments"] = (int)get_config("nodeinfo","local_comments");
 
-       if (nodeinfo_plugin_enabled("appnet") OR nodeinfo_plugin_enabled("buffer"))
-               $nodeinfo["services"][] = "appnet";
+       $nodeinfo["metadata"] = array("nodeName" => $a->config["sitename"]);
 
-       if (nodeinfo_plugin_enabled("blogger"))
-               $nodeinfo["services"][] = "blogger";
+       if (plugin_enabled("appnet"))
+               $nodeinfo["services"]["inbound"][] = "appnet";
 
-       //if (get_config("system","diaspora_enabled"))
-       //      $nodeinfo["services"][] = "diaspora";
+       if (plugin_enabled("appnet") OR plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "appnet";
 
-       if (nodeinfo_plugin_enabled("dwpost"))
-               $nodeinfo["services"][] = "dreamwidth";
+       if (plugin_enabled("blogger"))
+               $nodeinfo["services"]["outbound"][] = "blogger";
 
-       if (nodeinfo_plugin_enabled("fbpost") OR nodeinfo_plugin_enabled("buffer"))
-               $nodeinfo["services"][] = "facebook";
+       if (plugin_enabled("dwpost"))
+               $nodeinfo["services"]["outbound"][] = "dreamwidth";
 
-       //$nodeinfo["services"][] = "friendica";
+       if (plugin_enabled("fbpost") OR plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "facebook";
 
-       //if (nodeinfo_plugin_enabled("statusnet") OR !get_config("system","ostatus_disabled"))
-       if (nodeinfo_plugin_enabled("statusnet"))
-               $nodeinfo["services"][] = "gnusocial";
+       if (plugin_enabled("statusnet")) {
+               $nodeinfo["services"]["inbound"][] = "gnusocial";
+               $nodeinfo["services"]["outbound"][] = "gnusocial";
+       }
 
-       if (nodeinfo_plugin_enabled("gpluspost") OR nodeinfo_plugin_enabled("buffer"))
-               $nodeinfo["services"][] = "google";
+       if (plugin_enabled("gpluspost") OR plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "google";
 
-       if (nodeinfo_plugin_enabled("ijpost"))
-               $nodeinfo["services"][] = "insanejournal";
+       if (plugin_enabled("ijpost"))
+               $nodeinfo["services"]["outbound"][] = "insanejournal";
 
-       if (nodeinfo_plugin_enabled("libertree"))
-               $nodeinfo["services"][] = "libertree";
+       if (plugin_enabled("libertree"))
+               $nodeinfo["services"]["outbound"][] = "libertree";
 
-       if (nodeinfo_plugin_enabled("buffer"))
-               $nodeinfo["services"][] = "linkedin";
+       if (plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "linkedin";
 
-       if (nodeinfo_plugin_enabled("ljpost"))
-               $nodeinfo["services"][] = "livejournal";
+       if (plugin_enabled("ljpost"))
+               $nodeinfo["services"]["outbound"][] = "livejournal";
 
-       if (nodeinfo_plugin_enabled("buffer"))
-               $nodeinfo["services"][] = "pinterest";
+       if (plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "pinterest";
 
-       if (nodeinfo_plugin_enabled("posterous"))
-               $nodeinfo["services"][] = "posterous";
+       if (plugin_enabled("posterous"))
+               $nodeinfo["services"]["outbound"][] = "posterous";
 
-       if (nodeinfo_plugin_enabled("pumpio"))
-               $nodeinfo["services"][] = "pumpio";
+       if (plugin_enabled("pumpio")) {
+               $nodeinfo["services"]["inbound"][] = "pumpio";
+               $nodeinfo["services"]["outbound"][] = "pumpio";
+       }
 
        // redmatrix
 
        if ($smtp)
-               $nodeinfo["services"][] = "smtp";
+               $nodeinfo["services"]["outbound"][] = "smtp";
 
-       if (nodeinfo_plugin_enabled("tumblr"))
-               $nodeinfo["services"][] = "tumblr";
+       if (plugin_enabled("tumblr"))
+               $nodeinfo["services"]["outbound"][] = "tumblr";
 
-       if (nodeinfo_plugin_enabled("twitter"))
-               $nodeinfo["services"][] = "twitter";
+       if (plugin_enabled("twitter") OR plugin_enabled("buffer"))
+               $nodeinfo["services"]["outbound"][] = "twitter";
 
-       if (nodeinfo_plugin_enabled("wppost"))
-               $nodeinfo["services"][] = "wordpress";
+       if (plugin_enabled("wppost"))
+               $nodeinfo["services"]["outbound"][] = "wordpress";
 
-       $nodeinfo["openRegistrations"] = ($a->config['register_policy'] != 0);
+       $nodeinfo["metadata"]["protocols"] = $nodeinfo["protocols"];
+       $nodeinfo["metadata"]["protocols"]["outbound"][] = "atom1.0";
+       $nodeinfo["metadata"]["protocols"]["inbound"][] = "atom1.0";
+       $nodeinfo["metadata"]["protocols"]["inbound"][] = "rss2.0";
 
-       $nodeinfo["usage"] = array();
-       $nodeinfo["usage"]["users"] = array("total" => (int)get_config("nodeinfo","total_users"),
-                               "activeHalfyear" => (int)get_config("nodeinfo","active_users_halfyear"),
-                               "activeMonth" => (int)get_config("nodeinfo","active_users_monthly"));
-       $nodeinfo["usage"]["localPosts"] = (int)get_config("nodeinfo","local_posts");
-       $nodeinfo["usage"]["localComments"] = (int)get_config("nodeinfo","local_comments");
+       $nodeinfo["metadata"]["services"] = $nodeinfo["services"];
 
-       //$nodeinfo["metadata"] = new stdClass();
-       $nodeinfo["metadata"] = array("nodeName" => $a->config["sitename"]);
+       if (plugin_enabled("twitter"))
+               $nodeinfo["metadata"]["services"]["inbound"][] = "twitter";
 
        header('Content-type: application/json; charset=utf-8');
        echo json_encode($nodeinfo, JSON_PRETTY_PRINT|JSON_UNESCAPED_SLASHES);
        exit;
 }
 
-function nodeinfo_plugin_enabled($plugin) {
-       $r = q("SELECT * FROM `addon` WHERE `installed` = 1 AND `name` = '%s'", $plugin);
-       return((bool)(count($r) > 0));
-}
+
 
 function nodeinfo_cron() {
+
+       $a = get_app();
+
+       // If the plugin "statistics_json" is enabled then disable it and actrivate nodeinfo.
+       if (plugin_enabled("statistics_json")) {
+               set_config("system", "nodeinfo", true);
+
+               $plugin = "statistics_json";
+               $plugins = get_config("system","addon");
+               $plugins_arr = array();
+
+               if($plugins) {
+                       $plugins_arr = explode(",",str_replace(" ", "",$plugins));
+
+                       $idx = array_search($plugin, $plugins_arr);
+                       if ($idx !== false){
+                               unset($plugins_arr[$idx]);
+                               uninstall_plugin($plugin);
+                               set_config("system","addon", implode(", ",$plugins_arr));
+                       }
+               }
+       }
+
        if (!get_config("system", "nodeinfo"))
                return;