aboutsummaryrefslogblamecommitdiffstats
path: root/Zotlabs/Module/Oep.php
blob: d3ef05e162022b90e17e47a9a84318d4c01bb1af (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12
13


                         

                                     







                                           
 
                                                                                  
 
                                                                            
                                             


                                                                        
 

                                                           
 


                                                         

                                                                 
 













                                                                    

                                                                 

                                                                    
 












                                                                                
 
                                                  
 
         
 
                                           
 

                                    

                                                                                     
 

                                                                                 
                 
 




                                                                 



                                             

                                                                     
                  





                                                 
 
                                  
                               



                                                                                            
                                                                    


                                                                                                          
                                                
                  
 

                               
 

                                              

                                                                                    
                                                                                   





                                                                                            
 
                                                                                





                                                                                                       
                              

                                                     
                         
                                 
                                
 
                                                              
 
                                      
 
                                                     
                                                                      
 
                                                                                                                                               
 

                                    
 
                            
 
         


                                         
 

                                    

                                                                                     





                                                                                     
                                    









                                                                                              
                                                                                              




                                                                                                                                
                                                                                     



                                    
 

                                                              




                                                               


                               










                                                                                                                
 
                                                                                






                                                                                                       

                                                     
                         

                                 
 
                                                              
 
                                      
 

                                                                      
 
                                                                                                                                               
 

                                    
 
                            
 


                                            
 

                                    

                                                                                     





                                                                                        
                                    





                                                   








                                                                                                                                   
                                                                                     




                                    

                                                              




                                                               


                               










                                                                                                                
 
                                                                                







                                                                                                       
 
                         

                                 
 
                                                              
 
                                      
 

                                                                      
 
                                                                                                                                               
 

                                    
 
                            
 

         
 
                                       
 

                                    

                                                                                     
 



                                                                                            
 




                                                                                    
 

                               


                                                                                            
 
                                                                       
 





                                                                                             
 

                                              

                                                                                    
                                                                                   




                                                                                            
 
                                                                                


                                                                      
                                                                                                       



                                                                 
                         
                                 
                                
 

                                                              
                                      
 
                                                     
                                                                      
 
                                                                                                                                               
 

                                    
 
                            
 
         
 
                                           

 

                                                    
                                    
 


                                                                                 
 

                               
 
                                            
 

                               

 

                                                        
 

                              
 








                                                                  
                 
                               
 


                                                 
 
                                                                                                                     
 
                            
 
         
 
                                         
 

                                    

                                                                                     
 

                                                                              
                                              
                 
 




                                                                                    
 

                               
 


                                                                                           
                                                                  
 
                                                                                                                                                 




                                                   
 
                                            
 
                                                                                                                                                       


                                                    
 






                                                                            
                                                 

                                      
 

                                                      
                                                                                                                                


                                                                         

 

                            
 
         

 
                                            
 

                                    

                                                                                     
 


                                                                        
 




                                                                                    
 

                               
 


                                                                                           
                                                                  
 
                                                                                                                                



                                                   
 
                                            
 
                                                                                                                                                       


                                                    
 






                                                                            
                                                 

                                      
 

                                                      
                                                                                                                                


                                                                         

 

                            
 
         

 
                                         
 

                                    

                                                                                     
 



                                                                              
 




                                                                                    
 

                               



                                                                                           
                                                                  

 
                                                                                                                                                       


                                                    
 






                                                                            
                                                 

                                      
 

                                                      
                                                                                                                                


                                                                         

 

                            
 

         
<?php
namespace Zotlabs\Module;

require_once('include/security.php');

// oembed provider




class Oep extends \Zotlabs\Web\Controller {

	function init() {

		logger('oep: ' . print_r($_REQUEST,true), LOGGER_DEBUG, LOG_INFO);

		$html = ((argc() > 1 && argv(1) === 'html') ? true : false);
		if(isset($_REQUEST['url'])) {
			$_REQUEST['url'] = strip_zids($_REQUEST['url']);
			$url = $_REQUEST['url'];
		}

		if(! $url)
			http_status_exit(404, 'Not found');

		$maxwidth  = $_REQUEST['maxwidth'] ?? 0;
		$maxheight = $_REQUEST['maxheight'] ?? 0;
		$format = $_REQUEST['format'] ?? '';
		if($format && $format !== 'json')
			http_status_exit(501, 'Not implemented');

		if(fnmatch('*/photos/*/album/*',$url))
			$arr = $this->oep_album_reply($_REQUEST);
		elseif(fnmatch('*/photos/*/image/*',$url))
			$arr = $this->oep_photo_reply($_REQUEST);
		elseif(fnmatch('*/photos*',$url))
			$arr = $this->oep_phototop_reply($_REQUEST);
		elseif(fnmatch('*/display/*',$url))
			$arr = $this->oep_display_reply($_REQUEST);
		elseif(fnmatch('*/channel/*mid=*',$url))
			$arr = $this->oep_mid_reply($_REQUEST);
		elseif(fnmatch('*/channel*',$url))
			$arr = $this->oep_profile_reply($_REQUEST);
		elseif(fnmatch('*/profile/*',$url))
			$arr = $this->oep_profile_reply($_REQUEST);
		elseif(fnmatch('*/cards/*',$url))
			$arr = $this->oep_cards_reply($_REQUEST);
		elseif(fnmatch('*/articles/*',$url))
			$arr = $this->oep_articles_reply($_REQUEST);

		if($arr) {
			if($html) {
				if($arr['type'] === 'rich') {
					header('Content-Type: text/html');
					echo $arr['html'];
				}
			}
			else {
				header('Content-Type: application/json+oembed');
				echo json_encode($arr);
			}
			killme();
		}

		http_status_exit(404,'Not found');

	}

	function oep_display_reply($args) {

		$ret = array();
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('#//(.*?)/display/(.*?)(&|\?|$)#',$url,$matches)) {
			$res = $matches[2];
		}

		$res = unpack_link_id($res);

		if ($res === false) {
			notice(t('Malformed message id.') . EOL);
			return;
		}

		$item_normal = item_normal();

		$p = q("select * from item where mid = '%s' limit 1",
	  		dbesc($res)
		);

		if(! $p)
			return;

		$c = channelx_by_n($p[0]['uid']);


		if(! ($c && $res))
			return;

		if(! perm_is_allowed($c[0]['channel_id'],get_observer_hash(),'view_stream'))
			return;

		$sql_extra = item_permissions_sql($c['channel_id']);

		$p = q("select * from item where mid = '%s' and uid = %d $sql_extra $item_normal limit 1",
			dbesc($res),
			intval($c['channel_id'])
		);

		if(! $p)
			return;

		xchan_query($p,true);
		$p = fetch_post_tags($p,true);

		// This function can get tripped up if the item is already a reshare
		// (the multiple share declarations do not parse cleanly if nested)
		// So build a template with a known nonsense string as the content, and then
		// replace that known string with the actual rendered content, sending
		// each content layer through bbcode() separately.

		$x = '2eGriplW^*Jmf4';


		$o = "[share author='".urlencode($p[0]['author']['xchan_name']).
			"' profile='".$p[0]['author']['xchan_url'] .
			"' avatar='".$p[0]['author']['xchan_photo_s'].
			"' link='".$p[0]['plink'].
			"' auth='".(($p[0]['author']['xchan_network'] === 'zot6') ? 'true' : 'false') .
			"' posted='".$p[0]['created'].
			"' message_id='".$p[0]['mid']."']";
	    if($p[0]['title'])
            $o .= '[b]'.$p[0]['title'].'[/b]'."\r\n";

		$o .= $x;
		$o .= "[/share]";
		$o = bbcode($o);

		$o = str_replace($x,bbcode($p[0]['body']),$o);

		$ret['type'] = 'rich';

		$w = (($maxwidth) ? $maxwidth : 640);
		$h = (($maxheight) ? $maxheight : intval($w * 2 / 3));

		$ret['html'] = '<div style="width: ' . $w . '; height: ' . $h . '; font-family: sans-serif,arial,freesans;" >' . $o . '</div>';

		$ret['width'] = $w;
		$ret['height'] = $h;

		return $ret;

	}


	function oep_cards_reply($args) {

		$ret = [];
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('#//(.*?)/cards/(.*?)/(.*?)(&|\?|$)#',$url,$matches)) {
			$nick = $matches[2];
			$res = $matches[3];
		}
		if(! ($nick && $res))
			return $ret;

		$channel = channelx_by_nick($nick);

		if(! $channel)
			return $ret;


		if(! perm_is_allowed($channel['channel_id'],get_observer_hash(),'view_pages'))
			return $ret;

		$sql_extra = item_permissions_sql($channel['channel_id'],get_observer_hash());

		$r = q("select * from iconfig where iconfig.cat = 'system' and iconfig.k = 'CARD' and iconfig.v = '%s' limit 1",
			dbesc($res)
		);
		if($r) {
			$sql_extra .= " and item.id = " . intval($r[0]['iid']) . " ";
		}
		else {
			return $ret;
		}

		$r = q("select * from item
			where item.uid = %d and item_type = %d
			$sql_extra order by item.created desc",
			intval($channel['channel_id']),
			intval(ITEM_TYPE_CARD)
		);

		if(! $r)
			return;

		$item_normal = " and item.item_hidden = 0 and item.item_type in (0,6) and item.item_deleted = 0
			and item.item_unpublished = 0 and item.item_delayed = 0 and item.item_pending_remove = 0
			and item.item_blocked = 0 ";

		if($r) {
			xchan_query($r);
			$p = fetch_post_tags($r, true);
		}

		$x = '2eGriplW^*Jmf4';


		$o = "[share author='".urlencode($p[0]['author']['xchan_name']).
			"' profile='".$p[0]['author']['xchan_url'] .
			"' avatar='".$p[0]['author']['xchan_photo_s'].
			"' link='".$p[0]['plink'].
			"' auth='".(($p[0]['author']['xchan_network'] === 'zot6') ? 'true' : 'false') .
			"' posted='".$p[0]['created'].
			"' message_id='".$p[0]['mid']."']";
		if($p[0]['title'])
            $o .= '[b]'.$p[0]['title'].'[/b]'."\r\n";

		$o .= $x;
		$o .= "[/share]";
		$o = bbcode($o);

		$o = str_replace($x,bbcode($p[0]['body']),$o);

		$ret['type'] = 'rich';

		$w = (($maxwidth) ? $maxwidth : 640);
		$h = (($maxheight) ? $maxheight : intval($w * 2 / 3));

		$ret['html'] = '<div style="width: ' . $w . '; height: ' . $h . '; font-family: sans-serif,arial,freesans;" >' . $o . '</div>';

		$ret['width'] = $w;
		$ret['height'] = $h;

		return $ret;

	}

	function oep_articles_reply($args) {

		$ret = [];
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('#//(.*?)/articles/(.*?)/(.*?)(&|\?|$)#',$url,$matches)) {
			$nick = $matches[2];
			$res = $matches[3];
		}
		if(! ($nick && $res))
			return $ret;

		$channel = channelx_by_nick($nick);

		if(! $channel)
			return $ret;

		if(! perm_is_allowed($channel['channel_id'],get_observer_hash(),'view_pages'))
			return $ret;

		$sql_extra = item_permissions_sql($channel['channel_id'],get_observer_hash());

		$r = q("select * from iconfig where iconfig.cat = 'system' and iconfig.k = 'ARTICLE' and iconfig.v = '%s' limit 1",
			dbesc($res)
		);
		if($r) {
			$sql_extra .= " and item.id = " . intval($r[0]['iid']) . " ";
		}
		else {
			return $ret;
		}

		$r = q("select * from item
			where item.uid = %d and item_type = %d
			$sql_extra order by item.created desc",
			intval($channel['channel_id']),
			intval(ITEM_TYPE_ARTICLE)
		);

		if(! $r)
			return;

		$item_normal = " and item.item_hidden = 0 and item.item_type in (0,7) and item.item_deleted = 0
			and item.item_unpublished = 0 and item.item_delayed = 0 and item.item_pending_remove = 0
			and item.item_blocked = 0 ";

		if($r) {
			xchan_query($r);
			$p = fetch_post_tags($r, true);
		}

		$x = '2eGriplW^*Jmf4';


		$o = "[share author='".urlencode($p[0]['author']['xchan_name']).
			"' profile='".$p[0]['author']['xchan_url'] .
			"' avatar='".$p[0]['author']['xchan_photo_s'].
			"' link='".$p[0]['plink'].
			"' auth='".(($p[0]['author']['xchan_network'] === 'zot6') ? 'true' : 'false') .
			"' posted='".$p[0]['created'].
			"' message_id='".$p[0]['mid']."']";
		if($p[0]['title'])
			$o .= '[b]'.$p[0]['title'].'[/b]'."\r\n";

		$o .= $x;
		$o .= "[/share]";
		$o = bbcode($o);

		$o = str_replace($x,bbcode($p[0]['body']),$o);

		$ret['type'] = 'rich';

		$w = (($maxwidth) ? $maxwidth : 640);
		$h = (($maxheight) ? $maxheight : intval($w * 2 / 3));

		$ret['html'] = '<div style="width: ' . $w . '; height: ' . $h . '; font-family: sans-serif,arial,freesans;" >' . $o . '</div>';

		$ret['width'] = $w;
		$ret['height'] = $h;

		return $ret;

	}


	function oep_mid_reply($args) {

		$ret = array();
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('#//(.*?)/(.*?)/(.*?)/(.*?)mid\=(.*?)(&|$)#',$url,$matches)) {
			$chn = $matches[3];
			$res = $matches[5];
		}

		if(! ($chn && $res))
			return;
		$c = q("select * from channel where channel_address = '%s' limit 1",
			dbesc($chn)
		);

		if(! $c)
			return;

		if(! perm_is_allowed($c[0]['channel_id'],get_observer_hash(),'view_stream'))
			return;

		$sql_extra = item_permissions_sql($c[0]['channel_id']);

		$p = q("select * from item where mid = '%s' and uid = %d $sql_extra limit 1",
	  		dbesc($res),
			intval($c[0]['channel_id'])
		);
		if(! $p)
			return;

		xchan_query($p,true);
		$p = fetch_post_tags($p,true);

		// This function can get tripped up if the item is already a reshare
		// (the multiple share declarations do not parse cleanly if nested)
		// So build a template with a known nonsense string as the content, and then
		// replace that known string with the actual rendered content, sending
		// each content layer through bbcode() separately.

		$x = '2eGriplW^*Jmf4';

		$o = "[share author='".urlencode($p[0]['author']['xchan_name']).
			"' profile='".$p[0]['author']['xchan_url'] .
			"' avatar='".$p[0]['author']['xchan_photo_s'].
			"' link='".$p[0]['plink'].
			"' auth='".(($p[0]['author']['xchan_network'] === 'zot6') ? 'true' : 'false') .
			"' posted='".$p[0]['created'].
			"' message_id='".$p[0]['mid']."']";
		if($p[0]['title'])
			$o .= '[b]'.$p[0]['title'].'[/b]'."\r\n";
		$o .= $x;
		$o .= "[/share]";
		$o = bbcode($o);

		$o = str_replace($x,bbcode($p[0]['body']),$o);

		$ret['type'] = 'rich';

		$w = (($maxwidth) ? $maxwidth : 640);
		$h = (($maxheight) ? $maxheight : intval($w * 2 / 3));

		$ret['html'] = '<div style="width: ' . $w . '; height: ' . $h . '; font-family: sans-serif,arial,freesans;" >' . $o . '</div>';

		$ret['width'] = $w;
		$ret['height'] = $h;

		return $ret;

	}

	function oep_profile_reply($args) {


		require_once('include/channel.php');

		$url = $args['url'];

		if(preg_match('#//(.*?)/(.*?)/(.*?)(/|\?|&|$)#',$url,$matches)) {
			$chn = $matches[3];
		}

		if(! $chn)
			return;

		$c = channelx_by_nick($chn);

		if(! $c)
			return;


		$maxwidth  = intval($args['maxwidth']);
		$maxheight = intval($args['maxheight']);

		$width = 800;
		$height = 375;

		if($maxwidth) {
			$width = $maxwidth;
			$height = (375 / 800) * $width;
		}
		if($maxheight) {
			if($maxheight < $height) {
				$width = (800 / 375) * $maxheight;
				$height = $maxheight;
			}
		}
		$ret = array();

		$ret['type'] = 'rich';
		$ret['width'] = intval($width);
		$ret['height'] = intval($height);

		$ret['html'] = get_zcard_embed($c,get_observer_hash(),array('width' => $width, 'height' => $height));

		return $ret;

	}

	function oep_album_reply($args) {

		$ret = array();
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('|//(.*?)/(.*?)/(.*?)/album/|',$url,$matches)) {
			$chn = $matches[3];
			$res = basename($url);
		}

		if(! ($chn && $res))
			return;
		$c = q("select * from channel where channel_address = '%s' limit 1",
			dbesc($chn)
		);

		if(! $c)
			return;

		if(! perm_is_allowed($c[0]['channel_id'],get_observer_hash(),'view_files'))
			return;

		$sql_extra = permissions_sql($c[0]['channel_id']);

		$p = q("select resource_id from photo where album = '%s' and uid = %d and imgscale = 0 $sql_extra order by created desc limit 1",
	  		dbesc($res),
			intval($c[0]['channel_id'])
		);
		if(! $p)
			return;

		$res = $p[0]['resource_id'];

		$r = q("select height, width, imgscale, resource_id from photo where uid = %d and resource_id = '%s' $sql_extra order by imgscale asc",
			intval($c[0]['channel_id']),
			dbesc($res)
		);

		if($r) {
			foreach($r as $rr) {
				$foundres = false;
				if($maxheight && $rr['height'] > $maxheight)
					continue;
				if($maxwidth && $rr['width'] > $maxwidth)
					continue;
				$foundres = true;
				break;
			}

			if($foundres) {
				$ret['type'] = 'link';
				$ret['thumbnail_url'] = z_root() . '/photo/' . '/' . $rr['resource_id'] . '-' . $rr['imgscale'];
				$ret['thumbnail_width'] = $rr['width'];
				$ret['thumbnail_height'] = $rr['height'];
			}


		}
		return $ret;

	}


	function oep_phototop_reply($args) {

		$ret = array();
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('|//(.*?)/(.*?)/(.*?)$|',$url,$matches)) {
			$chn = $matches[3];
		}

		if(! $chn)
			return;
		$c = q("select * from channel where channel_address = '%s' limit 1",
			dbesc($chn)
		);

		if(! $c)
			return;

		if(! perm_is_allowed($c[0]['channel_id'],get_observer_hash(),'view_files'))
			return;

		$sql_extra = permissions_sql($c[0]['channel_id']);

		$p = q("select resource_id from photo where uid = %d and imgscale = 0 $sql_extra order by created desc limit 1",
			intval($c[0]['channel_id'])
		);
		if(! $p)
			return;

		$res = $p[0]['resource_id'];

		$r = q("select height, width, imgscale, resource_id from photo where uid = %d and resource_id = '%s' $sql_extra order by imgscale asc",
			intval($c[0]['channel_id']),
			dbesc($res)
		);

		if($r) {
			foreach($r as $rr) {
				$foundres = false;
				if($maxheight && $rr['height'] > $maxheight)
					continue;
				if($maxwidth && $rr['width'] > $maxwidth)
					continue;
				$foundres = true;
				break;
			}

			if($foundres) {
				$ret['type'] = 'link';
				$ret['thumbnail_url'] = z_root() . '/photo/' . '/' . $rr['resource_id'] . '-' . $rr['imgscale'];
				$ret['thumbnail_width'] = $rr['width'];
				$ret['thumbnail_height'] = $rr['height'];
			}


		}
		return $ret;

	}


	function oep_photo_reply($args) {

		$ret = array();
		$url = $args['url'];
		$maxwidth  = ((isset($args['maxwidth'])) ? $args['maxwidth']  : 0);
		$maxheight = ((isset($args['maxheight'])) ? $args['maxheight']  : 0);

		if(preg_match('|//(.*?)/(.*?)/(.*?)/image/|',$url,$matches)) {
			$chn = $matches[3];
			$res = basename($url);
		}

		if(! ($chn && $res))
			return;
		$c = q("select * from channel where channel_address = '%s' limit 1",
			dbesc($chn)
		);

		if(! $c)
			return;

		if(! perm_is_allowed($c[0]['channel_id'],get_observer_hash(),'view_files'))
			return;

		$sql_extra = permissions_sql($c[0]['channel_id']);


		$r = q("select height, width, imgscale, resource_id from photo where uid = %d and resource_id = '%s' $sql_extra order by imgscale asc",
			intval($c[0]['channel_id']),
			dbesc($res)
		);

		if($r) {
			foreach($r as $rr) {
				$foundres = false;
				if($maxheight && $rr['height'] > $maxheight)
					continue;
				if($maxwidth && $rr['width'] > $maxwidth)
					continue;
				$foundres = true;
				break;
			}

			if($foundres) {
				$ret['type'] = 'link';
				$ret['thumbnail_url'] = z_root() . '/photo/' . '/' . $rr['resource_id'] . '-' . $rr['imgscale'];
				$ret['thumbnail_width'] = $rr['width'];
				$ret['thumbnail_height'] = $rr['height'];
			}


		}
		return $ret;

	}
}