From 6ef16de4006b70159920d570c02cde275121b4ab Mon Sep 17 00:00:00 2001 From: rabuzarus <> Date: Thu, 5 May 2016 20:59:29 +0200 Subject: [PATCH] hovercard for the frio theme (initial commit) --- frio_hovercard.php | 140 ++++++++++++++++++++++++++++++++++++++++ templates/hovercard.tpl | 39 +++++++++++ 2 files changed, 179 insertions(+) create mode 100644 frio_hovercard.php create mode 100644 templates/hovercard.tpl diff --git a/frio_hovercard.php b/frio_hovercard.php new file mode 100644 index 000000000..9ddb4ce33 --- /dev/null +++ b/frio_hovercard.php @@ -0,0 +1,140 @@ + + * License: GNU AFFERO GENERAL PUBLIC LICENSE (Version 3) + */ + +require_once("include/socgraph.php"); +require_once("include/Contact.php"); + +function frio_hovercard_install() { + logger("installed frio-hovercard"); +} + +function frio_hovercard_uninstall() { + logger("uninstalled frio-hovercard"); +} +function frio_hovercard_module() { + return; +} +function frio_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", "addon/frio_hovercard/"); + return $templatecontent; + } + + // 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 + $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"])), +// 'alias' => $contact["alias"], + 'location' => $contact["location"], + 'gender' => $contact["gender"], + 'about' => $contact["about"], + 'network' => format_network_name($contact["network"]), + '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", "addon/frio_hovercard/"); + + $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; +} + + +function save_this_query() { + $contacts = q("SELECT * FROM `gcontact` + WHERE ((NOT `gcontact`.`hide` AND `gcontact`.`network` IN ('%s', '%s', '%s') AND + ((`gcontact`.`last_contact` >= `gcontact`.`last_failure`) OR (`gcontact`.`updated` >= `gcontact`.`last_failure`)))) AND + (`gcontact`.`addr` = '%s' OR `gcontact`.`nurl` = '%s') + LIMIT 1", + dbesc(NETWORK_DFRN), dbesc($ostatus), dbesc($diaspora), + dbesc(escape_tags($url)) + ); +} diff --git a/templates/hovercard.tpl b/templates/hovercard.tpl new file mode 100644 index 000000000..d206ae62f --- /dev/null +++ b/templates/hovercard.tpl @@ -0,0 +1,39 @@ +