Вход Регистрация
Файл: sngine-v2.8/Updates/Update 2.5.8 to 2.5.9/Update_2.5.9/profile.php
Строк: 164
<?php
/**
 * profile
 * 
 * @package Sngine
 * @author Zamblek
 */

// fetch bootstrap
require('bootstrap.php');

// user access
if(!$system['system_public']) {
    
user_access();
}

// check username
if(is_empty($_GET['username']) || !valid_username($_GET['username'])) {
    
_error(404);
}

try {

    
// [1] get main profile info
    
$get_profile $db->query(sprintf("SELECT users.*, picture_photo.source as user_picture_full, cover_photo.source as user_cover_full, packages.name as package_name, packages.color as package_color FROM users LEFT JOIN posts_photos as picture_photo ON users.user_picture_id = picture_photo.photo_id LEFT JOIN posts_photos as cover_photo ON users.user_cover_id = cover_photo.photo_id LEFT JOIN packages ON users.user_subscribed = '1' AND users.user_package = packages.package_id WHERE users.user_name = %s"secure($_GET['username']))) or _error(SQL_ERROR_THROWEN);
    if(
$get_profile->num_rows == 0) {
        
_error(404);
    }
    
$profile $get_profile->fetch_assoc();
    
/* check if banned by the system */
    
if($user->banned($profile['user_id'])) {
        
_error(404);
    }
    
/* check if blocked by the viewer */
    
if($user->blocked($profile['user_id'])) {
        
_error(404);
    }
    
/* check username case */
    
if(strtolower($_GET['username']) == strtolower($profile['user_name']) && $_GET['username'] != $profile['user_name']) {
        
redirect('/'.$profile['user_name']);
    }
    
/* get profile picture */
    
$profile['user_picture_default'] = ($profile['user_picture'])? false true;
    
$profile['user_picture'] = get_picture($profile['user_picture'], $profile['user_gender']);
    
$profile['user_picture_full'] = ($profile['user_picture_full'])? $system['system_uploads'].'/'.$profile['user_picture_full'] : $profile['user_picture_full'];
    
/* get profile cover */
    
$profile['user_cover_default'] = ($profile['user_cover'])? false true;
    
$profile['user_cover'] = ($profile['user_cover'])? $system['system_uploads'].'/'.$profile['user_cover'] : $profile['user_cover'];
    
$profile['user_cover_full'] = ($profile['user_cover_full'])? $system['system_uploads'].'/'.$profile['user_cover_full'] : $profile['user_cover_full'];
    
/* get the connection &  mutual friends */
    
if($user->_logged_in && $profile['user_id'] != $user->_data['user_id']) {
        
/* get the connection */
        
$profile['we_friends'] = (in_array($profile['user_id'], $user->_data['friends_ids']))? truefalse;
        
$profile['he_request'] = (in_array($profile['user_id'], $user->_data['friend_requests_ids']))? truefalse;
        
$profile['i_request'] = (in_array($profile['user_id'], $user->_data['friend_requests_sent_ids']))? truefalse;
        
$profile['i_follow'] = (in_array($profile['user_id'], $user->_data['followings_ids']))? truefalse;
        
$profile['friendship_declined'] = $user->friendship_declined($profile['user_id']);
        
/* get mutual friends */
        
$profile['mutual_friends_count'] = $user->get_mutual_friends_count($profile['user_id']);
        
$profile['mutual_friends'] = $user->get_mutual_friends($profile['user_id']);
    }
    
    
// [2] get view content
    
switch ($_GET['view']) {

        case 
'':
            
/* profile completion */
            
if($profile['user_id'] == $user->_data['user_id']) {
                
$profile['profile_completion'] = 100;
                
/* [1] check profile picture */
                
if($profile['user_picture_default']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [2] check profile cover */
                
if($profile['user_cover_default']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [3] check biography */
                
if(!$profile['user_biography']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [4] check birthdate */
                
if(!$profile['user_birthdate']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [5] check relationship */
                
if(!$profile['user_relationship']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [6] check work */
                
if(!$profile['user_work_title'] || !$profile['user_work_place']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [7] check location */
                
if(!$profile['user_current_city'] || !$profile['user_hometown']) {
                    
$profile['profile_completion'] -= 12.5;
                }
                
/* [8] check education */
                
if(!$profile['user_edu_major'] || !$profile['user_edu_school']) {
                    
$profile['profile_completion'] -= 12.5;
                }
            }

            
/* get followers count */
            
$profile['followers_count'] = count($user->get_followers_ids($profile['user_id']));

            
/* get custom fields */
            
$smarty->assign('custom_fields'$user->get_custom_fields( array("for" => "user""get" => "profile""node_id" => $profile['user_id']) ));

            
/* get friends */
            
$profile['friends'] = $user->get_friends($profile['user_id']);
            if(
count($profile['friends']) > 0) {
                
$profile['friends_count'] = count($user->get_friends_ids($profile['user_id']));
            }

            
/* get photos */
            
$profile['photos'] = $user->get_photos($profile['user_id']);

            
/* get pages */
            
$profile['pages'] = $user->get_pages( array('user_id' => $profile['user_id'], 'results' => $system['min_results_even']) );
            
            
/* get groups */
            
$profile['groups'] = $user->get_groups( array('user_id' => $profile['user_id'], 'results' => $system['min_results_even']) );

            
/* get events */
            
$profile['events'] = $user->get_events( array('user_id' => $profile['user_id'], 'results' => $system['min_results_even']) );

            
/* get pinned post */
            
$pinned_post $user->get_post($profile['user_pinned_post']);
            
$smarty->assign('pinned_post'$pinned_post);

            
/* prepare publisher */
            
$smarty->assign('feelings'get_feelings());
            
$smarty->assign('feelings_types'get_feelings_types());

            
/* get posts */
            
$posts $user->get_posts( array('get' => 'posts_profile''id' => $profile['user_id']) );
            
/* assign variables */
            
$smarty->assign('posts'$posts);
            break;

        case 
'friends':
            
/* get friends */
            
$profile['friends'] = $user->get_friends($profile['user_id']);            
            if(
count($profile['friends']) > 0) {
                
$profile['friends_count'] = count($user->get_friends_ids($profile['user_id']));
            }
            break;

        case 
'followers':
            
/* get followers count */
            
$profile['followers_count'] = count($user->get_followers_ids($profile['user_id']));
            
/* get followers */
            
if($profile['followers_count'] > 0) {
                
$profile['followers'] = $user->get_followers($profile['user_id']);
            }
            break;

        case 
'followings':
            
/* get followings count */
            
$profile['followings_count'] = count($user->get_followings_ids($profile['user_id']));
            
/* get followings */
            
if($profile['followings_count'] > 0) {
                
$profile['followings'] = $user->get_followings($profile['user_id']);
            }
            break;

        case 
'photos':
            
/* get photos */
            
$profile['photos'] = $user->get_photos($profile['user_id']);
            break;

        case 
'albums':
            
/* get albums */
            
$profile['albums'] = $user->get_albums($profile['user_id']);
            break;

        case 
'album':
            
/* get album */
            
$album $user->get_album($_GET['id']);
            if(!
$album || $album['in_group'] || $album['user_type'] == "page" || ($album['user_type'] == "user" && $album['user_id'] != $profile['user_id'])) {
                
_error(404);
            }
            
/* assign variables */
            
$smarty->assign('album'$album);
            break;

        case 
'likes':
            
/* get pages */
            
$profile['pages'] = $user->get_pages( array('user_id' => $profile['user_id']) );
            break;

        case 
'groups':
            
/* get groups */
            
$profile['groups'] = $user->get_groups( array('user_id' => $profile['user_id']) );
            break;

        case 
'events':
            
/* get events */
            
$profile['events'] = $user->get_events( array('user_id' => $profile['user_id']) );
            break;

        default:
            
_error(404);
            break;
    }

    
// [3] profile visit notification
    
if($_GET['view'] == "" && $user->_logged_in && $system['profile_notification_enabled']) {
        
$user->post_notification( array('to_user_id'=>$profile['user_id'], 'action'=>'profile_visit') );
    }

    
// recent rearches
    
if(isset($_GET['ref']) && $_GET['ref'] == "qs") {
        
$user->set_search_log($profile['user_id'], 'user');
    }

} catch (
Exception $e) {
    
_error(__("Error"), $e->getMessage());
}

// page header
page_header($profile['user_firstname']." ".$profile['user_lastname'], $profile['user_biography'], $profile['user_picture']);

// assign variables
$smarty->assign('profile'$profile);
$smarty->assign('view'$_GET['view']);

// page footer
page_footer("profile");

?>
Онлайн: 2
Реклама