aboutsummaryrefslogtreecommitdiffstats
path: root/system/user/main.php
blob: 56d82395d5ac66f8dff51bbcb4a526ca8d336971 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<?php
#===============================================================================
# INCLUDE: Main configuration
#===============================================================================
require_once '../../core/application.php';

#===============================================================================
# TRY: User\Exception
#===============================================================================
try {
	if(Application::get('USER.SLUG_URLS')) {
		$User = User\Factory::buildBySlug(HTTP::GET('param'));
	}

	else {
		$User = User\Factory::build(HTTP::GET('param'));
	}

	$user_data = generateUserItemData($User);

	#===============================================================================
	# Add user data for previous and next user
	#===============================================================================
	try {
		$PrevUser = User\Factory::build($User->getPrevID());
		$user_data['PREV'] = generateUserItemData($PrevUser);
	} catch(User\Exception $Exception){}

	try {
		$NextUser = User\Factory::build($User->getNextID());
		$user_data['NEXT'] = generateUserItemData($NextUser);
	} catch(User\Exception $Exception){}

	#===============================================================================
	# TRY: Template\Exception
	#===============================================================================
	try {
		#===============================================================================
		# TRY: PDOException
		#===============================================================================
		try {
			$PostCountStatement = $Database->query(sprintf('SELECT COUNT(*) FROM %s WHERE user = %d', Post\Attribute::TABLE, $User->getID()));
			$PageCountStatement = $Database->query(sprintf('SELECT COUNT(*) FROM %s WHERE user = %d', Page\Attribute::TABLE, $User->getID()));
		}

		#===============================================================================
		# CATCH: PDOException
		#===============================================================================
		catch(PDOException $Exception) {
			exit($Exception->getMessage());
		}

		$UserTemplate = Template\Factory::build('user/main');
		$UserTemplate->set('USER', $user_data);
		$UserTemplate->set('COUNT', [
			'POST' => $PostCountStatement->fetchColumn(),
			'PAGE' => $PageCountStatement->fetchColumn()
		]);

		$MainTemplate = Template\Factory::build('main');
		$MainTemplate->set('HTML', $UserTemplate);
		$MainTemplate->set('HEAD', [
			'NAME' => $user_data['ATTR']['FULLNAME'],
			'DESC' => cut(removeLineBreaksAndTabs(removeHTML($User->getHTML()), ' '), Application::get('USER.DESCRIPTION_SIZE')),
			'PERM' => $User->getURL(),
			'OG_IMAGES' => $User->getFiles()
		]);

		echo $MainTemplate;
	}

	#===============================================================================
	# CATCH: Template\Exception
	#===============================================================================
	catch(Template\Exception $Exception) {
		$Exception->defaultHandler();
	}
}

#===============================================================================
# CATCH: User\Exception
#===============================================================================
catch(User\Exception $Exception) {
	try {
		if(Application::get('USER.SLUG_URLS') === FALSE) {
			$User = User\Factory::buildBySlug(HTTP::GET('param'));
		} else {
			$User = User\Factory::build(HTTP::GET('param'));
		}

		HTTP::redirect($User->getURL());
	}

	catch(User\Exception $Exception) {
		Application::exit(404);
	}
}