* Rewrite to Proxy class: - introduced new Friendica\Network\Proxy class for in exchange of proxy_*() functions - moved also all PROXY_* constants there as Proxy::* - removed now no longer needed mod/proxy.php loading as composer's auto-load will do this for us - renamed those proxy_*() functions to better names: + proxy_init() -> Proxy::init() (public) + proxy_url() -> Proxy::proxifyUrl() (public) + proxy_parse_html() -> Proxy::proxifyHtml() (public) + proxy_is_local_image() -> Proxy::isLocalImage() (private) + proxy_parse_query() -> Proxy::parseQuery() (private) + proxy_img_cb() -> Proxy::replaceUrl() (private) * Ops, need to set $a here ... * CR request: - moved Proxy class to Friendica\Module - extended BaseModule * Ops, no need for own instance of $a when self::getApp() is around. * Proxy-rewrite: - proxy_url() and proxy_parse_html() are both non-module functions (now methods) - so they must be splitted into a seperate class - also the SIZE_* and DEFAULT_TIME constants are both not relevant to module * No instances from utility classes * Fixed error: - proxify*() is now located in `Friendica\Util\ProxyUtils` * Moved back to original place, ops? How did they move here? Well, it was not intended by me. * Removed duplicate (left-over from split) constants and static array. Thank to MrPetovan finding it. * Renamed ProxyUtils -> Proxy and aliased it back to ProxyUtils.
		
			
				
	
	
		
			147 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			147 lines
		
	
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?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)
 | |
|  */
 | |
| 
 | |
| use Friendica\App;
 | |
| use Friendica\Core\Config;
 | |
| use Friendica\Core\System;
 | |
| use Friendica\Database\DBA;
 | |
| use Friendica\Model\Contact;
 | |
| use Friendica\Model\GContact;
 | |
| use Friendica\Util\Proxy as ProxyUtils;
 | |
| 
 | |
| function hovercard_init(App $a)
 | |
| {
 | |
| 	// Just for testing purposes
 | |
| 	$_GET['mode'] = 'minimal';
 | |
| }
 | |
| 
 | |
| function hovercard_content()
 | |
| {
 | |
| 	$profileurl = defaults($_REQUEST, 'profileurl', '');
 | |
| 	$datatype   = defaults($_REQUEST, 'datatype'  , 'json');
 | |
| 
 | |
| 	// Get out if the system doesn't have public access allowed
 | |
| 	if (intval(Config::get('system', 'block_public'))) {
 | |
| 		System::httpExit(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 its own module. Maybe we could make more templates accessible.
 | |
| 	// (We need to discuss possible security leaks 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)
 | |
| 	$cid = 0;
 | |
| 	if (strpos($profileurl, 'redir/') === 0) {
 | |
| 		$cid = intval(substr($profileurl, 6));
 | |
| 		$remote_contact = DBA::selectFirst('contact', ['nurl'], ['id' => $cid]);
 | |
| 		$profileurl = defaults($remote_contact, 'nurl', '');
 | |
| 	}
 | |
| 
 | |
| 	$contact = [];
 | |
| 	// if it's the url containing https it should be converted to http
 | |
| 	$nurl = normalise_link(GContact::cleanContactUrl($profileurl));
 | |
| 	if (!$nurl) {
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// Search for contact data
 | |
| 	// Look if the local user has got the contact
 | |
| 	if (local_user()) {
 | |
| 		$contact = Contact::getDetailsByURL($nurl, local_user());
 | |
| 	}
 | |
| 
 | |
| 	// If not then check the global user
 | |
| 	if (!count($contact)) {
 | |
| 		$contact = Contact::getDetailsByURL($nurl);
 | |
| 	}
 | |
| 
 | |
| 	// Feeds url could have been destroyed through "cleanContactUrl", so we now use the original url
 | |
| 	if (!count($contact) && local_user()) {
 | |
| 		$nurl = normalise_link($profileurl);
 | |
| 		$contact = Contact::getDetailsByURL($nurl, local_user());
 | |
| 	}
 | |
| 
 | |
| 	if (!count($contact)) {
 | |
| 		$nurl = normalise_link($profileurl);
 | |
| 		$contact = Contact::getDetailsByURL($nurl);
 | |
| 	}
 | |
| 
 | |
| 	if (!count($contact)) {
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// Get the photo_menu - the menu if possible contact actions
 | |
| 	if (local_user()) {
 | |
| 		$actions = Contact::photoMenu($contact);
 | |
| 	} else {
 | |
| 		$actions = [];
 | |
| 	}
 | |
| 
 | |
| 	// Move the contact data to the profile array so we can deliver it to
 | |
| 	$profile = [
 | |
| 		'name'     => $contact['name'],
 | |
| 		'nick'     => $contact['nick'],
 | |
| 		'addr'     => defaults($contact, 'addr', $contact['url']),
 | |
| 		'thumb'    => ProxyUtils::proxifyUrl($contact['thumb'], false, ProxyUtils::SIZE_THUMB),
 | |
| 		'url'      => Contact::magicLink($contact['url']),
 | |
| 		'nurl'     => $contact['nurl'], // We additionally store the nurl as identifier
 | |
| 		'location' => $contact['location'],
 | |
| 		'gender'   => $contact['gender'],
 | |
| 		'about'    => $contact['about'],
 | |
| 		'network'  => format_network_name($contact['network'], $contact['url']),
 | |
| 		'tags'     => $contact['keywords'],
 | |
| 		'bd'       => $contact['birthday'] <= '0001-01-01' ? '' : $contact['birthday'],
 | |
| 		'account_type' => Contact::getAccountType($contact),
 | |
| 		'actions'  => $actions,
 | |
| 	];
 | |
| 	if ($datatype == 'html') {
 | |
| 		$tpl = get_markup_template('hovercard.tpl');
 | |
| 		$o = replace_macros($tpl, [
 | |
| 			'$profile' => $profile,
 | |
| 		]);
 | |
| 
 | |
| 		return $o;
 | |
| 	} else {
 | |
| 		System::jsonExit($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;
 | |
| }
 |