2020-06-07 19:04:43 +03:00
< ? php declare ( strict_types = 1 );
namespace openvk\Web\Models\Entities ;
2022-04-12 20:10:35 +03:00
use morphos\Gender ;
2020-06-11 23:21:49 +03:00
use openvk\Web\Themes\ { Themepack , Themepacks };
2020-06-07 19:04:43 +03:00
use openvk\Web\Util\DateTime ;
use openvk\Web\Models\RowModel ;
2021-10-07 11:48:55 +03:00
use openvk\Web\Models\Entities\ { Photo , Message , Correspondence , Gift };
2023-08-11 16:50:19 +03:00
use openvk\Web\Models\Repositories\ { Applications , Bans , Comments , Notes , Posts , Users , Clubs , Albums , Gifts , Notifications , Videos , Photos };
2022-02-05 21:09:37 +03:00
use openvk\Web\Models\Exceptions\InvalidUserNameException ;
2020-06-07 19:04:43 +03:00
use Nette\Database\Table\ActiveRow ;
use Chandler\Database\DatabaseConnection ;
use Chandler\Security\User as ChandlerUser ;
2022-04-12 20:10:35 +03:00
use function morphos\Russian\inflectName ;
2020-06-07 19:04:43 +03:00
class User extends RowModel
{
protected $tableName = " profiles " ;
const TYPE_DEFAULT = 0 ;
const TYPE_BOT = 1 ;
const SUBSCRIPTION_ABSENT = 0 ;
const SUBSCRIPTION_INCOMING = 1 ;
const SUBSCRIPTION_OUTGOING = 2 ;
const SUBSCRIPTION_MUTUAL = 3 ;
const PRIVACY_NO_ONE = 0 ;
const PRIVACY_ONLY_FRIENDS = 1 ;
const PRIVACY_ONLY_REGISTERED = 2 ;
const PRIVACY_EVERYONE = 3 ;
2021-01-07 19:19:36 +03:00
const NSFW_INTOLERANT = 0 ;
const NSFW_TOLERANT = 1 ;
const NSFW_FULL_TOLERANT = 2 ;
2022-03-27 16:43:20 +03:00
protected function _abstractRelationGenerator ( string $filename , int $page = 1 , int $limit = 6 ) : \Traversable
2020-06-07 19:04:43 +03:00
{
$id = $this -> getId ();
$query = " SELECT id FROM \n " . file_get_contents ( __DIR__ . " /../sql/ $filename .tsql " );
2022-03-27 16:43:20 +03:00
$query .= " \n LIMIT " . $limit . " OFFSET " . ( ( $page - 1 ) * $limit );
2020-06-07 19:04:43 +03:00
2023-08-04 15:10:23 +03:00
$ids = [];
2020-06-07 19:04:43 +03:00
$rels = DatabaseConnection :: i () -> getConnection () -> query ( $query , $id , $id );
foreach ( $rels as $rel ) {
$rel = ( new Users ) -> get ( $rel -> id );
if ( ! $rel ) continue ;
2023-08-04 15:10:23 +03:00
if ( in_array ( $rel -> getId (), $ids )) continue ;
$ids [] = $rel -> getId ();
2020-06-07 19:04:43 +03:00
yield $rel ;
}
}
protected function _abstractRelationCount ( string $filename ) : int
{
$id = $this -> getId ();
$query = " SELECT COUNT(*) AS cnt FROM \n " . file_get_contents ( __DIR__ . " /../sql/ $filename .tsql " );
return ( int ) DatabaseConnection :: i () -> getConnection () -> query ( $query , $id , $id ) -> fetch () -> cnt ;
}
function getId () : int
{
return $this -> getRecord () -> id ;
}
2020-06-11 23:21:49 +03:00
function getStyle () : string
2020-06-07 19:04:43 +03:00
{
return $this -> getRecord () -> style ;
}
2020-06-11 23:21:49 +03:00
function getTheme () : ? Themepack
{
return Themepacks :: i ()[ $this -> getStyle ()] ? ? NULL ;
}
2020-06-07 19:04:43 +03:00
function getStyleAvatar () : int
{
return $this -> getRecord () -> style_avatar ;
}
function hasMilkshakeEnabled () : bool
{
return ( bool ) $this -> getRecord () -> milkshake ;
}
2021-01-04 20:33:25 +03:00
function hasMicroblogEnabled () : bool
{
return ( bool ) $this -> getRecord () -> microblog ;
}
2022-05-23 11:18:06 +03:00
function getMainPage () : int
{
return $this -> getRecord () -> main_page ;
}
2020-06-07 19:04:43 +03:00
function getChandlerGUID () : string
{
return $this -> getRecord () -> user ;
}
function getChandlerUser () : ChandlerUser
{
return new ChandlerUser ( $this -> getRecord () -> ref ( " ChandlerUsers " , " user " ));
}
function getURL () : string
{
if ( ! is_null ( $this -> getShortCode ()))
return " / " . $this -> getShortCode ();
else
return " /id " . $this -> getId ();
}
2022-04-05 14:39:13 +03:00
function getAvatarUrl ( string $size = " miniscule " ) : string
2020-06-07 19:04:43 +03:00
{
2022-02-06 16:09:26 +03:00
$serverUrl = ovk_scheme ( true ) . $_SERVER [ " HTTP_HOST " ];
2020-09-29 23:03:55 +03:00
2020-06-07 19:04:43 +03:00
if ( $this -> getRecord () -> deleted )
2020-09-29 23:03:55 +03:00
return " $serverUrl /assets/packages/static/openvk/img/camera_200.png " ;
2020-06-07 19:04:43 +03:00
else if ( $this -> isBanned ())
2020-09-29 23:03:55 +03:00
return " $serverUrl /assets/packages/static/openvk/img/banned.jpg " ;
2020-06-07 19:04:43 +03:00
$avPhoto = $this -> getAvatarPhoto ();
if ( is_null ( $avPhoto ))
2020-09-29 23:03:55 +03:00
return " $serverUrl /assets/packages/static/openvk/img/camera_200.png " ;
2020-06-07 19:04:43 +03:00
else
2022-04-05 14:39:13 +03:00
return $avPhoto -> getURLBySizeId ( $size );
2020-06-07 19:04:43 +03:00
}
function getAvatarLink () : string
{
$avPhoto = $this -> getAvatarPhoto ();
if ( ! $avPhoto ) return " javascript:void(0) " ;
$pid = $avPhoto -> getPrettyId ();
$aid = ( new Albums ) -> getUserAvatarAlbum ( $this ) -> getId ();
return " /photo $pid ?from=album $aid " ;
}
function getAvatarPhoto () : ? Photo
{
$avAlbum = ( new Albums ) -> getUserAvatarAlbum ( $this );
$avCount = $avAlbum -> getPhotosCount ();
$avPhotos = $avAlbum -> getPhotos ( $avCount , 1 );
return iterator_to_array ( $avPhotos )[ 0 ] ? ? NULL ;
}
2022-05-30 11:09:45 +03:00
function getFirstName ( bool $pristine = false ) : string
2020-06-07 19:04:43 +03:00
{
2022-08-05 23:00:52 +03:00
$name = ( $this -> isDeleted () && ! $this -> isDeactivated () ? " DELETED " : mb_convert_case ( $this -> getRecord () -> first_name , MB_CASE_TITLE ));
2022-11-14 17:47:34 +03:00
$tsn = tr ( " __transNames " );
if (( $tsn !== " @__transNames " && ! empty ( $tsn ) ) && ! $pristine )
2022-11-14 18:01:56 +03:00
return mb_convert_case ( transliterator_transliterate ( $tsn , $name ), MB_CASE_TITLE );
2022-05-30 11:09:45 +03:00
else
return $name ;
2020-06-07 19:04:43 +03:00
}
2022-05-30 11:09:45 +03:00
function getLastName ( bool $pristine = false ) : string
2020-06-07 19:04:43 +03:00
{
2022-08-05 23:00:52 +03:00
$name = ( $this -> isDeleted () && ! $this -> isDeactivated () ? " DELETED " : mb_convert_case ( $this -> getRecord () -> last_name , MB_CASE_TITLE ));
2022-11-14 17:47:34 +03:00
$tsn = tr ( " __transNames " );
if (( $tsn !== " @__transNames " && ! empty ( $tsn ) ) && ! $pristine )
2022-11-14 18:01:56 +03:00
return mb_convert_case ( transliterator_transliterate ( $tsn , $name ), MB_CASE_TITLE );
2022-05-30 11:09:45 +03:00
else
return $name ;
2020-06-07 19:04:43 +03:00
}
function getPseudo () : ? string
{
2022-08-05 23:00:52 +03:00
return ( $this -> isDeleted () && ! $this -> isDeactivated () ? " DELETED " : $this -> getRecord () -> pseudo );
2020-06-07 19:04:43 +03:00
}
function getFullName () : string
{
2022-08-05 23:00:52 +03:00
if ( $this -> isDeleted () && ! $this -> isDeactivated ())
2020-06-07 19:04:43 +03:00
return " DELETED " ;
$pseudo = $this -> getPseudo ();
if ( ! $pseudo )
$pseudo = " " ;
else
$pseudo = " ( $pseudo ) " ;
return $this -> getFirstName () . $pseudo . $this -> getLastName ();
}
2022-04-12 20:10:35 +03:00
function getMorphedName ( string $case = " genitive " , bool $fullName = true ) : string
{
$name = $fullName ? ( $this -> getLastName () . " " . $this -> getFirstName ()) : $this -> getFirstName ();
if ( ! preg_match ( " %^[А -яё \ -]+ $ % " , $name ))
return $name ; # name is probably not russian
$inflected = inflectName ( $name , $case , $this -> isFemale () ? Gender :: FEMALE : Gender :: MALE );
return $inflected ? : $name ;
}
2020-06-07 19:04:43 +03:00
function getCanonicalName () : string
{
2022-08-05 23:00:52 +03:00
if ( $this -> isDeleted () && ! $this -> isDeactivated ())
2020-06-07 19:04:43 +03:00
return " DELETED " ;
2022-04-12 20:10:35 +03:00
else
return $this -> getFirstName () . " " . $this -> getLastName ();
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPhone () : ? string
{
return $this -> getRecord () -> phone ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getEmail () : ? string
{
return $this -> getRecord () -> email ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getOnline () : DateTime
{
return new DateTime ( $this -> getRecord () -> online );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getDescription () : ? string
{
return $this -> getRecord () -> about ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getStatus () : ? string
{
return $this -> getRecord () -> status ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getShortCode () : ? string
{
return $this -> getRecord () -> shortcode ;
}
2022-04-12 20:10:35 +03:00
2021-11-03 00:07:26 +03:00
function getAlert () : ? string
{
return $this -> getRecord () -> alert ;
}
2022-04-12 20:10:35 +03:00
2023-08-11 16:50:19 +03:00
function getTextForContentBan ( string $type ) : string
{
switch ( $type ) {
case " post " : return " за размещение от Вашего лица таких <b>записей</b>: " ;
case " photo " : return " за размещение от Вашего лица таких <b>фотографий</b>: " ;
case " video " : return " за размещение от Вашего лица таких <b>видеозаписей</b>: " ;
case " group " : return " за подозрительное вступление от Вашего лица <b>в группу:</b> " ;
case " comment " : return " за размещение от Вашего лица таких <b>комментариев</b>: " ;
case " note " : return " за размещение от Вашего лица таких <b>заметок</b>: " ;
case " app " : return " за создание от Вашего имени <b>подозрительных приложений</b>. " ;
default : return " за размещение от Вашего лица такого <b>контента</b>: " ;
}
}
function getRawBanReason () : ? string
2020-06-07 19:04:43 +03:00
{
return $this -> getRecord () -> block_reason ;
}
2022-03-26 23:48:42 +03:00
2023-08-11 16:50:19 +03:00
function getBanReason ( ? string $for = null )
{
$ban = ( new Bans ) -> get (( int ) $this -> getRecord () -> block_reason );
if ( ! $ban || $ban -> isOver ()) return null ;
$reason = $ban -> getReason ();
preg_match ( '/\*\*content-(post|photo|video|group|comment|note|app|noSpamTemplate|user)-(\d+)\*\*$/' , $reason , $matches );
if ( sizeof ( $matches ) === 3 ) {
$content_type = $matches [ 1 ]; $content_id = ( int ) $matches [ 2 ];
if ( in_array ( $content_type , [ " noSpamTemplate " , " user " ])) {
$reason = " Подозрительная активность " ;
} else {
if ( $for !== " banned " ) {
$reason = " Подозрительная активность " ;
} else {
$reason = [ $this -> getTextForContentBan ( $content_type ), $content_type ];
switch ( $content_type ) {
case " post " : $reason [] = ( new Posts ) -> get ( $content_id ); break ;
case " photo " : $reason [] = ( new Photos ) -> get ( $content_id ); break ;
case " video " : $reason [] = ( new Videos ) -> get ( $content_id ); break ;
case " group " : $reason [] = ( new Clubs ) -> get ( $content_id ); break ;
case " comment " : $reason [] = ( new Comments ) -> get ( $content_id ); break ;
case " note " : $reason [] = ( new Notes ) -> get ( $content_id ); break ;
case " app " : $reason [] = ( new Applications ) -> get ( $content_id ); break ;
case " user " : $reason [] = ( new Users ) -> get ( $content_id ); break ;
default : $reason [] = null ;
}
}
}
}
return $reason ;
}
2022-03-26 23:48:42 +03:00
function getBanInSupportReason () : ? string
{
return $this -> getRecord () -> block_in_support_reason ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getType () : int
{
return $this -> getRecord () -> type ;
}
2022-04-12 20:10:35 +03:00
2021-11-03 20:19:15 +03:00
function getCoins () : float
2020-06-07 19:04:43 +03:00
{
2021-10-12 12:15:55 +03:00
if ( ! OPENVK_ROOT_CONF [ " openvk " ][ " preferences " ][ " commerce " ])
2021-11-03 20:19:15 +03:00
return 0.0 ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return $this -> getRecord () -> coins ;
}
2022-04-12 20:10:35 +03:00
2021-10-07 11:47:30 +03:00
function getRating () : int
{
2021-10-12 12:15:55 +03:00
return OPENVK_ROOT_CONF [ " openvk " ][ " preferences " ][ " commerce " ] ? $this -> getRecord () -> rating : 0 ;
2021-10-07 11:47:30 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getReputation () : int
{
return $this -> getRecord () -> reputation ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getRegistrationTime () : DateTime
{
return new DateTime ( $this -> getRecord () -> since -> getTimestamp ());
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getRegistrationIP () : string
{
return $this -> getRecord () -> registering_ip ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getHometown () : ? string
{
return $this -> getRecord () -> hometown ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPoliticalViews () : int
{
return $this -> getRecord () -> polit_views ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getMaritalStatus () : int
{
return $this -> getRecord () -> marital_status ;
}
2022-05-30 10:46:27 +03:00
function getLocalizedMaritalStatus () : string
{
$status = $this -> getMaritalStatus ();
$string = " relationship_ $status " ;
if ( $this -> isFemale ()) {
$res = tr ( $string . " _fem " );
if ( $res != ( " @ " . $string . " _fem " ))
return $res ; # If fem version exists, return
}
return tr ( $string );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getContactEmail () : ? string
{
return $this -> getRecord () -> email_contact ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getTelegram () : ? string
{
return $this -> getRecord () -> telegram ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getInterests () : ? string
{
return $this -> getRecord () -> interests ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFavoriteMusic () : ? string
{
return $this -> getRecord () -> fav_music ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFavoriteFilms () : ? string
{
return $this -> getRecord () -> fav_films ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFavoriteShows () : ? string
{
return $this -> getRecord () -> fav_shows ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFavoriteBooks () : ? string
{
return $this -> getRecord () -> fav_books ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFavoriteQuote () : ? string
{
return $this -> getRecord () -> fav_quote ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getCity () : ? string
{
return $this -> getRecord () -> city ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPhysicalAddress () : ? string
{
return $this -> getRecord () -> address ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getNotificationOffset () : int
{
return $this -> getRecord () -> notification_offset ;
}
2021-09-13 19:34:02 +03:00
2021-12-14 18:53:44 +03:00
function getBirthday () : ? DateTime
2021-09-13 19:34:02 +03:00
{
2022-07-09 17:33:55 +03:00
if ( is_null ( $this -> getRecord () -> birthday ))
return NULL ;
else
return new DateTime ( $this -> getRecord () -> birthday );
}
function getBirthdayPrivacy () : int
{
return $this -> getRecord () -> birthday_privacy ;
2021-09-13 19:34:02 +03:00
}
2021-11-27 21:02:37 +03:00
function getAge () : ? int
{
2021-12-25 14:21:39 +03:00
return ( int ) floor (( time () - $this -> getBirthday () -> timestamp ()) / YEAR );
2021-11-27 21:02:37 +03:00
}
2022-04-12 20:10:35 +03:00
2021-12-02 18:31:32 +03:00
function get2faSecret () : ? string
{
return $this -> getRecord ()[ " 2fa_secret " ];
}
function is2faEnabled () : bool
{
return ! is_null ( $this -> get2faSecret ());
}
2020-06-07 19:04:43 +03:00
function updateNotificationOffset () : void
{
$this -> stateChanges ( " notification_offset " , time ());
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getLeftMenuItemStatus ( string $id ) : bool
{
return ( bool ) bmask ( $this -> getRecord () -> left_menu , [
" length " => 1 ,
" mappings " => [
" photos " ,
" videos " ,
" messages " ,
" notes " ,
" groups " ,
" news " ,
2021-12-17 19:58:31 +03:00
" links " ,
2022-01-03 22:13:53 +03:00
" poster " ,
2023-09-17 00:56:36 +03:00
" apps "
2020-06-07 19:04:43 +03:00
],
]) -> get ( $id );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPrivacySetting ( string $id ) : int
{
return ( int ) bmask ( $this -> getRecord () -> privacy , [
" length " => 2 ,
" mappings " => [
" page.read " ,
" page.info.read " ,
" groups.read " ,
" photos.read " ,
" videos.read " ,
" notes.read " ,
" friends.read " ,
" friends.add " ,
" wall.write " ,
2021-12-28 12:40:14 +03:00
" messages.write " ,
2020-06-07 19:04:43 +03:00
],
]) -> get ( $id );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPrivacyPermission ( string $permission , ? User $user = NULL ) : bool
{
$permStatus = $this -> getPrivacySetting ( $permission );
if ( ! $user )
return $permStatus === User :: PRIVACY_EVERYONE ;
else if ( $user -> getId () === $this -> getId ())
return true ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
switch ( $permStatus ) {
case User :: PRIVACY_ONLY_FRIENDS :
return $this -> getSubscriptionStatus ( $user ) === User :: SUBSCRIPTION_MUTUAL ;
case User :: PRIVACY_ONLY_REGISTERED :
case User :: PRIVACY_EVERYONE :
return true ;
default :
return false ;
}
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getProfileCompletenessReport () : object
{
$incompleteness = 0 ;
$unfilled = [];
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
if ( ! $this -> getRecord () -> status ) {
$unfilled [] = " status " ;
2021-02-06 23:38:39 +03:00
$incompleteness += 15 ;
2020-06-07 19:04:43 +03:00
}
if ( ! $this -> getRecord () -> telegram ) {
$unfilled [] = " telegram " ;
2021-02-06 23:38:39 +03:00
$incompleteness += 15 ;
2020-06-07 19:04:43 +03:00
}
if ( ! $this -> getRecord () -> email ) {
$unfilled [] = " email " ;
$incompleteness += 20 ;
}
if ( ! $this -> getRecord () -> city ) {
$unfilled [] = " city " ;
$incompleteness += 20 ;
}
if ( ! $this -> getRecord () -> interests ) {
$unfilled [] = " interests " ;
$incompleteness += 20 ;
}
2022-04-12 20:10:35 +03:00
2021-10-09 22:42:20 +03:00
$total = max ( 100 - $incompleteness + $this -> getRating (), 0 );
2021-10-09 22:44:48 +03:00
if ( ovkGetQuirk ( " profile.rating-bar-behaviour " ) === 0 )
2021-10-10 00:05:20 +03:00
if ( $total >= 100 )
2021-10-12 12:15:55 +03:00
$percent = round (( $total / 10 ** strlen ( strval ( $total ))) * 100 , 0 );
2021-10-09 22:42:20 +03:00
else
2021-10-12 12:15:55 +03:00
$percent = min ( $total , 100 );
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return ( object ) [
2021-10-09 22:42:20 +03:00
" total " => $total ,
" percent " => $percent ,
2020-06-07 19:04:43 +03:00
" unfilled " => $unfilled ,
];
}
2022-04-12 20:10:35 +03:00
2022-03-27 16:43:20 +03:00
function getFriends ( int $page = 1 , int $limit = 6 ) : \Traversable
2020-06-07 19:04:43 +03:00
{
2022-03-27 16:43:20 +03:00
return $this -> _abstractRelationGenerator ( " get-friends " , $page , $limit );
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFriendsCount () : int
{
return $this -> _abstractRelationCount ( " get-friends " );
}
2022-04-12 20:10:35 +03:00
2022-07-31 14:33:23 +03:00
function getFriendsOnline ( int $page = 1 , int $limit = 6 ) : \Traversable
{
return $this -> _abstractRelationGenerator ( " get-online-friends " , $page , $limit );
}
function getFriendsOnlineCount () : int
{
return $this -> _abstractRelationCount ( " get-online-friends " );
}
2022-03-27 16:43:20 +03:00
function getFollowers ( int $page = 1 , int $limit = 6 ) : \Traversable
2020-06-07 19:04:43 +03:00
{
2022-03-27 16:43:20 +03:00
return $this -> _abstractRelationGenerator ( " get-followers " , $page , $limit );
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getFollowersCount () : int
{
return $this -> _abstractRelationCount ( " get-followers " );
}
2022-04-12 20:10:35 +03:00
2022-03-27 16:43:20 +03:00
function getSubscriptions ( int $page = 1 , int $limit = 6 ) : \Traversable
2020-06-07 19:04:43 +03:00
{
2022-03-27 16:43:20 +03:00
return $this -> _abstractRelationGenerator ( " get-subscriptions-user " , $page , $limit );
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getSubscriptionsCount () : int
{
return $this -> _abstractRelationCount ( " get-subscriptions-user " );
}
2021-01-07 19:19:36 +03:00
function getUnreadMessagesCount () : int
{
return sizeof ( DatabaseConnection :: i () -> getContext () -> table ( " messages " ) -> where ([ " recipient_id " => $this -> getId (), " unread " => 1 ]));
}
2022-04-12 20:10:35 +03:00
2022-10-11 03:46:49 +03:00
function getClubs ( int $page = 1 , bool $admin = false , int $count = OPENVK_DEFAULT_PER_PAGE , bool $offset = false ) : \Traversable
2020-06-07 19:04:43 +03:00
{
2022-10-11 03:46:49 +03:00
if ( ! $offset )
$page = ( $page - 1 ) * $count ;
2021-12-03 21:08:50 +03:00
if ( $admin ) {
$id = $this -> getId ();
$query = " SELECT `id` FROM `groups` WHERE `owner` = ? UNION SELECT `club` as `id` FROM `group_coadmins` WHERE `user` = ? " ;
2022-10-11 03:46:49 +03:00
$query .= " LIMIT " . $count . " OFFSET " . $page ;
2021-12-03 21:08:50 +03:00
$sel = DatabaseConnection :: i () -> getConnection () -> query ( $query , $id , $id );
foreach ( $sel as $target ) {
$target = ( new Clubs ) -> get ( $target -> id );
if ( ! $target ) continue ;
yield $target ;
}
} else {
2022-10-11 03:46:49 +03:00
$sel = $this -> getRecord () -> related ( " subscriptions.follower " ) -> limit ( $count , $page );
2021-12-03 21:08:50 +03:00
foreach ( $sel -> where ( " model " , " openvk \\ Web \\ Models \\ Entities \\ Club " ) as $target ) {
$target = ( new Clubs ) -> get ( $target -> target );
if ( ! $target ) continue ;
yield $target ;
}
2020-06-07 19:04:43 +03:00
}
}
2022-04-12 20:10:35 +03:00
2021-11-20 13:47:59 +03:00
function getClubCount ( bool $admin = false ) : int
2020-06-07 19:04:43 +03:00
{
2021-12-03 21:08:50 +03:00
if ( $admin ) {
$id = $this -> getId ();
$query = " SELECT COUNT(*) AS `cnt` FROM (SELECT `id` FROM `groups` WHERE `owner` = ? UNION SELECT `club` as `id` FROM `group_coadmins` WHERE `user` = ?) u0; " ;
return ( int ) DatabaseConnection :: i () -> getConnection () -> query ( $query , $id , $id ) -> fetch () -> cnt ;
} else {
$sel = $this -> getRecord () -> related ( " subscriptions.follower " );
$sel = $sel -> where ( " model " , " openvk \\ Web \\ Models \\ Entities \\ Club " );
2021-11-20 13:47:59 +03:00
2021-12-03 21:08:50 +03:00
return sizeof ( $sel );
2021-11-20 13:47:59 +03:00
}
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2021-11-10 11:45:06 +03:00
function getPinnedClubs () : \Traversable
{
foreach ( $this -> getRecord () -> related ( " groups.owner " ) -> where ( " owner_club_pinned " , true ) as $target ) {
$target = ( new Clubs ) -> get ( $target -> id );
if ( ! $target ) continue ;
yield $target ;
}
foreach ( $this -> getRecord () -> related ( " group_coadmins.user " ) -> where ( " club_pinned " , true ) as $target ) {
$target = ( new Clubs ) -> get ( $target -> club );
if ( ! $target ) continue ;
yield $target ;
}
}
function getPinnedClubCount () : int
{
return sizeof ( $this -> getRecord () -> related ( " groups.owner " ) -> where ( " owner_club_pinned " , true )) + sizeof ( $this -> getRecord () -> related ( " group_coadmins.user " ) -> where ( " club_pinned " , true ));
}
function isClubPinned ( Club $club ) : bool
{
if ( $club -> getOwner () -> getId () === $this -> getId ())
return $club -> isOwnerClubPinned ();
$manager = $club -> getManager ( $this );
if ( ! is_null ( $manager ))
return $manager -> isClubPinned ();
2021-12-24 23:08:03 +03:00
return false ;
2021-11-10 11:45:06 +03:00
}
2020-06-07 19:04:43 +03:00
function getMeetings ( int $page = 1 ) : \Traversable
{
$sel = $this -> getRecord () -> related ( " event_turnouts.user " ) -> page ( $page , OPENVK_DEFAULT_PER_PAGE );
foreach ( $sel as $target ) {
$target = ( new Clubs ) -> get ( $target -> event );
if ( ! $target ) continue ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
yield $target ;
}
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getMeetingCount () : int
{
return sizeof ( $this -> getRecord () -> related ( " event_turnouts.user " ));
}
2022-04-12 20:10:35 +03:00
2021-10-07 11:48:55 +03:00
function getGifts ( int $page = 1 , ? int $perPage = NULL ) : \Traversable
{
$gifts = $this -> getRecord () -> related ( " gift_user_relations.receiver " ) -> order ( " sent DESC " ) -> page ( $page , $perPage ? ? OPENVK_DEFAULT_PER_PAGE );
foreach ( $gifts as $rel ) {
yield ( object ) [
" sender " => ( new Users ) -> get ( $rel -> sender ),
" gift " => ( new Gifts ) -> get ( $rel -> gift ),
" caption " => $rel -> comment ,
" anon " => $rel -> anonymous ,
" sent " => new DateTime ( $rel -> sent ),
];
}
}
2022-04-12 20:10:35 +03:00
2021-10-07 11:48:55 +03:00
function getGiftCount () : int
{
return sizeof ( $this -> getRecord () -> related ( " gift_user_relations.receiver " ));
}
2021-12-02 18:31:32 +03:00
function get2faBackupCodes () : \Traversable
{
$sel = $this -> getRecord () -> related ( " 2fa_backup_codes.owner " );
foreach ( $sel as $target )
yield $target -> code ;
}
function get2faBackupCodeCount () : int
{
return sizeof ( $this -> getRecord () -> related ( " 2fa_backup_codes.owner " ));
}
function generate2faBackupCodes () : void
{
$codes = [];
for ( $i = 0 ; $i < 10 - $this -> get2faBackupCodeCount (); $i ++ ) {
$codes [] = [
owner => $this -> getId (),
code => random_int ( 10000000 , 99999999 )
];
}
if ( sizeof ( $codes ) > 0 )
DatabaseConnection :: i () -> getContext () -> table ( " 2fa_backup_codes " ) -> insert ( $codes );
}
function use2faBackupCode ( int $code ) : bool
{
2022-04-12 20:10:35 +03:00
return ( bool ) $this -> getRecord () -> related ( " 2fa_backup_codes.owner " ) -> where ( " code " , $code ) -> delete ();
2021-12-02 18:31:32 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getSubscriptionStatus ( User $user ) : int
{
$subbed = ! is_null ( $this -> getRecord () -> related ( " subscriptions.follower " ) -> where ([
" model " => static :: class ,
" target " => $user -> getId (),
]) -> fetch ());
$followed = ! is_null ( $this -> getRecord () -> related ( " subscriptions.target " ) -> where ([
" model " => static :: class ,
" follower " => $user -> getId (),
]) -> fetch ());
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
if ( $subbed && $followed ) return User :: SUBSCRIPTION_MUTUAL ;
if ( $subbed ) return User :: SUBSCRIPTION_INCOMING ;
if ( $followed ) return User :: SUBSCRIPTION_OUTGOING ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return User :: SUBSCRIPTION_ABSENT ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getNotificationsCount ( bool $archived = false ) : int
{
return ( new Notifications ) -> getNotificationCountByUser ( $this , $this -> getNotificationOffset (), $archived );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getNotifications ( int $page , bool $archived = false ) : \Traversable
{
return ( new Notifications ) -> getNotificationsByUser ( $this , $this -> getNotificationOffset (), $archived , $page );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getPendingPhoneVerification () : ? ActiveRow
{
return $this -> getRecord () -> ref ( " number_verification " , " id " );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function getRefLinkId () : string
{
2021-09-13 06:22:05 +03:00
$hash = hash_hmac ( " Snefru " , ( string ) $this -> getId (), CHANDLER_ROOT_CONF [ " security " ][ " secret " ], true );
2022-04-12 20:10:35 +03:00
2021-09-13 06:22:05 +03:00
return dechex ( $this -> getId ()) . " " . base64_encode ( $hash );
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2021-01-07 19:19:36 +03:00
function getNsfwTolerance () : int
{
return $this -> getRecord () -> nsfw_tolerance ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function isFemale () : bool
{
return ( bool ) $this -> getRecord () -> sex ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function isVerified () : bool
{
return ( bool ) $this -> getRecord () -> verified ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function isBanned () : bool
{
return ! is_null ( $this -> getBanReason ());
}
2022-03-26 23:48:42 +03:00
function isBannedInSupport () : bool
{
return ! is_null ( $this -> getBanInSupportReason ());
}
2022-04-12 20:10:35 +03:00
2021-11-04 14:45:30 +03:00
function isOnline () : bool
{
return time () - $this -> getRecord () -> online <= 300 ;
}
2022-04-12 20:10:35 +03:00
2022-12-17 02:03:02 +03:00
function getOnlinePlatform ( bool $forAPI = false ) : ? string
{
$platform = $this -> getRecord () -> client_name ;
if ( $forAPI ) {
switch ( $platform ) {
2023-02-03 14:22:19 +03:00
case 'openvk_refresh_android' :
2022-12-17 02:03:02 +03:00
case 'openvk_legacy_android' :
return 'android' ;
break ;
case 'openvk_ios' :
case 'openvk_legacy_ios' :
return 'iphone' ;
break ;
case 'vika_touch' : // кика хохотач а х а х а х а х х а х а х а х а х а х
case 'vk4me' :
return 'mobile' ;
break ;
case NULL :
return NULL ;
break ;
default :
return 'api' ;
break ;
}
} else {
return $platform ;
}
}
function getOnlinePlatformDetails () : array
{
$clients = simplexml_load_file ( OPENVK_ROOT . " /data/clients.xml " );
foreach ( $clients as $client ) {
if ( $client [ 'tag' ] == $this -> getOnlinePlatform ()) {
return [
" tag " => $client [ 'tag' ],
" name " => $client [ 'name' ],
" url " => $client [ 'url' ],
" img " => $client [ 'img' ]
];
break ;
}
}
return [
" tag " => $this -> getOnlinePlatform (),
" name " => NULL ,
" url " => NULL ,
" img " => NULL
];
}
2020-06-07 19:04:43 +03:00
function prefersNotToSeeRating () : bool
{
return ! (( bool ) $this -> getRecord () -> show_rating );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function hasPendingNumberChange () : bool
{
return ! is_null ( $this -> getPendingPhoneVerification ());
}
2022-04-12 20:10:35 +03:00
2021-10-07 11:48:55 +03:00
function gift ( User $sender , Gift $gift , ? string $comment = NULL , bool $anonymous = false ) : void
{
DatabaseConnection :: i () -> getContext () -> table ( " gift_user_relations " ) -> insert ([
" sender " => $sender -> getId (),
" receiver " => $this -> getId (),
" gift " => $gift -> getId (),
" comment " => $comment ,
" anonymous " => $anonymous ,
" sent " => time (),
]);
}
2022-04-12 20:10:35 +03:00
2023-08-11 16:50:19 +03:00
function ban ( string $reason , bool $deleteSubscriptions = true , $unban_time = NULL , ? int $initiator = NULL ) : void
2021-12-25 23:32:15 +03:00
{
if ( $deleteSubscriptions ) {
$subs = DatabaseConnection :: i () -> getContext () -> table ( " subscriptions " );
$subs = $subs -> where (
" follower = ? OR (target = ? AND model = ?) " ,
$this -> getId (),
$this -> getId (),
get_class ( $this ),
);
$subs -> delete ();
}
2022-04-12 20:10:35 +03:00
2023-08-11 16:50:19 +03:00
$iat = time ();
$ban = new Ban ;
$ban -> setUser ( $this -> getId ());
$ban -> setReason ( $reason );
$ban -> setInitiator ( $initiator );
$ban -> setIat ( $iat );
$ban -> setExp ( $unban_time !== " permanent " ? $unban_time : 0 );
$ban -> setTime ( $unban_time === " permanent " ? 0 : ( $unban_time ? ( $unban_time - $iat ) : 0 ));
$ban -> save ();
$this -> setBlock_Reason ( $ban -> getId ());
// $this->setUnblock_time($unban_time);
$this -> save ();
}
function unban ( int $removed_by ) : void
{
$ban = ( new Bans ) -> get (( int ) $this -> getRawBanReason ());
if ( ! $ban || $ban -> isOver ())
return ;
$ban -> setRemoved_Manually ( true );
$ban -> setRemoved_By ( $removed_by );
$ban -> save ();
$this -> setBlock_Reason ( NULL );
// $user->setUnblock_time(NULL);
2020-07-17 19:26:59 +03:00
$this -> save ();
}
2022-04-12 20:10:35 +03:00
2022-08-05 23:00:52 +03:00
function deactivate ( ? string $reason ) : void
{
$this -> setDeleted ( 1 );
$this -> setDeact_Date ( time () + ( MONTH * 7 ));
$this -> setDeact_Reason ( $reason );
$this -> save ();
}
function reactivate () : void
{
$this -> setDeleted ( 0 );
$this -> setDeact_Date ( 0 );
$this -> setDeact_Reason ( " " );
$this -> save ();
}
function getDeactivationDate () : DateTime
{
return new DateTime ( $this -> getRecord () -> deact_date );
}
2020-06-07 19:04:43 +03:00
function verifyNumber ( string $code ) : bool
{
$ver = $this -> getPendingPhoneVerification ();
if ( ! $ver ) return false ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
try {
if ( sodium_memcmp (( string ) $ver -> code , $code ) === - 1 ) return false ;
} catch ( \SodiumException $ex ) {
return false ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
$this -> setPhone ( $ver -> number );
$this -> save ();
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
DatabaseConnection :: i () -> getContext ()
-> table ( " number_verification " )
-> where ( " user " , $this -> getId ())
-> delete ();
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return true ;
}
2022-04-12 20:10:35 +03:00
2022-02-05 21:09:37 +03:00
function setFirst_Name ( string $firstName ) : void
{
$firstName = mb_convert_case ( $firstName , MB_CASE_TITLE );
2022-02-08 13:15:29 +03:00
if ( ! preg_match ( '%^[\p{Lu}\p{Lo}]\p{Mn}?(?:[\p{L&}\p{Lo}]\p{Mn}?){1,16}$%u' , $firstName ))
2022-02-05 21:09:37 +03:00
throw new InvalidUserNameException ;
2022-04-12 20:10:35 +03:00
2022-02-05 21:09:37 +03:00
$this -> stateChanges ( " first_name " , $firstName );
}
2022-04-12 20:10:35 +03:00
2022-02-05 21:09:37 +03:00
function setLast_Name ( string $lastName ) : void
{
2022-02-07 20:16:47 +03:00
if ( ! empty ( $lastName ))
{
$lastName = mb_convert_case ( $lastName , MB_CASE_TITLE );
2022-02-08 13:15:29 +03:00
if ( ! preg_match ( '%^[\p{Lu}\p{Lo}]\p{Mn}?([\p{L&}\p{Lo}]\p{Mn}?){1,16}(\-\g<1>+)?$%u' , $lastName ))
2022-02-07 20:16:47 +03:00
throw new InvalidUserNameException ;
}
2022-04-12 20:10:35 +03:00
2022-02-05 21:09:37 +03:00
$this -> stateChanges ( " last_name " , $lastName );
}
2022-04-12 20:10:35 +03:00
2021-01-07 19:19:36 +03:00
function setNsfwTolerance ( int $tolerance ) : void
{
$this -> stateChanges ( " nsfw_tolerance " , $tolerance );
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function setPrivacySetting ( string $id , int $status ) : void
{
$this -> stateChanges ( " privacy " , bmask ( $this -> changes [ " privacy " ] ? ? $this -> getRecord () -> privacy , [
" length " => 2 ,
" mappings " => [
" page.read " ,
" page.info.read " ,
" groups.read " ,
" photos.read " ,
" videos.read " ,
" notes.read " ,
" friends.read " ,
" friends.add " ,
" wall.write " ,
2021-12-28 12:40:14 +03:00
" messages.write " ,
2020-06-07 19:04:43 +03:00
],
]) -> set ( $id , $status ) -> toInteger ());
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function setLeftMenuItemStatus ( string $id , bool $status ) : void
{
$mask = bmask ( $this -> changes [ " left_menu " ] ? ? $this -> getRecord () -> left_menu , [
" length " => 1 ,
" mappings " => [
" photos " ,
" videos " ,
" messages " ,
" notes " ,
" groups " ,
" news " ,
2021-12-17 19:58:31 +03:00
" links " ,
2022-01-03 22:13:53 +03:00
" poster " ,
2023-09-17 00:56:36 +03:00
" apps "
2020-06-07 19:04:43 +03:00
],
]) -> set ( $id , ( int ) $status ) -> toInteger ();
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
$this -> stateChanges ( " left_menu " , $mask );
}
2022-04-12 20:10:35 +03:00
2021-10-13 23:41:12 +03:00
function setShortCode ( ? string $code = NULL , bool $force = false ) : ? bool
2020-06-07 19:04:43 +03:00
{
if ( ! is_null ( $code )) {
2021-10-13 23:41:12 +03:00
if ( strlen ( $code ) < OPENVK_ROOT_CONF [ " openvk " ][ " preferences " ][ " shortcodes " ][ " minLength " ] && ! $force )
return false ;
2020-06-07 19:04:43 +03:00
if ( ! preg_match ( " %^[a-z][a-z0-9 \\ . \\ _] { 0,30}[a-z0-9] $ % " , $code ))
return false ;
if ( in_array ( $code , OPENVK_ROOT_CONF [ " openvk " ][ " preferences " ][ " shortcodes " ][ " forbiddenNames " ]))
return false ;
if ( \Chandler\MVC\Routing\Router :: i () -> getMatchingRoute ( " / $code " )[ 0 ] -> presenter !== " UnknownTextRouteStrategy " )
return false ;
2022-04-12 20:10:35 +03:00
2021-10-13 23:41:12 +03:00
$pClub = DatabaseConnection :: i () -> getContext () -> table ( " groups " ) -> where ( " shortcode " , $code ) -> fetch ();
if ( ! is_null ( $pClub ))
return false ;
2022-09-17 00:21:29 +03:00
$pAlias = DatabaseConnection :: i () -> getContext () -> table ( " aliases " ) -> where ( " shortcode " , $code ) -> fetch ();
if ( ! is_null ( $pAlias ))
return false ;
2020-06-07 19:04:43 +03:00
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
$this -> stateChanges ( " shortcode " , $code );
return true ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
function setPhoneWithVerification ( string $phone ) : string
{
$code = unpack ( " S " , openssl_random_pseudo_bytes ( 2 ))[ 1 ];
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
if ( $this -> hasPendingNumberChange ()) {
DatabaseConnection :: i () -> getContext ()
-> table ( " number_verification " )
-> where ( " user " , $this -> getId ())
-> update ([ " number " => $phone , " code " => $code ]);
} else {
DatabaseConnection :: i () -> getContext ()
-> table ( " number_verification " )
-> insert ([ " user " => $this -> getId (), " number " => $phone , " code " => $code ]);
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return ( string ) $code ;
}
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
# KABOBSQL temporary fix
# Tuesday, the 7th of January 2020 @ 22:43 <Menhera>: implementing quick fix to this problem and monitoring
# NOTICE: this is an ongoing conversation, add your comments just above this line. Thanks!
function setOnline ( int $time ) : bool
{
$this -> stateChanges ( " shortcode " , $this -> getRecord () -> shortcode ); #fix KABOBSQL
$this -> stateChanges ( " online " , $time );
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return true ;
}
2022-04-12 20:10:35 +03:00
2023-03-13 17:46:54 +03:00
function updOnline ( string $platform ) : bool
{
$this -> setOnline ( time ());
$this -> setClient_name ( $platform );
2023-08-11 16:43:39 +03:00
$this -> save ( false );
2023-03-13 17:46:54 +03:00
return true ;
}
2022-05-07 16:00:25 +03:00
function changeEmail ( string $email ) : void
2022-05-06 17:17:08 +03:00
{
DatabaseConnection :: i () -> getContext () -> table ( " ChandlerUsers " )
-> where ( " id " , $this -> getChandlerUser () -> getId ()) -> update ([
" login " => $email
]);
$this -> stateChanges ( " email " , $email );
$this -> save ();
}
2020-06-07 19:04:43 +03:00
function adminNotify ( string $message ) : bool
{
2023-08-11 16:43:39 +03:00
$admId = ( int ) OPENVK_ROOT_CONF [ " openvk " ][ " preferences " ][ " support " ][ " adminAccount " ];
2020-06-07 19:04:43 +03:00
if ( ! $admId )
return false ;
else if ( is_null ( $admin = ( new Users ) -> get ( $admId )))
return false ;
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
$cor = new Correspondence ( $admin , $this );
$msg = new Message ;
$msg -> setContent ( $message );
$cor -> sendMessage ( $msg , true );
2022-04-12 20:10:35 +03:00
2020-06-07 19:04:43 +03:00
return true ;
}
function isDeleted () : bool
{
2022-08-05 23:29:31 +03:00
if ( $this -> getRecord () -> deleted == 1 )
2022-01-31 14:45:53 +03:00
return TRUE ;
else
return FALSE ;
2020-06-07 19:04:43 +03:00
}
2022-08-05 23:00:52 +03:00
function isDeactivated () : bool
{
2022-08-05 23:29:31 +03:00
if ( $this -> getDeactivationDate () -> timestamp () > time ())
2022-08-05 23:00:52 +03:00
return TRUE ;
else
return FALSE ;
}
2021-09-11 01:33:45 +03:00
/**
* 0 - Default status
* 1 - Incognito online status
* 2 - Page of a dead person
*/
function onlineStatus () : int
{
switch ( $this -> getRecord () -> online ) {
case 1 :
return 1 ;
break ;
case 2 :
return 2 ;
break ;
2022-04-12 20:10:35 +03:00
2021-09-11 01:33:45 +03:00
default :
return 0 ;
break ;
}
}
2021-11-13 15:13:44 +03:00
function getWebsite () : ? string
{
return $this -> getRecord () -> website ;
}
2022-01-31 14:45:53 +03:00
2022-05-08 13:06:26 +03:00
# ты устрица
2022-01-31 14:45:53 +03:00
function isActivated () : bool
{
return ( bool ) $this -> getRecord () -> activated ;
}
2022-09-05 11:16:22 +03:00
function getUnbanTime () : ? string
{
2023-08-11 16:50:19 +03:00
$ban = ( new Bans ) -> get (( int ) $this -> getRecord () -> block_reason );
if ( ! $ban || $ban -> isOver () || $ban -> isPermanent ()) return null ;
if ( $this -> canUnbanThemself ()) return tr ( " today " );
return date ( 'd.m.Y' , $ban -> getEndTime ());
2022-09-05 11:16:22 +03:00
}
function canUnbanThemself () : bool
{
if ( ! $this -> isBanned ())
return false ;
2023-08-11 16:50:19 +03:00
$ban = ( new Bans ) -> get (( int ) $this -> getRecord () -> block_reason );
if ( ! $ban || $ban -> isOver () || $ban -> isPermanent ()) return false ;
2022-09-05 11:16:22 +03:00
2023-08-11 16:50:19 +03:00
return $ban -> getEndTime () <= time () && ! $ban -> isPermanent ();
}
function getNewBanTime ()
{
$bans = iterator_to_array (( new Bans ) -> getByUser ( $this -> getid ()));
if ( ! $bans || count ( $bans ) === 0 )
return 0 ;
$last_ban = end ( $bans );
if ( ! $last_ban ) return 0 ;
if ( $last_ban -> isPermanent ()) return " permanent " ;
$values = [ 0 , 3600 , 7200 , 86400 , 172800 , 604800 , 1209600 , 3024000 , 9072000 ];
$response = 0 ;
$i = 0 ;
foreach ( $values as $value ) {
$i ++ ;
if ( $last_ban -> getTime () === 0 && $value === 0 ) continue ;
if ( $last_ban -> getTime () < $value ) {
$response = $value ;
break ;
} else if ( $last_ban -> getTime () >= $value ) {
if ( $i < count ( $values )) continue ;
$response = " permanent " ;
break ;
}
}
return $response ;
2022-09-05 11:16:22 +03:00
}
VKAPI: методы для подарков, заметок, статусов, обсуждений и немного для фоток и групп (#876)
* API methods for gifts, notes, statuses
* Some fixes
Строки локализации у gifts.send теперь не костыльные и можно прикрепить до 10 аттачей к посту
* Small imp
Пофиксил пагинацию у заметков и подарок
Перенёс структуру заметок
Добавил аттачи к комментариям
Добавил проверку на удалённость аттача
Ну и пофиксил сортировку заметок
* VKAPI: Some methods for topics and photos
Добавлены методы для обсуждений (addTopic, closeTopic(), createComment(), deleteComment(), deleteTopic(), editTopic(), fixTopic(), getComments(), getTopics(), openTopic(), unfixTopic())
и для фотографий (createAlbum(), editAlbum(), getAlbums(), getAlbumsCount(), getById(), get(), deleteAlbum(), edit(), delete(), deleteComment(), createComment(), getAll(), getComments())
* fixsex
2023-06-13 21:03:43 +03:00
function toVkApiStruct () : object
{
$res = ( object ) [];
$res -> id = $this -> getId ();
$res -> first_name = $this -> getFirstName ();
$res -> last_name = $this -> getLastName ();
$res -> deactivated = $this -> isDeactivated ();
$res -> photo_50 = $this -> getAvatarURL ();
$res -> photo_100 = $this -> getAvatarURL ( " tiny " );
$res -> photo_200 = $this -> getAvatarURL ( " normal " );
$res -> photo_id = ! is_null ( $this -> getAvatarPhoto ()) ? $this -> getAvatarPhoto () -> getPrettyId () : NULL ;
# TODO: Perenesti syuda vsyo ostalnoyie
return $res ;
}
2023-09-26 14:17:59 +03:00
function getRealId ()
{
return $this -> getId ();
}
function getIgnoredSources ( int $page = 1 , int $perPage = 10 , bool $onlyIds = false )
{
$sources = DatabaseConnection :: i () -> getContext () -> table ( " ignored_sources " ) -> where ( " owner " , $this -> getId ()) -> page ( $page , $perPage );
$arr = [];
foreach ( $sources as $source ) {
$ignoredSource = ( int ) $source -> ignored_source ;
if ( $ignoredSource > 0 )
$ignoredSourceModel = ( new Users ) -> get ( $ignoredSource );
else
$ignoredSourceModel = ( new Clubs ) -> get ( abs ( $ignoredSource ));
if ( ! $ignoredSourceModel )
continue ;
if ( ! $onlyIds )
$arr [] = $ignoredSourceModel ;
else
$arr [] = $ignoredSourceModel -> getRealId ();
}
return $arr ;
}
function getIgnoredSourcesCount ()
{
return sizeof ( DatabaseConnection :: i () -> getContext () -> table ( " ignored_sources " ) -> where ( " owner " , $this -> getId ()));
}
function isIgnoredBy ( User $user ) : bool
{
$ctx = DatabaseConnection :: i () -> getContext ();
$data = [
" owner " => $user -> getId (),
" ignored_source " => $this -> getId (),
];
$sub = $ctx -> table ( " ignored_sources " ) -> where ( $data );
if ( ! $sub -> fetch ()) {
return false ;
}
return true ;
}
function getUsersIgnoredCount ()
{
return sizeof ( DatabaseConnection :: i () -> getContext () -> table ( " ignored_sources " ) -> where ( " ignored_source " , $this -> getId ()));
}
2020-06-07 19:04:43 +03:00
2022-12-12 02:23:42 +03:00
use Traits\TBackDrops ;
2020-06-07 19:04:43 +03:00
use Traits\TSubscribable ;
}