X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fnodeinfo.php;h=ba310a10514151c6cac11a507709164a6b4046c6;hb=2d63f9deb646d30c60927026b83e08d0f47c381a;hp=bf1d4ef3ef20d1e9709897a2fad51ee36c82ec3e;hpb=820ded2c2d3cbbb170f990a2f0c162decb0029d7;p=friendica.git diff --git a/mod/nodeinfo.php b/mod/nodeinfo.php index bf1d4ef3ef..ba310a1051 100644 --- a/mod/nodeinfo.php +++ b/mod/nodeinfo.php @@ -1,18 +1,22 @@ 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, true); + echo json_encode($nodeinfo, JSON_PRETTY_PRINT|JSON_UNESCAPED_SLASHES); exit; } @@ -50,80 +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["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("dreamwidth")) - $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")) - $nodeinfo["services"][] = "gnusocial"; + if (plugin_enabled("statusnet")) { + $nodeinfo["services"]["inbound"][] = "gnusocial"; + $nodeinfo["services"]["outbound"][] = "gnusocial"; + } + + if (plugin_enabled("gpluspost") OR plugin_enabled("buffer")) + $nodeinfo["services"]["outbound"][] = "google"; - if (nodeinfo_plugin_enabled("fpluspost") OR nodeinfo_plugin_enabled("buffer")) - $nodeinfo["services"][] = "google"; + 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("pumpio")) - $nodeinfo["services"][] = "pumpio"; + if (plugin_enabled("buffer")) + $nodeinfo["services"]["outbound"][] = "pinterest"; + + if (plugin_enabled("posterous")) + $nodeinfo["services"]["outbound"][] = "posterous"; + + 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("wordpress")) - $nodeinfo["services"][] = "wppost"; + 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" => get_config("nodeinfo","total_users"), - "activeHalfyear" => get_config("nodeinfo","active_users_halfyear"), - "activeMonth" => get_config("nodeinfo","active_users_monthly")); - $nodeinfo["usage"]["localPosts"] = get_config("nodeinfo","local_posts"); - $nodeinfo["usage"]["localComments"] = get_config("nodeinfo","local_comments"); + $nodeinfo["metadata"]["services"] = $nodeinfo["services"]; + + if (plugin_enabled("twitter")) + $nodeinfo["metadata"]["services"]["inbound"][] = "twitter"; header('Content-type: application/json; charset=utf-8'); - echo json_encode($nodeinfo, true); + 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; @@ -206,10 +252,10 @@ function nodeinfo_cron() { set_config('nodeinfo','local_comments', $local_comments); // Now trying to register - //$url = "http://the-federation.info/register/".$a->get_hostname(); - //logger('nodeinfo_cron: registering url: '.$url, LOGGER_DEBUG); - //$ret = fetch_url($url); - //logger('nodeinfo_cron: registering answer: '.$ret, LOGGER_DEBUG); + $url = "http://the-federation.info/register/".$a->get_hostname(); + logger('registering url: '.$url, LOGGER_DEBUG); + $ret = fetch_url($url); + logger('registering answer: '.$ret, LOGGER_DEBUG); logger("cron_end"); set_config('nodeinfo','last_calucation', time());