2019-05-02 00:01:43 -04:00
< ? php
namespace Friendica\Module\Admin ;
use Friendica\Content\Pager ;
use Friendica\Core\Renderer ;
use Friendica\Database\DBA ;
2019-12-15 16:34:11 -05:00
use Friendica\DI ;
2019-05-02 00:01:43 -04:00
use Friendica\Model\Register ;
use Friendica\Model\User ;
2020-01-22 23:14:14 -05:00
use Friendica\Module\BaseAdmin ;
2019-05-02 00:01:43 -04:00
use Friendica\Util\Strings ;
use Friendica\Util\Temporal ;
2020-01-22 23:14:14 -05:00
class Users extends BaseAdmin
2019-05-02 00:01:43 -04:00
{
2019-11-05 16:48:54 -05:00
public static function post ( array $parameters = [])
2019-05-02 00:01:43 -04:00
{
2019-11-05 15:22:54 -05:00
parent :: post ( $parameters );
2019-05-02 00:01:43 -04:00
2019-10-15 09:20:32 -04:00
$pending = $_POST [ 'pending' ] ? ? [];
$users = $_POST [ 'user' ] ? ? [];
$nu_name = $_POST [ 'new_user_name' ] ? ? '' ;
$nu_nickname = $_POST [ 'new_user_nickname' ] ? ? '' ;
$nu_email = $_POST [ 'new_user_email' ] ? ? '' ;
2020-01-19 15:21:13 -05:00
$nu_language = DI :: config () -> get ( 'system' , 'language' );
2019-05-02 00:01:43 -04:00
parent :: checkFormSecurityTokenRedirectOnError ( '/admin/users' , 'admin_users' );
if ( $nu_name !== '' && $nu_email !== '' && $nu_nickname !== '' ) {
try {
$result = User :: create ([
'username' => $nu_name ,
'email' => $nu_email ,
'nickname' => $nu_nickname ,
'verified' => 1 ,
'language' => $nu_language
]);
} catch ( \Exception $ex ) {
notice ( $ex -> getMessage ());
return ;
}
$user = $result [ 'user' ];
2020-01-18 14:52:34 -05:00
$preamble = Strings :: deindent ( DI :: l10n () -> t ( '
2019-05-02 00:01:43 -04:00
Dear % 1 $s ,
the administrator of % 2 $s has set up an account for you . ' ));
2020-01-18 14:52:34 -05:00
$body = Strings :: deindent ( DI :: l10n () -> t ( '
2019-05-02 00:01:43 -04:00
The login details are as follows :
Site Location : % 1 $s
Login Name : % 2 $s
Password : % 3 $s
You may change your password from your account " Settings " page after logging
in .
Please take a few moments to review the other account settings on that page .
You may also wish to add some basic information to your default profile
( on the " Profiles " page ) so that other people can easily find you .
We recommend setting your full name , adding a profile photo ,
adding some profile " keywords " ( very useful in making new friends ) - and
perhaps what country you live in ; if you do not wish to be more specific
than that .
We fully respect your right to privacy , and none of these items are necessary .
If you are new and do not know anybody here , they may help
you to make some new and interesting friends .
If you ever want to delete your account , you can do so at % 1 $s / removeme
Thank you and welcome to % 4 $s . ' ));
2020-01-19 15:21:13 -05:00
$preamble = sprintf ( $preamble , $user [ 'username' ], DI :: config () -> get ( 'config' , 'sitename' ));
$body = sprintf ( $body , DI :: baseUrl () -> get (), $user [ 'nickname' ], $result [ 'password' ], DI :: config () -> get ( 'config' , 'sitename' ));
2019-05-02 00:01:43 -04:00
2020-02-01 14:08:54 -05:00
$email = DI :: emailer ()
-> newSystemMail (( ! empty ( $user [ 'language' ])) ? DI :: l10n () -> withLang ( $user [ 'language' ]) : DI :: l10n ())
-> withMessage ( DI :: l10n () -> t ( 'Registration details for %s' , DI :: config () -> get ( 'config' , 'sitename' )), $preamble , $body )
-> forUser ( $user [ 'uid' ] ? ? 0 )
-> withRecipient ( $user [ 'email' ])
-> build ();
return DI :: emailer () -> send ( $email );
2019-05-02 00:01:43 -04:00
}
if ( ! empty ( $_POST [ 'page_users_block' ])) {
2019-05-02 10:20:02 -04:00
// @TODO Move this to Model\User:block($users);
2019-05-02 00:01:43 -04:00
DBA :: update ( 'user' , [ 'blocked' => 1 ], [ 'uid' => $users ]);
2020-01-18 14:53:01 -05:00
notice ( DI :: l10n () -> tt ( '%s user blocked' , '%s users blocked' , count ( $users )));
2019-05-02 00:01:43 -04:00
}
if ( ! empty ( $_POST [ 'page_users_unblock' ])) {
2019-05-02 10:20:02 -04:00
// @TODO Move this to Model\User:unblock($users);
2019-05-02 00:01:43 -04:00
DBA :: update ( 'user' , [ 'blocked' => 0 ], [ 'uid' => $users ]);
2020-01-18 14:53:01 -05:00
notice ( DI :: l10n () -> tt ( '%s user unblocked' , '%s users unblocked' , count ( $users )));
2019-05-02 00:01:43 -04:00
}
if ( ! empty ( $_POST [ 'page_users_delete' ])) {
foreach ( $users as $uid ) {
if ( local_user () != $uid ) {
User :: remove ( $uid );
} else {
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'You can\'t remove yourself' ));
2019-05-02 00:01:43 -04:00
}
}
2020-01-18 14:53:01 -05:00
notice ( DI :: l10n () -> tt ( '%s user deleted' , '%s users deleted' , count ( $users )));
2019-05-02 00:01:43 -04:00
}
if ( ! empty ( $_POST [ 'page_users_approve' ])) {
require_once 'mod/regmod.php' ;
foreach ( $pending as $hash ) {
user_allow ( $hash );
}
}
if ( ! empty ( $_POST [ 'page_users_deny' ])) {
require_once 'mod/regmod.php' ;
foreach ( $pending as $hash ) {
user_deny ( $hash );
}
}
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( 'admin/users' );
2019-05-02 00:01:43 -04:00
}
2019-11-05 16:48:54 -05:00
public static function content ( array $parameters = [])
2019-05-02 00:01:43 -04:00
{
2019-11-05 15:22:54 -05:00
parent :: content ( $parameters );
2019-05-02 00:01:43 -04:00
2019-12-15 16:34:11 -05:00
$a = DI :: app ();
2019-05-02 00:01:43 -04:00
if ( $a -> argc > 3 ) {
// @TODO: Replace with parameter from router
$action = $a -> argv [ 2 ];
$uid = $a -> argv [ 3 ];
2019-05-02 10:20:02 -04:00
$user = User :: getById ( $uid , [ 'username' , 'blocked' ]);
2019-05-02 00:01:43 -04:00
if ( ! DBA :: isResult ( $user )) {
notice ( 'User not found' . EOL );
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( 'admin/users' );
2019-05-02 00:01:43 -04:00
return '' ; // NOTREACHED
}
switch ( $action ) {
case 'delete' :
if ( local_user () != $uid ) {
parent :: checkFormSecurityTokenRedirectOnError ( '/admin/users' , 'admin_users' , 't' );
// delete user
User :: remove ( $uid );
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'User "%s" deleted' , $user [ 'username' ]));
2019-05-02 00:01:43 -04:00
} else {
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'You can\'t remove yourself' ));
2019-05-02 00:01:43 -04:00
}
break ;
case 'block' :
parent :: checkFormSecurityTokenRedirectOnError ( '/admin/users' , 'admin_users' , 't' );
2019-05-02 10:20:02 -04:00
// @TODO Move this to Model\User:block([$uid]);
2019-05-02 00:01:43 -04:00
DBA :: update ( 'user' , [ 'blocked' => 1 ], [ 'uid' => $uid ]);
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'User "%s" blocked' , $user [ 'username' ]));
2019-05-02 00:01:43 -04:00
break ;
case 'unblock' :
parent :: checkFormSecurityTokenRedirectOnError ( '/admin/users' , 'admin_users' , 't' );
2019-05-02 10:20:02 -04:00
// @TODO Move this to Model\User:unblock([$uid]);
2019-05-02 00:01:43 -04:00
DBA :: update ( 'user' , [ 'blocked' => 0 ], [ 'uid' => $uid ]);
2020-01-18 14:52:34 -05:00
notice ( DI :: l10n () -> t ( 'User "%s" unblocked' , $user [ 'username' ]));
2019-05-02 00:01:43 -04:00
break ;
}
2019-12-15 18:28:31 -05:00
DI :: baseUrl () -> redirect ( 'admin/users' );
2019-05-02 00:01:43 -04:00
}
/* get pending */
$pending = Register :: getPending ();
2019-12-15 19:30:34 -05:00
$pager = new Pager ( DI :: args () -> getQueryString (), 100 );
2019-05-02 00:01:43 -04:00
2019-05-02 10:20:02 -04:00
// @TODO Move below block to Model\User::getUsers($start, $count, $order = 'contact.name', $order_direction = '+')
2019-05-02 00:01:43 -04:00
$valid_orders = [
'contact.name' ,
'user.email' ,
'user.register_date' ,
'user.login_date' ,
'lastitem_date' ,
'user.page-flags'
];
$order = 'contact.name' ;
$order_direction = '+' ;
if ( ! empty ( $_GET [ 'o' ])) {
$new_order = $_GET [ 'o' ];
if ( $new_order [ 0 ] === '-' ) {
$order_direction = '-' ;
$new_order = substr ( $new_order , 1 );
}
if ( in_array ( $new_order , $valid_orders )) {
$order = $new_order ;
}
}
$sql_order = '`' . str_replace ( '.' , '`.`' , $order ) . '`' ;
$sql_order_direction = ( $order_direction === '+' ) ? 'ASC' : 'DESC' ;
$usersStmt = DBA :: p ( " SELECT `user`.*, `contact`.`name`, `contact`.`url`, `contact`.`micro`, `user`.`account_expired`, `contact`.`last-item` AS `lastitem_date`
FROM `user`
INNER JOIN `contact` ON `contact` . `uid` = `user` . `uid` AND `contact` . `self`
WHERE `user` . `verified`
ORDER BY $sql_order $sql_order_direction LIMIT ? , ? " , $pager->getStart (), $pager->getItemsPerPage ()
);
$users = DBA :: toArray ( $usersStmt );
2020-01-19 15:21:13 -05:00
$adminlist = explode ( ',' , str_replace ( ' ' , '' , DI :: config () -> get ( 'config' , 'admin_email' )));
2019-05-02 00:01:43 -04:00
$_setup_users = function ( $e ) use ( $adminlist ) {
$page_types = [
2020-01-18 14:52:34 -05:00
User :: PAGE_FLAGS_NORMAL => DI :: l10n () -> t ( 'Normal Account Page' ),
User :: PAGE_FLAGS_SOAPBOX => DI :: l10n () -> t ( 'Soapbox Page' ),
User :: PAGE_FLAGS_COMMUNITY => DI :: l10n () -> t ( 'Public Forum' ),
User :: PAGE_FLAGS_FREELOVE => DI :: l10n () -> t ( 'Automatic Friend Page' ),
User :: PAGE_FLAGS_PRVGROUP => DI :: l10n () -> t ( 'Private Forum' )
2019-05-02 00:01:43 -04:00
];
$account_types = [
2020-01-18 14:52:34 -05:00
User :: ACCOUNT_TYPE_PERSON => DI :: l10n () -> t ( 'Personal Page' ),
User :: ACCOUNT_TYPE_ORGANISATION => DI :: l10n () -> t ( 'Organisation Page' ),
User :: ACCOUNT_TYPE_NEWS => DI :: l10n () -> t ( 'News Page' ),
User :: ACCOUNT_TYPE_COMMUNITY => DI :: l10n () -> t ( 'Community Forum' ),
User :: ACCOUNT_TYPE_RELAY => DI :: l10n () -> t ( 'Relay' ),
2019-05-02 00:01:43 -04:00
];
$e [ 'page_flags_raw' ] = $e [ 'page-flags' ];
$e [ 'page-flags' ] = $page_types [ $e [ 'page-flags' ]];
$e [ 'account_type_raw' ] = ( $e [ 'page_flags_raw' ] == 0 ) ? $e [ 'account-type' ] : - 1 ;
$e [ 'account-type' ] = ( $e [ 'page_flags_raw' ] == 0 ) ? $account_types [ $e [ 'account-type' ]] : '' ;
$e [ 'register_date' ] = Temporal :: getRelativeDate ( $e [ 'register_date' ]);
$e [ 'login_date' ] = Temporal :: getRelativeDate ( $e [ 'login_date' ]);
$e [ 'lastitem_date' ] = Temporal :: getRelativeDate ( $e [ 'lastitem_date' ]);
$e [ 'is_admin' ] = in_array ( $e [ 'email' ], $adminlist );
$e [ 'is_deletable' ] = ( intval ( $e [ 'uid' ]) != local_user ());
$e [ 'deleted' ] = ( $e [ 'account_removed' ] ? Temporal :: getRelativeDate ( $e [ 'account_expires_on' ]) : False );
return $e ;
};
$tmp_users = array_map ( $_setup_users , $users );
// Get rid of dashes in key names, Smarty3 can't handle them
// and extracting deleted users
$deleted = [];
$users = [];
foreach ( $tmp_users as $user ) {
foreach ( $user as $k => $v ) {
$newkey = str_replace ( '-' , '_' , $k );
$user [ $newkey ] = $v ;
}
if ( $user [ 'deleted' ]) {
$deleted [] = $user ;
} else {
$users [] = $user ;
}
}
2020-01-18 14:52:34 -05:00
$th_users = array_map ( null , [ DI :: l10n () -> t ( 'Name' ), DI :: l10n () -> t ( 'Email' ), DI :: l10n () -> t ( 'Register date' ), DI :: l10n () -> t ( 'Last login' ), DI :: l10n () -> t ( 'Last item' ), DI :: l10n () -> t ( 'Type' )], $valid_orders );
2019-05-02 00:01:43 -04:00
$t = Renderer :: getMarkupTemplate ( 'admin/users.tpl' );
$o = Renderer :: replaceMacros ( $t , [
// strings //
2020-01-18 14:52:34 -05:00
'$title' => DI :: l10n () -> t ( 'Administration' ),
'$page' => DI :: l10n () -> t ( 'Users' ),
'$submit' => DI :: l10n () -> t ( 'Add User' ),
'$select_all' => DI :: l10n () -> t ( 'select all' ),
'$h_pending' => DI :: l10n () -> t ( 'User registrations waiting for confirm' ),
'$h_deleted' => DI :: l10n () -> t ( 'User waiting for permanent deletion' ),
'$th_pending' => [ DI :: l10n () -> t ( 'Request date' ), DI :: l10n () -> t ( 'Name' ), DI :: l10n () -> t ( 'Email' )],
'$no_pending' => DI :: l10n () -> t ( 'No registrations.' ),
'$pendingnotetext' => DI :: l10n () -> t ( 'Note from the user' ),
'$approve' => DI :: l10n () -> t ( 'Approve' ),
'$deny' => DI :: l10n () -> t ( 'Deny' ),
'$delete' => DI :: l10n () -> t ( 'Delete' ),
'$block' => DI :: l10n () -> t ( 'Block' ),
'$blocked' => DI :: l10n () -> t ( 'User blocked' ),
'$unblock' => DI :: l10n () -> t ( 'Unblock' ),
'$siteadmin' => DI :: l10n () -> t ( 'Site admin' ),
'$accountexpired' => DI :: l10n () -> t ( 'Account expired' ),
'$h_users' => DI :: l10n () -> t ( 'Users' ),
'$h_newuser' => DI :: l10n () -> t ( 'New User' ),
'$th_deleted' => [ DI :: l10n () -> t ( 'Name' ), DI :: l10n () -> t ( 'Email' ), DI :: l10n () -> t ( 'Register date' ), DI :: l10n () -> t ( 'Last login' ), DI :: l10n () -> t ( 'Last item' ), DI :: l10n () -> t ( 'Permanent deletion' )],
2019-05-02 00:01:43 -04:00
'$th_users' => $th_users ,
'$order_users' => $order ,
'$order_direction_users' => $order_direction ,
2020-01-18 14:52:34 -05:00
'$confirm_delete_multi' => DI :: l10n () -> t ( 'Selected users will be deleted!\n\nEverything these users had posted on this site will be permanently deleted!\n\nAre you sure?' ),
'$confirm_delete' => DI :: l10n () -> t ( 'The user {0} will be deleted!\n\nEverything this user has posted on this site will be permanently deleted!\n\nAre you sure?' ),
2019-05-02 00:01:43 -04:00
'$form_security_token' => parent :: getFormSecurityToken ( 'admin_users' ),
// values //
2019-12-15 19:05:15 -05:00
'$baseurl' => DI :: baseUrl () -> get ( true ),
2019-05-02 00:01:43 -04:00
'$pending' => $pending ,
'deleted' => $deleted ,
'$users' => $users ,
2020-01-18 14:52:34 -05:00
'$newusername' => [ 'new_user_name' , DI :: l10n () -> t ( 'Name' ), '' , DI :: l10n () -> t ( 'Name of the new user.' )],
'$newusernickname' => [ 'new_user_nickname' , DI :: l10n () -> t ( 'Nickname' ), '' , DI :: l10n () -> t ( 'Nickname of the new user.' )],
'$newuseremail' => [ 'new_user_email' , DI :: l10n () -> t ( 'Email' ), '' , DI :: l10n () -> t ( 'Email address of the new user.' ), '' , '' , 'email' ],
2019-05-02 00:01:43 -04:00
]);
$o .= $pager -> renderFull ( DBA :: count ( 'user' ));
return $o ;
}
}