Seditio Source
Root |
./othercms/ips_4.3.4/applications/core/modules/admin/applications/apiLogs.php
<?php
/**
 * @brief        API Logs
 * @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        04 Dec 2015
 */

namespace IPS\core\modules\admin\applications;

/* 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;
}

/**
 * apiReference
 */
class _apiLogs extends \IPS\Dispatcher\Controller
{
   
/**
     * Execute
     *
     * @return    void
     */
   
public function execute()
    {
        \
IPS\Dispatcher::i()->checkAcpPermission( 'api_logs' );
       
parent::execute();
    }

   
/**
     * View Logs
     *
     * @return    void
     */
   
protected function manage()
    {
       
/* Init table */
       
$table = new \IPS\Helpers\Table\Db( 'core_api_logs', \IPS\Http\Url::internal('app=core&module=applications&controller=api&tab=apiLogs') );
       
$table->langPrefix = 'api_log_';
       
       
/* Columns */
       
$table->include = array( 'date', 'endpoint', 'api_key', 'ip_address', 'response_code' );
       
$table->parsers = array(
           
'date'        => function( $val )
            {
                return \
IPS\DateTime::ts( $val );
            },
           
'endpoint'    => function( $val, $row )
            {
                return \
IPS\Theme::i()->getTemplate('api')->apiKey( $row['method'] . ' ' . $val );
            },
           
'api_key'    => function( $val, $row )
            {
               
$apiKey = NULL;
               
$client = NULL;
               
$member = NULL;
                if (
$row['api_key'] )
                {
                    try
                    {
                       
$apiKey = \IPS\Api\Key::load( $row['api_key'] );
                    }
                    catch ( \
OutOfRangeException $e ) { }
                }
                if (
$row['client_id'] )
                {
                    try
                    {
                       
$client = \IPS\Api\OAuthClient::load( $row['client_id'] );
                    }
                    catch ( \
OutOfRangeException $e ) { }
                   
                    if (
$row['member_id'] )
                    {
                       
$member = \IPS\Member::load( $row['member_id'] );
                    }
                }
               
                return \
IPS\Theme::i()->getTemplate('api')->apiLogCredentials( $row, $apiKey, $client, $member );
            },
           
'response_code'    => function( $val )
            {
                return
$val . ' ' . \IPS\Output::$httpStatuses[ $val ];
            }
        );
       
       
/* Default sort */
       
$table->sortBy = $table->sortBy ?: 'date';
       
$table->sortDirection = $table->sortDirection ?: 'desc';
       
       
/* Filters */
       
$table->filters = array(
           
'api_log_success'    => array( 'response_code LIKE ?', '2%' ),
           
'api_log_fail'        => array( 'response_code NOT LIKE ?', '2%' ),
        );
       
       
/* Search */
       
$endpoints = array();
        foreach ( \
IPS\Api\Controller::getAllEndpoints() as $k => $data )
        {
           
$endpoints[ $data['title'] ] = $data['title'];
        }
       
$statuses = array();
        foreach ( \
IPS\Output::$httpStatuses as $code => $name )
        {
           
$statuses[ $code ] = "{$code} {$name}";
        }
       
$table->advancedSearch = array(
           
'date'            => \IPS\Helpers\Table\SEARCH_DATE_RANGE,
           
'endpoint'        => array( \IPS\Helpers\Table\SEARCH_SELECT, array( 'options' => $endpoints ), function( $val )
            {
               
$exploded = explode( ' ', $val );
                return array(
'method=? AND endpoint=?', $exploded[0], trim( $exploded[1], '/' ) );
            } ),
           
'api_key'        => array( \IPS\Helpers\Table\SEARCH_NODE, array( 'class' => 'IPS\Api\Key' ) ),
           
'ip_address'    => \IPS\Helpers\Table\SEARCH_CONTAINS_TEXT,
           
'response_code'    => array( \IPS\Helpers\Table\SEARCH_SELECT, array( 'options' => $statuses ) ),
        );
       
       
/* Buttons */
       
$table->rowButtons = function( $row )
        {
           
$return = array(
               
'view'    => array(
                   
'icon'    => 'search',
                   
'title'    => 'view',
                   
'link'    => \IPS\Http\Url::internal('app=core&module=applications&controller=apiLogs&do=view')->setQueryString( 'id', $row['id'] ),
                   
'data'    => array( 'ipsDialog' => '', 'ipsDialog-title' => $row['method'] . ' ' . $row['endpoint'] )
                )
            );
            if ( \
IPS\Member::loggedIn()->hasAcpRestriction( 'core', 'applications', 'api_logs_delete' ) )
            {
               
$return['delete'] = array(
                   
'icon'    => 'times-circle',
                   
'title'    => 'delete',
                   
'link'    => \IPS\Http\Url::internal('app=core&module=applications&controller=apiLogs&do=delete')->setQueryString( 'id', $row['id'] ),
                   
'data'    => array( 'delete' => '' )
                );
            }
            return
$return;
        };
       
       
/* Display */
       
if ( !isset( \IPS\Request::i()->advancedSearchForm ) )
        {
            if ( \
IPS\Member::loggedIn()->hasAcpRestriction( 'core', 'applications', 'api_logs_settings' ) )
            {
                \
IPS\Output::i()->output = \IPS\Theme::i()->getTemplate( 'forms' )->blurb( \IPS\Member::loggedIn()->language()->addToStack( 'api_log_blurb_change', FALSE, array( 'sprintf' => array( \IPS\Settings::i()->api_log_prune ) ) ), TRUE, TRUE ) . $table;
            }
            else
            {
                \
IPS\Output::i()->output = \IPS\Theme::i()->getTemplate( 'forms' )->blurb( \IPS\Member::loggedIn()->language()->addToStack( 'api_log_blurb', FALSE, array( 'sprintf' => array( \IPS\Settings::i()->api_log_prune ) ) ), TRUE, TRUE ) . $table;
            }
        }
        else
        {
            \
IPS\Output::i()->output = $table;
        }
    }
   
   
/**
     * View Log
     *
     * @return    void
     */
   
protected function view()
    {
        try
        {
           
$log = \IPS\Db::i()->select( '*', 'core_api_logs', array( 'id=?', \IPS\Request::i()->id ) )->first();
        }
        catch ( \
UnderflowException $e )
        {
            \
IPS\Output::i()->error( 'node_error', '2C293/1', 404, '' );
        }
       
        \
IPS\Output::i()->output = \IPS\Theme::i()->getTemplate('api')->viewLog( $log['request_data'], $log['response_output'] );
    }
   
   
/**
     * Delete Log
     *
     * @return    void
     */
   
protected function delete()
    {
        \
IPS\Dispatcher::i()->checkAcpPermission( 'api_logs_delete' );

       
/* Make sure the user confirmed the deletion */
       
\IPS\Request::i()->confirmedDelete();

        try
        {
           
$log = \IPS\Db::i()->select( '*', 'core_api_logs', array( 'id=?', \IPS\Request::i()->id ) )->first();
        }
        catch ( \
UnderflowException $e )
        {
            \
IPS\Output::i()->error( 'node_error', '2C293/2', 404, '' );
        }
       
        \
IPS\Db::i()->delete( 'core_api_logs', array( 'id=?', $log['id'] ) );
       
        \
IPS\Session::i()->log( 'acplog__api_log_deleted', array( $log['id'] => FALSE ) );
       
        \
IPS\Output::i()->redirect( \IPS\Http\Url::internal('app=core&module=applications&controller=api&tab=apiLogs') );
    }
   
   
/**
     * Prune Settings
     *
     * @return    void
     */
   
protected function settings()
    {
        \
IPS\Dispatcher::i()->checkAcpPermission( 'api_logs_settings' );
       
       
$form = new \IPS\Helpers\Form;
       
$form->add( new \IPS\Helpers\Form\Number( 'api_log_prune', \IPS\Settings::i()->api_log_prune, FALSE, array(), NULL, \IPS\Member::loggedIn()->language()->addToStack('after'), \IPS\Member::loggedIn()->language()->addToStack('days') ) );
       
        if (
$values = $form->values() )
        {
           
$form->saveAsSettings();
            \
IPS\Session::i()->log( 'acplogs__api_log_settings' );
            \
IPS\Output::i()->redirect( \IPS\Http\Url::internal('app=core&module=applications&controller=api&tab=apiLogs') );
        }
       
        \
IPS\Output::i()->output = $form;
    }    
}