<?php
/**
* @brief MemberHistory: Core
* @author <a href='https://www.invisioncommunity.com'>Invision Power Services, Inc.</a>
* @copyright (c) Invision Power Services, Inc.
* @license https://www.invisioncommunity.com/legal/standards/
* @package Invision Community
* @since 24 Jan 2017
*/
namespace IPS\core\extensions\core\MemberHistory;
/* To prevent PHP errors (extending class does not exist) revealing path */
if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) )
{
header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' );
exit;
}
/**
* Member History: Core
*/
class _Core
{
/**
* Return the valid member history log types
*
* @return array
*/
public function getTypes()
{
return array(
'photo',
'coverphoto',
'groups',
'login',
'password_change',
'display_name',
'email_change',
'social_account',
'account',
'warning',
'mfa',
'terms_acceptance'
);
}
/**
* Parse LogData column
*
* @param string $value column value
* @param array $row entire log row
* @return string
*/
public function parseLogData( $value, $row )
{
$jsonValue = json_decode( $value, TRUE );
$byMember = '';
$byStaff = '';
if ( $row['log_by'] )
{
if ( $row['log_by'] === $row['log_member'] )
{
$byMember = \IPS\Member::loggedIn()->language()->addToStack('history_by_member');
}
$byStaff = \IPS\Member::loggedIn()->language()->addToStack('history_by_admin', FALSE, array( 'sprintf' => array( \IPS\Member::load( $row['log_by'] )->name ) ) );
}
switch( $row['log_type'] )
{
case 'photo':
if ( $jsonValue['action'] === 'new' )
{
if ( $jsonValue['type'] === 'gallery' )
{
try
{
$image = \IPS\gallery\Image::load( $jsonValue['id'] );
$link = \IPS\Theme::i()->getTemplate( 'global', 'core', 'global' )->basicUrl( $image->url(), TRUE, \IPS\Member::loggedIn()->language()->addToStack('history_new_photo_gallery_link'), FALSE );
}
catch ( \OutOfRangeException $e )
{
$link = \IPS\Member::loggedIn()->language()->addToStack('history_new_photo_gallery_link');
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_new_photo_gallery', FALSE, array( 'htmlsprintf' => array( $link, $byMember ?: $byStaff ) ) );
}
elseif ( $jsonValue['type'] === 'profilesync' )
{
try
{
$method = \IPS\Login\Handler::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$method = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_new_photo_profilesync', FALSE, array( 'sprintf' => array( $method ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_new_photo_' . $jsonValue['type'], FALSE, array( 'sprintf' => array( $byMember ?: $byStaff ) ) );
}
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_photo_' . $jsonValue['action'], FALSE, array( 'sprintf' => array( $byMember ?: $byStaff ) ) );
}
break;
case 'coverphoto':
if ( isset( $jsonValue['type'] ) and $jsonValue['type'] == 'profilesync' )
{
try
{
$method = \IPS\Login\Handler::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$method = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_cover_photo_profilesync', FALSE, array( 'sprintf' => array( $method ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_cover_photo_' . $jsonValue['action'], FALSE, array( 'sprintf' => array( $byMember ?: $byStaff ) ) );
}
break;
case 'group':
if ( $jsonValue['by'] == 'legacy' )
{
$jsonValue['new'] = explode( ',', $jsonValue['data']['new'] );
$jsonValue['old'] = array();
}
foreach ( array( 'old', 'new' ) as $k )
{
$$k = array();
foreach ( is_array( $jsonValue[ $k ] ) ? $jsonValue[ $k ] : array( $jsonValue[ $k ] ) as $id )
{
try
{
${$k}[] = \IPS\Theme::i()->getTemplate( 'members', 'core' )->groupLink( \IPS\Member\Group::load( $id ) );
}
catch ( \OutOfRangeException $e )
{
${$k}[] = \IPS\Member::loggedIn()->language()->addToStack( 'history_deleted_group_id', FALSE, array( 'sprintf' => array( $id ) ) );
}
}
if ( $$k )
{
$$k = \IPS\Member::loggedIn()->language()->formatList( $$k );
}
else
{
$$k = \IPS\Member::loggedIn()->language()->addToStack('history_no_groups');
}
}
switch ( $jsonValue['by'] )
{
case 'subscription':
try
{
$subs = \IPS\nexus\Subscription\Package::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$subs = '';
}
switch ( $jsonValue['action'] )
{
case 'add':
case 'remove':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_subscription_' . $jsonValue['action'], FALSE, array( 'htmlsprintf' => array( $subs, $old, $new ) ) );
}
case 'purchase':
try
{
$purchase = \IPS\Theme::i()->getTemplate('purchases', 'nexus')->link( \IPS\nexus\Purchase::load( $jsonValue['id'] ) );
}
catch ( \OutOfRangeException $e )
{
$purchase = $val['name'];
}
$type = \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_purchase_' . $jsonValue['type'] );
switch ( $jsonValue['action'] )
{
case 'add':
case 'remove':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_purchase_' . $jsonValue['action'], FALSE, array( 'htmlsprintf' => array( $purchase, $type, $old, $new ) ) );
case 'change':
try
{
$expiringPurchase = \IPS\Theme::i()->getTemplate('purchases', 'nexus')->link( \IPS\nexus\Purchase::load( $jsonValue['remove_id'] ), TRUE );
}
catch ( \OutOfRangeException $e )
{
$expiringPurchase = $val['remove_name'];
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_purchase_' . $jsonValue['action'], FALSE, array( 'htmlsprintf' => array( $expiringPurchase, $purchase, $type, $old, $new ) ) );
}
case 'manual':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_' . $jsonValue['type'], FALSE, array( 'htmlsprintf' => array( $old, $new ), 'sprintf' => array( $byStaff ) ) );
case 'mass':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_mass', FALSE, array( 'htmlsprintf' => array( $old, $new ), 'sprintf' => array( $byStaff ) ) );
case 'api':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_api_' . $jsonValue['type'], FALSE, array( 'htmlsprintf' => array( $old, $new ) ) );
case 'promotion':
try
{
$rule = \IPS\Member\GroupPromotion::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$rule = '#' . $jsonValue['id'];
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_change_promotion_' . $jsonValue['type'], FALSE, array( 'htmlsprintf' => array( $old, $new ), 'sprintf' => array( $rule ) ) );
case 'legacy':
if ( in_array( $jsonValue['type'], array( 'group_promotion', 'group_promotion_o' ) ) )
{
try
{
$rule = \IPS\Member\GroupPromotion::load( $jsonValue['data']['reason'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$rule = '#' . $jsonValue['id'];
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_legacy_' . $jsonValue['type'], FALSE, array( 'htmlsprintf' => array( $new ), 'sprintf' => array( $rule ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_group_legacy_' . $jsonValue['type'], FALSE, array( 'htmlsprintf' => array( $new ) ) );
}
}
break;
case 'login':
switch ( $jsonValue['type'] )
{
case 'new_device':
case 'logout':
try
{
$device = \IPS\Theme::i()->getTemplate( 'global', 'core', 'global' )->basicUrl( \IPS\Http\Url::internal("app=core&module=members&controller=devices&do=device&key={$jsonValue['device']}&member={$row['log_member']}"), FALSE, (string) \IPS\Member\Device::load( $jsonValue['device'] )->userAgent(), FALSE );
}
catch ( \Exception $e )
{
$device = htmlspecialchars( $jsonValue['device'], ENT_QUOTES | ENT_DISALLOWED, 'UTF-8', FALSE );
}
if ( $jsonValue['type'] == 'new_device' )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_new_device', FALSE, array( 'htmlsprintf' => array( $device ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_device_logout', FALSE, array( 'htmlsprintf' => array( $device, $byMember ?: $byStaff ) ) );
}
case 'lock':
if ( isset( $jsonValue['unlockTime'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_locked_time', FALSE, array( 'htmlsprintf' => array( \IPS\DateTime::ts( $jsonValue['unlockTime'] ), $jsonValue['count'] ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_locked', FALSE, array( 'htmlsprintf' => array( $jsonValue['count'] ) ) );
}
case 'mfalock':
if ( isset( $jsonValue['unlockTime'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_mfa_locked_time', FALSE, array( 'htmlsprintf' => array( \IPS\DateTime::ts( $jsonValue['unlockTime'] ), $jsonValue['count'] ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_mfa_locked', FALSE, array( 'htmlsprintf' => array( $jsonValue['count'] ) ) );
}
case 'unlock':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_unlocked', FALSE, array( 'htmlsprintf' => array( $byStaff ) ) );
}
break;
case 'password_change':
switch ( $jsonValue )
{
case 'lost':
return \IPS\Member::loggedIn()->language()->addToStack('history_password_changed_lost');
case 'api':
return \IPS\Member::loggedIn()->language()->addToStack('history_password_changed_api');
default:
return \IPS\Member::loggedIn()->language()->addToStack( 'history_password_changed', FALSE, array( 'sprintf' => array( $byMember ?: $byStaff ) ) );
}
break;
case 'display_name':
$oldDisplayName = $jsonValue['old'] ?: \IPS\Member::loggedIn()->language()->addToStack('history_unknown'); // Old display name records may be missing this
switch ( isset( $jsonValue['by'] ) ? $jsonValue['by'] : NULL )
{
case 'manual':
return \IPS\Member::loggedIn()->language()->addToStack('history_name_changed_manual', FALSE, array( 'sprintf' => array( $jsonValue['new'], $oldDisplayName, $byMember ?: $byStaff ) ) );
case 'api':
return \IPS\Member::loggedIn()->language()->addToStack('history_name_changed_api', FALSE, array( 'sprintf' => array( $jsonValue['new'], $oldDisplayName ) ) );
case 'profilesync':
try
{
$method = \IPS\Login\Handler::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$method = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
return \IPS\Member::loggedIn()->language()->addToStack('history_name_changed_profilesync', FALSE, array( 'sprintf' => array( $jsonValue['new'], $oldDisplayName, $method ) ) );
default:
return \IPS\Member::loggedIn()->language()->addToStack('history_name_changed', FALSE, array( 'sprintf' => array( $jsonValue['new'], $oldDisplayName ) ) );
}
break;
case 'email_change':
$newEmailAddress = $jsonValue['new'] ?: \IPS\Member::loggedIn()->language()->addToStack('history_unknown'); // Previous customer history didn't log what it was changed to
switch ( isset( $jsonValue['by'] ) ? $jsonValue['by'] : NULL )
{
case 'manual':
return \IPS\Member::loggedIn()->language()->addToStack('history_email_changed_manual', FALSE, array( 'sprintf' => array( $newEmailAddress, $jsonValue['old'], $byMember ?: $byStaff ) ) );
case 'api':
return \IPS\Member::loggedIn()->language()->addToStack('history_email_changed_api', FALSE, array( 'sprintf' => array( $newEmailAddress, $jsonValue['old'] ) ) );
case 'profilesync':
try
{
$method = \IPS\Login\Handler::load( $jsonValue['id'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$method = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
return \IPS\Member::loggedIn()->language()->addToStack('history_email_changed_profilesync', FALSE, array( 'sprintf' => array( $newEmailAddress, $jsonValue['old'], $method ) ) );
default:
return \IPS\Member::loggedIn()->language()->addToStack('history_email_changed', FALSE, array( 'sprintf' => array( $newEmailAddress, $jsonValue['old'] ) ) );
}
break;
case 'social_account':
$handler = NULL;
if ( isset( $jsonValue['handler'] ) )
{
try
{
$handler = \IPS\Login\Handler::load( $jsonValue['handler'] );
$handlerName = $handler->_title;
}
catch ( \OutOfRangeException $e )
{
$handlerName = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
}
else
{
$handlerName = \IPS\Member::loggedIn()->language()->addToStack( 'login_handler_' . mb_ucfirst( $jsonValue['service'] ) );
}
if ( isset( $jsonValue['changed'] ) )
{
$changes = array();
foreach ( $jsonValue['changed'] as $k => $v )
{
$changes[] = \IPS\Member::loggedIn()->language()->addToStack( 'history_social_sync_changed_' . $k, FALSE, array( 'sprintf' => array( \IPS\Member::loggedIn()->language()->addToStack( $v ? 'history_social_sync_enabled' : 'history_social_sync_disabled' ) ) ) );
}
return \IPS\Member::loggedIn()->language()->addToStack('history_social_sync_changes', FALSE, array( 'sprintf' => array( $handlerName, $byMember ?: $byStaff, implode( '; ', $changes ) ) ) );
}
$account = NULL;
$link = NULL;
if ( $handler and ( isset( $jsonValue['account_id'] ) or isset( $jsonValue['account_name'] ) ) )
{
$account = $jsonValue['account_name'];
if ( $link = $handler->userLink( $jsonValue['account_id'], $jsonValue['account_name'] ) )
{
$link = (string) $link->makeSafeForAcp();
}
}
if( isset( $jsonValue['registered'] ) or $jsonValue['linked'] === TRUE )
{
$type = 'connected';
}
else
{
$type = 'disconnected';
}
if ( $account )
{
if ( $link )
{
return \IPS\Member::loggedIn()->language()->addToStack('history_'.$type.'_social_with_link', FALSE, array( 'sprintf' => array( $handlerName, $link, $account, $byMember ?: $byStaff ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack('history_'.$type.'_social_with_account', FALSE, array( 'sprintf' => array( $handlerName, $account, $byMember ?: $byStaff ) ) );
}
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack('history_'.$type.'_social', FALSE, array( 'sprintf' => array( $handlerName, $byMember ?: $byStaff ) ) );
}
break;
case 'account':
$spamDefenseScore = NULL;
if ( isset( $jsonValue['spamCode'] ) AND isset( $jsonValue['spamAction'] ) )
{
$spamDefenseScore = \IPS\Member::loggedIn()->language()->addToStack( 'history_spam_defense_' . $jsonValue['spamAction'], FALSE, array( 'sprintf' => array( $jsonValue['spamCode'] ) ) );
}
switch ( $jsonValue['type'] )
{
case 'register':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_register', FALSE, array( 'sprintf' => array( $spamDefenseScore ) ) );
case 'register_checkout':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_register_checkout', FALSE, array( 'sprintf' => array( $spamDefenseScore ) ) );
case 'register_admin':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_register_admin', FALSE, array( 'sprintf' => array( $byStaff ) ) );
case 'register_handler':
try
{
$method = \IPS\Login\Handler::load( $jsonValue['handler'] )->_title;
}
catch ( \OutOfRangeException $e )
{
$method = \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['service'] );
}
return \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['complete'] ? 'history_account_created_handler' : 'history_account_created_handler_incomplete', FALSE, array( 'sprintf' => array( $method, $spamDefenseScore ) ) );
case 'complete':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_completed', FALSE, array( 'sprintf' => array( $byMember ?: $byStaff, $spamDefenseScore ) ) );
case 'email_validated':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_email_validated' );
case 'admin_validated':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_admin_validated', FALSE, array( 'sprintf' => array( $byStaff ) ) );
case 'merge':
if ( isset( $jsonValue['id'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_merged', FALSE, array( 'sprintf' => array( $jsonValue['id'], $jsonValue['name'], $jsonValue['email'], $byStaff ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_account_merged_legacy', FALSE, array( 'sprintf' => array( $jsonValue['legacy']['old'], $byStaff ) ) );
}
case 'spammer':
$set = isset( $jsonValue['set'] ) ? $jsonValue['set'] : $jsonValue['legacy']['set'];
if ( $set and isset( $jsonValue['actions'] ) )
{
$flagActions = array();
if ( in_array( 'delete', $jsonValue['actions'] ) )
{
$flagActions[] = \IPS\Member::loggedIn()->language()->addToStack('history_flagged_spammer_action_delete');
}
elseif ( in_array( 'unapprove', $jsonValue['actions'] ) )
{
$flagActions[] = \IPS\Member::loggedIn()->language()->addToStack('history_flagged_spammer_action_unapprove');
}
if ( in_array( 'ban', $jsonValue['actions'] ) )
{
$flagActions[] = \IPS\Member::loggedIn()->language()->addToStack('history_flagged_spammer_action_ban');
}
elseif ( in_array( 'disable', $jsonValue['actions'] ) )
{
$flagActions[] = \IPS\Member::loggedIn()->language()->addToStack('history_flagged_spammer_action_disable');
}
if ( count( $flagActions ) )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_flagged_spammer_with_actions', FALSE, array( 'sprintf' => array( $byStaff, \IPS\Member::loggedIn()->language()->formatList( $flagActions ) ) ) );
}
}
return \IPS\Member::loggedIn()->language()->addToStack( $set ? 'history_flagged_spammer' : 'history_unflagged_spammer', FALSE, array( 'sprintf' => array( $byStaff ) ) );
}
break;
case 'warning':
if ( isset( $jsonValue['restrictions'] ) ) // Manual restrictions change
{
$changes = array();
if ( isset( $jsonValue['restrictions']['member_warnings'] ) )
{
$changes[] = \IPS\Member::loggedIn()->language()->addToStack( 'history_restrictions_warning_level', FALSE, array( 'sprintf' => array( $jsonValue['restrictions']['member_warnings']['new'], $jsonValue['restrictions']['member_warnings']['old'] ) ) );
}
if ( isset( $jsonValue['restrictions']['ban'] ) )
{
if ( $jsonValue['restrictions']['ban']['new'] )
{
$c = \IPS\Member::loggedIn()->language()->addToStack( 'moderation_banned' );
if ( $jsonValue['restrictions']['ban']['new'] != -1 )
{
$diff = \IPS\DateTime::ts( $row['log_date'] )->diff( \IPS\DateTime::ts( $jsonValue['restrictions']['ban']['new'] ) );
$c = \IPS\Member::loggedIn()->language()->addToStack( 'history_received_warning_penalty_time', FALSE, array( 'sprintf' => array( $c, \IPS\DateTime::formatInterval( $diff, 2 ) ) ) );
}
}
else
{
$c = \IPS\Member::loggedIn()->language()->addToStack( 'history_warning_revoke_temp_ban' );
}
$changes[] = $c;
}
if ( isset( $jsonValue['restrictions']['members_disable_pm'] ) )
{
$changes[] = \IPS\Member::loggedIn()->language()->addToStack( 'history_restrictions_messenger_' . intval( $jsonValue['restrictions']['members_disable_pm']['new'] ) );
}
foreach ( \IPS\Application::allExtensions( 'core', 'MemberRestrictions', TRUE, 'core', 'Content', FALSE ) as $class )
{
foreach ( $class::changesForHistory( $jsonValue['restrictions'] ) as $v )
{
$changes[] = $v;
}
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_restrictions_change', FALSE, array( 'sprintf' => array( $byStaff, \IPS\Member::loggedIn()->language()->formatList( $changes ) ) ) );
}
elseif ( isset( $jsonValue['type'] ) and $jsonValue['type'] == 'revoke' ) // Warning revoked
{
$consequences = array();
if ( isset( $jsonValue['consequences'] ) )
{
foreach ( array( 'modq' => 'mod_posts', 'nopost' => 'restrict_post', 'banned' => 'temp_ban' ) as $k => $v )
{
if ( isset( $jsonValue['consequences'][ $v ] ) )
{
$consequences[] = \IPS\Member::loggedIn()->language()->addToStack( 'history_warning_revoke_' . $v );
}
}
}
$consequences = count( $consequences ) ? \IPS\Member::loggedIn()->language()->formatList( $consequences ) : \IPS\Member::loggedIn()->language()->addToStack('history_received_warning_no_changes');
return \IPS\Member::loggedIn()->language()->addToStack( 'history_revoke_warning', FALSE, array( 'sprintf' => array( $byStaff, $consequences ) ) );
}
else // Warning given
{
$consequences = array();
if ( isset( $jsonValue['consequences'] ) )
{
foreach ( array( 'modq' => 'mod_posts', 'nopost' => 'restrict_post', 'banned' => 'temp_ban' ) as $k => $v )
{
if ( isset( $jsonValue['consequences'][ $v ] ) )
{
$c = \IPS\Member::loggedIn()->language()->addToStack( 'moderation_' . $k );
if ( $jsonValue['consequences'][ $v ] != -1 )
{
$c = \IPS\Member::loggedIn()->language()->addToStack( 'history_received_warning_penalty_time', FALSE, array( 'sprintf' => array( $c, \IPS\DateTime::formatInterval( new \DateInterval( $jsonValue['consequences'][ $v ] ), 2 ) ) ) );
}
$consequences[] = $c;
}
}
}
$consequences = count( $consequences ) ? \IPS\Member::loggedIn()->language()->formatList( $consequences ) : \IPS\Member::loggedIn()->language()->addToStack('history_received_warning_no_penalties');
try
{
$warning = \IPS\core\Warnings\Warning::load( $jsonValue['wid'] );
if ( $warning->canViewDetails() )
{
if ( isset( $jsonValue['points'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack('history_received_warning_link', FALSE, array( 'sprintf' => array( \IPS\Http\Url::internal("app=core&module=members&controllers=members&do=viewWarning&id={$warning->id}"), $jsonValue['points'], \IPS\Member::loggedIn()->language()->addToStack( 'core_warn_reason_' . $jsonValue['reason'] ), $byStaff, $consequences ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack('history_received_warning_legacy_link', FALSE, array( 'sprintf' => array( \IPS\Http\Url::internal("app=core&module=members&controllers=members&do=viewWarning&id={$warning->id}") ) ) );
}
}
}
catch ( \Exception $e ) { }
if ( isset( $jsonValue['points'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack('history_received_warning_details', FALSE, array( 'sprintf' => array( $jsonValue['points'], \IPS\Member::loggedIn()->language()->addToStack( 'core_warn_reason_' . $jsonValue['reason'] ), $byStaff, $consequences ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_received_warning', FALSE, array( 'sprintf' => array( $byStaff ) ) );
}
}
break;
case 'mfa':
$handlerName = \IPS\Member::loggedIn()->language()->addToStack('mfa_' . $jsonValue['handler'] . '_title');
if( $jsonValue['enable'] === TRUE )
{
if ( isset( $jsonValue['reconfigure'] ) and $jsonValue['reconfigure'] )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_mfa_reconfigured', FALSE, array( 'sprintf' => array( $handlerName, $byMember ?: $byStaff ) ) );
}
else
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_mfa_enabled', FALSE, array( 'sprintf' => array( $handlerName, $byMember ?: $byStaff ) ) );
}
}
if( isset( $jsonValue['optout'] ) )
{
return \IPS\Member::loggedIn()->language()->addToStack( $jsonValue['optout'] ? 'history_mfa_optout' : 'history_mfa_optin', FALSE, array( 'sprintf' => array( $byMember ?: $byStaff ) ) );
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_mfa_disabled', FALSE, array( 'sprintf' => array( $handlerName, $byMember ?: $byStaff ) ) );
break;
case 'oauth':
try
{
$client = \IPS\Api\OAuthClient::load( $jsonValue['client'] );
$client = \IPS\Theme::i()->getTemplate( 'api', 'core' )->oauthClientLink( $client );
}
catch ( \OutOfRangeException $e )
{
$client = \IPS\Theme::i()->getTemplate( 'api', 'core' )->apiKey( $jsonValue['client'] );
}
switch ( $jsonValue['type'] )
{
case 'issued_access_token':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_oauth_token_issued', FALSE, array( 'htmlsprintf' => array( $client, \IPS\Member::loggedIn()->language()->addToStack( 'history_oauth_token_issued_' . $jsonValue['grant'] ) ) ) );
case 'revoked_access_token':
return \IPS\Member::loggedIn()->language()->addToStack( 'history_oauth_token_revoked', FALSE, array( 'htmlsprintf' => array( $client, $byMember ?: $byStaff ) ) );
}
break;
case 'admin_mails':
if( $jsonValue['enabled'] === TRUE )
{
return \IPS\Member::loggedIn()->language()->addToStack( 'history_enabled_admin_mails', FALSE, array( 'htmlsprintf' => array( $byMember ?: $byStaff ) ) );
}
return \IPS\Member::loggedIn()->language()->addToStack( 'history_disabled_admin_mails', FALSE, array( 'htmlsprintf' => array( $byMember ?: $byStaff ) ) );
break;
case 'terms_acceptance':
if( $jsonValue['type'] == 'privacy' )
{
return \IPS\Member::loggedIn()->language()->addToStack('history_terms_accepted_privacy');
}
if( $jsonValue['type'] == 'terms' )
{
return \IPS\Member::loggedIn()->language()->addToStack('history_terms_accepted_terms');
}
break;
}
return $value;
}
/**
* Parse LogType column
*
* @param string $value column value
* @param array $row entire log row
* @return string
*/
public function parseLogType( $value, $row )
{
return \IPS\Theme::i()->getTemplate( 'members', 'core' )->logType( $value );
}
}