2020-06-07 19:04:43 +03:00
< ? php declare ( strict_types = 1 );
namespace openvk\Web\Presenters ;
use openvk\Web\Models\Entities\ { Club , Photo };
use openvk\Web\Models\Entities\Notifications\ClubModeratorNotification ;
2021-12-15 01:27:17 +03:00
use openvk\Web\Models\Repositories\ { Clubs , Users , Albums , Managers , Topics };
2021-12-16 21:40:34 +03:00
use Chandler\Security\Authenticator ;
2020-06-07 19:04:43 +03:00
final class GroupPresenter extends OpenVKPresenter
{
private $clubs ;
function __construct ( Clubs $clubs )
{
$this -> clubs = $clubs ;
parent :: __construct ();
}
function renderView ( int $id ) : void
{
$club = $this -> clubs -> get ( $id );
if ( ! $club ) {
$this -> notFound ();
} else {
if ( $club -> getShortCode ())
if ( parse_url ( $_SERVER [ " REQUEST_URI " ], PHP_URL_PATH ) !== " / " . $club -> getShortCode ())
$this -> redirect ( " / " . $club -> getShortCode (), static :: REDIRECT_TEMPORARY_PRESISTENT );
$this -> template -> club = $club ;
$this -> template -> albums = ( new Albums ) -> getClubAlbums ( $club , 1 , 3 );
$this -> template -> albumsCount = ( new Albums ) -> getClubAlbumsCount ( $club );
2021-12-15 01:27:17 +03:00
$this -> template -> topics = ( new Topics ) -> getLastTopics ( $club , 3 );
$this -> template -> topicsCount = ( new Topics ) -> getClubTopicsCount ( $club );
2020-06-07 19:04:43 +03:00
}
}
function renderCreate () : void
{
$this -> assertUserLoggedIn ();
2021-01-01 00:18:53 +03:00
$this -> willExecuteWriteAction ();
2020-06-07 19:04:43 +03:00
if ( $_SERVER [ " REQUEST_METHOD " ] === " POST " ) {
if ( ! empty ( $this -> postParam ( " name " )))
{
$club = new Club ;
$club -> setName ( $this -> postParam ( " name " ));
$club -> setAbout ( empty ( $this -> postParam ( " about " )) ? NULL : $this -> postParam ( " about " ));
$club -> setOwner ( $this -> user -> id );
try {
$club -> save ();
} catch ( \PDOException $ex ) {
if ( $ex -> getCode () == 23000 )
$this -> flashFail ( " err " , " Ошибка " , " Произошла ошибка на стороне сервера. Обратитесь к системному администратору. " );
else
throw $ex ;
}
$club -> toggleSubscription ( $this -> user -> identity );
header ( " HTTP/1.1 302 Found " );
header ( " Location: /club " . $club -> getId ());
} else {
$this -> flashFail ( " err " , " Ошибка " , " Вы не ввели название группы. " );
}
}
}
function renderSub () : void
{
$this -> assertUserLoggedIn ();
2021-01-01 00:18:53 +03:00
$this -> willExecuteWriteAction ();
2020-06-07 19:04:43 +03:00
if ( $_SERVER [ " REQUEST_METHOD " ] !== " POST " ) exit ( " Invalid state " );
$club = $this -> clubs -> get (( int ) $this -> postParam ( " id " ));
if ( ! $club ) exit ( " Invalid state " );
$club -> toggleSubscription ( $this -> user -> identity );
header ( " HTTP/1.1 302 Found " );
header ( " Location: /club " . $club -> getId ());
exit ;
}
function renderFollowers ( int $id ) : void
{
$this -> assertUserLoggedIn ();
2021-11-12 16:31:23 +03:00
$this -> template -> club = $this -> clubs -> get ( $id );
$this -> template -> onlyShowManagers = $this -> queryParam ( " onlyAdmins " ) == " 1 " ;
if ( $this -> template -> onlyShowManagers ) {
$this -> template -> followers = null ;
$this -> template -> managers = $this -> template -> club -> getManagers (( int ) ( $this -> queryParam ( " p " ) ? ? 1 ), ! $this -> template -> club -> canBeModifiedBy ( $this -> user -> identity ));
if ( $this -> template -> club -> canBeModifiedBy ( $this -> user -> identity ) || ! $this -> template -> club -> isOwnerHidden ()) {
$this -> template -> managers = array_merge ([ $this -> template -> club -> getOwner ()], iterator_to_array ( $this -> template -> managers ));
}
$this -> template -> count = $this -> template -> club -> getManagersCount ();
2021-11-14 00:39:00 +03:00
} else {
$this -> template -> followers = $this -> template -> club -> getFollowers (( int ) ( $this -> queryParam ( " p " ) ? ? 1 ));
$this -> template -> managers = null ;
$this -> template -> count = $this -> template -> club -> getFollowersCount ();
2021-11-12 16:31:23 +03:00
}
2021-11-14 00:39:00 +03:00
$this -> template -> paginatorConf = ( object ) [
" count " => $this -> template -> count ,
" page " => $this -> queryParam ( " p " ) ? ? 1 ,
" amount " => NULL ,
" perPage " => OPENVK_DEFAULT_PER_PAGE ,
];
2020-06-07 19:04:43 +03:00
}
function renderModifyAdmin ( int $id ) : void
{
$user = is_null ( $this -> queryParam ( " user " )) ? $this -> postParam ( " user " ) : $this -> queryParam ( " user " );
$comment = $this -> postParam ( " comment " );
2021-11-06 14:06:57 +03:00
$removeComment = $this -> postParam ( " removeComment " ) === " 1 " ;
2021-11-12 16:31:23 +03:00
$hidden = [ " 0 " => false , " 1 " => true ][ $this -> queryParam ( " hidden " )] ? ? null ;
2020-06-07 19:04:43 +03:00
//$index = $this->queryParam("index");
if ( ! $user )
$this -> badRequest ();
$club = $this -> clubs -> get ( $id );
$user = ( new Users ) -> get (( int ) $user );
if ( ! $user || ! $club )
$this -> notFound ();
2021-11-12 16:31:23 +03:00
if ( ! $club -> canBeModifiedBy ( $this -> user -> identity ? ? NULL ))
2020-06-07 19:04:43 +03:00
$this -> flashFail ( " err " , " Ошибка доступа " , " У вас недостаточно прав, чтобы изменять этот р е с у р с ." );
2021-11-12 16:31:23 +03:00
if ( ! is_null ( $hidden )) {
if ( $club -> getOwner () -> getId () == $user -> getId ()) {
$club -> setOwner_Hidden ( $hidden );
$club -> save ();
} else {
$manager = ( new Managers ) -> getByUserAndClub ( $user -> getId (), $club -> getId ());
$manager -> setHidden ( $hidden );
$manager -> save ();
}
if ( $club -> getManagersCount ( true ) == 0 ) {
$club -> setAdministrators_List_Display ( 2 );
$club -> save ();
}
if ( $hidden ) {
$this -> flashFail ( " succ " , " Операция успешна " , " Теперь " . $user -> getCanonicalName () . " будет показываться как обычный подписчик всем кроме других администраторов " );
} else {
$this -> flashFail ( " succ " , " Операция успешна " , " Теперь все будут знать про то что " . $user -> getCanonicalName () . " - администратор " );
}
} elseif ( $removeComment ) {
2021-11-06 14:06:57 +03:00
if ( $club -> getOwner () -> getId () == $user -> getId ()) {
$club -> setOwner_Comment ( null );
$club -> save ();
} else {
$manager = ( new Managers ) -> getByUserAndClub ( $user -> getId (), $club -> getId ());
$manager -> setComment ( null );
$manager -> save ();
}
$this -> flashFail ( " succ " , " Операция успешна " , " Комментарий к администратору удален " );
} elseif ( $comment ) {
2021-11-24 23:47:32 +03:00
if ( mb_strlen ( $comment ) > 36 ) {
$commentLength = ( string ) mb_strlen ( $comment );
2021-11-06 14:06:57 +03:00
$this -> flashFail ( " err " , " Ошибка " , " Комментарий слишком длинный ( $commentLength символов вместо 36 символов) " );
}
if ( $club -> getOwner () -> getId () == $user -> getId ()) {
$club -> setOwner_Comment ( $comment );
$club -> save ();
} else {
$manager = ( new Managers ) -> getByUserAndClub ( $user -> getId (), $club -> getId ());
$manager -> setComment ( $comment );
$manager -> save ();
}
2020-06-07 19:04:43 +03:00
$this -> flashFail ( " succ " , " Операция успешна " , " Комментарий к администратору изменён " );
} else {
if ( $club -> canBeModifiedBy ( $user )) {
$club -> removeManager ( $user );
$this -> flashFail ( " succ " , " Операция успешна " , $user -> getCanonicalName () . " более не администратор. " );
} else {
$club -> addManager ( $user );
( new ClubModeratorNotification ( $user , $club , $this -> user -> identity )) -> emit ();
$this -> flashFail ( " succ " , " Операция успешна " , $user -> getCanonicalName () . " назначен(а ) администратором. " );
}
}
}
function renderEdit ( int $id ) : void
{
$this -> assertUserLoggedIn ();
2021-01-01 00:18:53 +03:00
$this -> willExecuteWriteAction ();
2020-06-07 19:04:43 +03:00
$club = $this -> clubs -> get ( $id );
if ( ! $club -> canBeModifiedBy ( $this -> user -> identity ))
$this -> notFound ();
else
$this -> template -> club = $club ;
if ( $_SERVER [ " REQUEST_METHOD " ] === " POST " ) {
$club -> setName ( empty ( $this -> postParam ( " name " )) ? $club -> getName () : $this -> postParam ( " name " ));
$club -> setAbout ( empty ( $this -> postParam ( " about " )) ? NULL : $this -> postParam ( " about " ));
$club -> setShortcode ( empty ( $this -> postParam ( " shortcode " )) ? NULL : $this -> postParam ( " shortcode " ));
2020-06-11 12:54:20 +03:00
$club -> setWall ( empty ( $this -> postParam ( " wall " )) ? 0 : 1 );
2021-11-05 12:44:50 +03:00
$club -> setAdministrators_List_Display ( empty ( $this -> postParam ( " administrators_list_display " )) ? 0 : $this -> postParam ( " administrators_list_display " ));
2021-12-15 01:27:17 +03:00
$club -> setEveryone_Can_Create_Topics ( empty ( $this -> postParam ( " everyone_can_create_topics " )) ? 0 : 1 );
2020-06-07 19:04:43 +03:00
2021-11-12 19:56:41 +03:00
$website = $this -> postParam ( " website " ) ? ? " " ;
if ( empty ( $website ))
2021-11-14 00:43:51 +03:00
$club -> setWebsite ( NULL );
2021-11-12 19:56:41 +03:00
else
2021-11-14 00:43:51 +03:00
$club -> setWebsite (( ! parse_url ( $website , PHP_URL_SCHEME ) ? " https:// " : " " ) . $website );
2021-11-12 19:56:41 +03:00
2020-06-07 19:04:43 +03:00
if ( $_FILES [ " ava " ][ " error " ] === UPLOAD_ERR_OK ) {
$photo = new Photo ;
try {
$photo -> setOwner ( $this -> user -> id );
$photo -> setDescription ( " Profile image " );
$photo -> setFile ( $_FILES [ " ava " ]);
$photo -> setCreated ( time ());
$photo -> save ();
( new Albums ) -> getClubAvatarAlbum ( $club ) -> addPhoto ( $photo );
} catch ( ISE $ex ) {
$name = $album -> getName ();
$this -> flashFail ( " err " , " Неизвестная ошибка " , " Н е удалось сохранить фотографию." );
}
}
try {
$club -> save ();
} catch ( \PDOException $ex ) {
if ( $ex -> getCode () == 23000 )
$this -> flashFail ( " err " , " Ошибка " , " Произошла ошибка на стороне сервера. Обратитесь к системному администратору. " );
else
throw $ex ;
}
$this -> flash ( " succ " , " Изменения сохранены " , " Новые данные появятся в вашей группе. " );
}
}
function renderStatistics ( int $id ) : void
{
$this -> assertUserLoggedIn ();
if ( ! eventdb ())
$this -> flashFail ( " err " , " Ошибка подключения " , " Н е удалось подключится к службе телеметрии." );
$club = $this -> clubs -> get ( $id );
if ( ! $club -> canBeModifiedBy ( $this -> user -> identity ))
$this -> notFound ();
else
$this -> template -> club = $club ;
$this -> template -> reach = $club -> getPostViewStats ( true );
$this -> template -> views = $club -> getPostViewStats ( false );
}
function renderAdmin ( int $clb , int $id ) : void
{
$this -> assertUserLoggedIn ();
$manager = ( new Managers ) -> get ( $id );
if ( $manager -> getClub () -> canBeModifiedBy ( $this -> user -> identity )){
$this -> template -> manager = $manager ;
$this -> template -> club = $manager -> getClub ();
} else {
$this -> notFound ();
}
}
2021-12-16 21:40:34 +03:00
function renderChangeOwner ( int $id , int $newOwnerId ) : void
{
$this -> assertUserLoggedIn ();
$this -> willExecuteWriteAction ();
if ( $_SERVER [ 'REQUEST_METHOD' ] !== " POST " )
$this -> redirect ( " /groups " . $this -> user -> id );
if ( ! Authenticator :: verifyHash ( $this -> postParam ( " password " ), $this -> user -> identity -> getChandlerUser () -> getRaw () -> passwordHash ))
$this -> flashFail ( " err " , tr ( " error " ), tr ( " incorrect_password " ));
$club = $this -> clubs -> get ( $id );
$newOwner = ( new Users ) -> get ( $newOwnerId );
if ( $this -> user -> id !== $club -> getOwner () -> getId ())
$this -> flashFail ( " err " , tr ( " error " ), tr ( " forbidden " ));
$club -> setOwner ( $newOwnerId );
$club -> addManager ( $this -> user -> id );
$club -> save ();
$this -> flashFail ( " succ " , tr ( " information_-1 " ), tr ( " group_owner_setted " , $newOwner -> getCanonicalName (), $club -> getName ()));
}
2020-06-07 19:04:43 +03:00
}