diff options
Diffstat (limited to 'core/include/user/main.php')
-rw-r--r-- | core/include/user/main.php | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/core/include/user/main.php b/core/include/user/main.php new file mode 100644 index 0000000..7944f1f --- /dev/null +++ b/core/include/user/main.php @@ -0,0 +1,98 @@ +<?php +#=============================================================================== +# Get instances +#=============================================================================== +$Database = Application::getDatabase(); +$Language = Application::getLanguage(); + +#=============================================================================== +# TRY: User\Exception +#=============================================================================== +try { + if(Application::get('USER.SLUG_URLS')) { + $User = User\Factory::buildBySlug($param); + } + + else { + $User = User\Factory::build($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_data['BODY']['HTML']), ' '), Application::get('USER.DESCRIPTION_SIZE')), + 'PERM' => $User->getURL(), + 'OG_IMAGES' => $User->getFiles() + ]); + + echo $MainTemplate; + } + + #=============================================================================== + # CATCH: Template\Exception + #=============================================================================== + catch(Template\Exception $Exception) { + Application::exit($Exception->getMessage()); + } +} + +#=============================================================================== +# CATCH: User\Exception +#=============================================================================== +catch(User\Exception $Exception) { + try { + if(Application::get('USER.SLUG_URLS') === FALSE) { + $User = User\Factory::buildBySlug($param); + } else { + $User = User\Factory::build($param); + } + + HTTP::redirect($User->getURL()); + } + + catch(User\Exception $Exception) { + Application::error404(); + } +}
\ No newline at end of file |