aboutsummaryrefslogblamecommitdiffstats
path: root/Zotlabs/Module/Profile.php
blob: 732beaa6aa8b2b763e30f9f2453dc2680b6bc251 (plain) (tree)
1
2
3
4
5
6
7
8
9
10
     
 







                                








                                            
                                  

                         

                               

                                         
                                                                               
                                          

                               
 
                                                       




                                                                   

                                                                                              

                 
                              
 
                                                                                
                                                      

                                                               

                                                                                                     


                                                       
 
                                


                                                         


                                               




                                                               

                                               





                                                                             
                                


                                                                                                                    
                                 
                                                      

                         


                                               
         
 
                        

                                                
                                       
                 
 
                                            
 

                             


                                                                                                            

                               

 
                                                        
                                                           
                                                                                                                                              
                                                            

                                 
 
                                                                                                                    
 
                                                                                                                             
                                                              

                               

                               

                                                             
                                                                                                              


                                           
                                         
                                                   
                          
 
         
 
 
<?php

namespace Zotlabs\Module;

use App;
use Zotlabs\Lib\ActivityStreams;
use Zotlabs\Lib\Activity;
use Zotlabs\Web\Controller;

/** @file */

require_once('include/contact_widgets.php');
require_once('include/items.php');
require_once("include/bbcode.php");
require_once('include/security.php');
require_once('include/conversation.php');
require_once('include/acl_selectors.php');


class Profile extends Controller {

	function init() {

		if (argc() > 1)
			$which = argv(1);
		else {
			notice(t('Requested profile is not available.') . EOL);
			App::$error = 404;
			return;
		}

		if (ActivityStreams::is_as_request()) {
			$channel = channelx_by_nick($which);
			if (!$channel) {
				http_status_exit(404, 'Not found');
			}

			$p = Activity::encode_person($channel, true);
			as_return_and_die(['type' => 'Profile', 'describes' => $p], $channel);
		}

		$profile = '';

		if ((local_channel()) && (argc() > 2) && (argv(2) === 'view')) {
			$channel = App::get_channel();
			$which   = $channel['channel_address'];
			$profile = argv(1);

			$r = q("select profile_guid from profile where id = %d and uid = %d limit 1",
				intval($profile),
				intval(local_channel())
			);

			if (!$r)
				$profile = '';
			$profile = $r[0]['profile_guid'];
		}

		head_add_link([
			'rel'   => 'alternate',
			'type'  => 'application/atom+xml',
			'title' => t('Posts and comments'),
			'href'  => z_root() . '/feed/' . $which
		]);

		head_add_link([
			'rel'   => 'alternate',
			'type'  => 'application/atom+xml',
			'title' => t('Only posts'),
			'href'  => z_root() . '/feed/' . $which . '?f=&top=1'
		]);


		if (!$profile) {
			$x = q("select channel_id as profile_uid from channel where channel_address = '%s' limit 1",
				dbesc(argv(1))
			);
			if ($x) {
				App::$profile = $x[0];
			}
		}

		profile_load($which, $profile);

	}

	function get() {

		if (observer_prohibited(true)) {
			return login();
		}

		nav_set_selected('Profile');

		$groups = [];
		$o      = '';

		if (!(perm_is_allowed(App::$profile['profile_uid'], get_observer_hash(), 'view_profile'))) {
			notice(t('Permission denied.') . EOL);
			return;
		}


		if (argc() > 2 && argv(2) === 'vcard') {
			header('Content-type: text/vcard');
			header('content-disposition: attachment; filename="' . t('vcard') . '-' . App::$profile['channel_address'] . '.vcf"');
			echo App::$profile['profile_vcard'];
			killme();
		}

		$is_owner = ((local_channel()) && (local_channel() == App::$profile['profile_uid']) ? true : false);

		if ((isset(App::$profile['hidewall']) && App::$profile['hidewall']) && (!$is_owner) && (!remote_channel())) {
			notice(t('Permission denied.') . EOL);
			return;
		}

		head_add_link([
			'rel'   => 'alternate',
			'type'  => 'application/json+oembed',
			'href'  => z_root() . '/oep?f=&url=' . urlencode(z_root() . '/' . App::$query_string),
			'title' => 'oembed'
		]);

		$o .= advanced_profile();
		call_hooks('profile_advanced', $o);
		return $o;

	}

}