|
|
@ -0,0 +1,126 @@ |
|
|
|
<?php |
|
|
|
|
|
|
|
/** |
|
|
|
* Name: Frio Hovercard |
|
|
|
* Description: Hovercard addon for the frio theme |
|
|
|
* Version: 0.1 |
|
|
|
* Author: Rabuzarus <https://github.com/rabuzarus> |
|
|
|
* License: GNU AFFERO GENERAL PUBLIC LICENSE (Version 3) |
|
|
|
*/ |
|
|
|
|
|
|
|
require_once("include/socgraph.php"); |
|
|
|
require_once("include/Contact.php"); |
|
|
|
|
|
|
|
function hovercard_init(&$a) { |
|
|
|
// Just for testing purposes
|
|
|
|
$_GET["mode"] = "minimal"; |
|
|
|
} |
|
|
|
function hovercard_content() { |
|
|
|
$profileurl = (x($_REQUEST,'profileurl') ? $_REQUEST['profileurl'] : ""); |
|
|
|
$datatype = (x($_REQUEST,'datatype') ?$_REQUEST['datatype'] : "json"); |
|
|
|
|
|
|
|
// Get out if the system doesn't have public access allowed
|
|
|
|
if(intval(get_config('system','block_public'))) |
|
|
|
http_status_exit(401); |
|
|
|
|
|
|
|
// Return the raw content of the template. We use this to make templates usable for js functions.
|
|
|
|
// Look at hovercard.js (function getHoverCardTemplate()).
|
|
|
|
// This part should be moved in it's own module. Maybe we could make more templates accessabel.
|
|
|
|
// (We need to discuss possible security lacks before doing this)
|
|
|
|
if ($datatype == "tpl") { |
|
|
|
$templatecontent = get_template_content("hovercard.tpl"); |
|
|
|
echo $templatecontent; |
|
|
|
killme(); |
|
|
|
} |
|
|
|
|
|
|
|
// If a contact is connected the url is internally changed to "redir/CID". We need the pure url to search for
|
|
|
|
// the contact. So we strip out the contact id from the internal url and look in the contact table for
|
|
|
|
// the real url (nurl)
|
|
|
|
if(local_user() && strpos($profileurl, "redir/") === 0) { |
|
|
|
$cid = intval(substr($profileurl, 6)); |
|
|
|
$r = q("SELECT `nurl`, `self` FROM `contact` WHERE `id` = '%d' LIMIT 1", intval($cid)); |
|
|
|
$profileurl = ($r[0]["nurl"] ? $r[0]["nurl"] : ""); |
|
|
|
$self = ($r[0]["self"] ? $r[0]["self"] : ""); |
|
|
|
} |
|
|
|
|
|
|
|
// if it's the url containing https it should be converted to http
|
|
|
|
$nurl = normalise_link(clean_contact_url($profileurl)); |
|
|
|
if($nurl) { |
|
|
|
// Search for contact data
|
|
|
|
$contact = get_contact_details_by_url($nurl); |
|
|
|
|
|
|
|
// Get_contact_details_by_url() doesn't provide the nurl but we
|
|
|
|
// need it for the photo_menu, so we copy it to the contact array
|
|
|
|
if (!isset($contact["nurl"])) |
|
|
|
$contact["nurl"] = $nurl; |
|
|
|
} |
|
|
|
|
|
|
|
if(!is_array($contact)) |
|
|
|
return; |
|
|
|
|
|
|
|
// Get the photo_menu - the menu if possible contact actions
|
|
|
|
if(local_user()) |
|
|
|
$actions = contact_photo_menu($contact); |
|
|
|
|
|
|
|
|
|
|
|
// Move the contact data to the profile array so we can deliver it to
|
|
|
|
//
|
|
|
|
$profile = array( |
|
|
|
'name' => $contact["name"], |
|
|
|
'nick' => $contact["nick"], |
|
|
|
'addr' => (($contact["addr"] != "") ? $contact["addr"] : $contact["url"]), |
|
|
|
'thumb' => proxy_url($contact["photo"], false, PROXY_SIZE_THUMB), |
|
|
|
'url' => ($cid ? ("redir/".$cid) : zrl($contact["url"])), |
|
|
|
'nurl' => $contact["nurl"], // We additionally store the nurl as identifier
|
|
|
|
// 'alias' => $contact["alias"],
|
|
|
|
'location' => $contact["location"], |
|
|
|
'gender' => $contact["gender"], |
|
|
|
'about' => $contact["about"], |
|
|
|
'network' => format_network_name($contact["network"], $contact["url"]), |
|
|
|
'tags' => intval($contact["keywords"]), |
|
|
|
// 'nsfw' => intval($contact["nsfw"]),
|
|
|
|
// 'server_url' => $contact["server_url"],
|
|
|
|
'bd' => (($contact["birthday"] == "0000-00-00") ? "" : $contact["birthday"]), |
|
|
|
// 'generation' => $contact["generation"],
|
|
|
|
'account_type' => ($contact['community'] ? t("Forum") : ""), |
|
|
|
'actions' => $actions, |
|
|
|
); |
|
|
|
|
|
|
|
if($datatype == "html") { |
|
|
|
$t = get_markup_template("hovercard.tpl"); |
|
|
|
|
|
|
|
$o = replace_macros($t, array( |
|
|
|
'$profile' => $profile, |
|
|
|
)); |
|
|
|
|
|
|
|
return $o; |
|
|
|
|
|
|
|
} else { |
|
|
|
json_return_and_die($profile); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* @brief Get the raw content of a template file |
|
|
|
* |
|
|
|
* @param string $template The name of the template |
|
|
|
* @param string $root Directory of the template |
|
|
|
* |
|
|
|
* @return string|bool Output the raw content if existent, otherwise false |
|
|
|
*/ |
|
|
|
function get_template_content($template, $root = "") { |
|
|
|
|
|
|
|
// We load the whole template system to get the filename.
|
|
|
|
// Maybe we can do it a little bit smarter if I get time.
|
|
|
|
$t = get_markup_template($template, $root); |
|
|
|
$filename = $t->filename; |
|
|
|
|
|
|
|
// Get the content of the template file
|
|
|
|
if(file_exists($filename)) { |
|
|
|
$content = file_get_contents($filename); |
|
|
|
|
|
|
|
return $content; |
|
|
|
} |
|
|
|
|
|
|
|
return false; |
|
|
|
} |