403Webshell
Server IP : 104.21.38.3  /  Your IP : 162.158.189.64
Web Server : Apache
System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64
User : www ( 1000)
PHP Version : 7.4.33
Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : ON
Directory :  /www/wwwroot/coircraft.com/wp-content/plugins/wp-mail-logging/src/Model/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /www/wwwroot/coircraft.com/wp-content/plugins/wp-mail-logging/src/Model/Email_Log_Collection.php
<?php

namespace No3x\WPML\Model;

// Exit if accessed directly
use No3x\WPML\Migration\Migration;

if ( ! defined( 'ABSPATH' ) ) {
    exit;
}

class Email_Log_Collection {

    /**
     * Status to use when fetching all logs.
     *
     * @since 1.11.0
     *
     * @var int
     */
    const STATUS_ALL = 0;

    /**
     * Status of email log without error.
     *
     * @since 1.11.0
     *
     * @var int
     */
    const STATUS_SUCCESSFUL = 1;

    /**
     * Status of email log with error.
     *
     * @since 1.11.0
     *
     * @var int
     */
    const STATUS_FAILED = 2;

    /**
     * Order ASC.
     *
     * @since 1.11.0
     *
     * @var string
     */
    const ORDER_ASC  = 'asc';

    /**
     * Order DESC.
     *
     * @since 1.11.0
     *
     * @var string
     */
    const ORDER_DESC = 'desc';

    /**
     * DB table name where email logs are stored.
     *
     * @since 1.11.0
     *
     * @var string
     */
    private $table_name = '';

    /**
     * Searchable fields.
     *
     * @since 1.11.0
     *
     * @var string[]
     */
    private $searchable_fields = [];

    /**
     * Contains the number of logs for each status.
     *
     * @since 1.11.0
     *
     * @var int[]
     */
    private $statuses_count = [
        self::STATUS_ALL        => 0,
        self::STATUS_SUCCESSFUL => 0,
        self::STATUS_FAILED     => 0,
    ];

    /**
     * Whether or not to only count the results.
     *
     * @since 1.11.0
     *
     * @var bool
     */
    private $count_only = false;

    /**
     * Status of the email logs to fetch. Default to all logs.
     *
     * @since 1.11.0
     *
     * @var int
     */
    private $status = self::STATUS_ALL;

    /**
     * Search term.
     *
     * @since 1.11.0
     *
     * @var string
     */
    private $search = '';

    /**
     * What field to search in.
     *
     * @since 1.12.0
     *
     * @var string
     */
    private $search_place = '';

    /**
     * Sorting of the email logs.
     *
     * @since 1.11.0
     *
     * @var string
     */
    private $sort_by = 'mail_id';

    /**
     * Order of the email logs.
     *
     * @since 1.11.0
     *
     * @var string
     */
    private $order = self::ORDER_DESC;

    /**
     * Number of email logs in the collection.
     *
     * @since 1.11.0
     *
     * @var int
     */
    private $limit = 25;

    /**
     * Offset used for pagination.
     *
     * @since 1.11.0
     *
     * @var int
     */
    private $offset = 0;

    /**
     * Constructor
     *
     * @since 1.11.0
     *
     * @param string   $table_name        DB table name where email logs are stored.
     * @param string[] $searchable_fields Array containing searchable fields.
     */
    public function __construct( $table_name, $searchable_fields ) {

        $this->table_name        = $table_name;
        $this->searchable_fields = $searchable_fields;
    }

    /**
     * Returns an array containing the number of email logs for each status.
     *
     * @since 1.11.0
     *
     * @return int[]
     */
    public function get_statuses_count() {

        // Cache temporarily the vars.
        $count_only = $this->count_only;
        $status     = $this->status;

        $this->count_only = true;

        // Get count of the successful logs.
        $this->status = self::STATUS_SUCCESSFUL;
        $this->statuses_count[ self::STATUS_SUCCESSFUL ] = $this->find_list();

        // Get count of the failed logs.
        $this->status = self::STATUS_FAILED;
        $this->statuses_count[ self::STATUS_FAILED ] = $this->find_list();

        // "All" is the combination of both successful and failed logs.
        $this->statuses_count[ self::STATUS_ALL ] = absint( $this->statuses_count[ self::STATUS_SUCCESSFUL ] ) + absint( $this->statuses_count[ self::STATUS_FAILED ] );

        // Revert back.
        $this->count_only = $count_only;
        $this->status = $status;

        return $this->statuses_count;
    }

    /**
     * Set if we are only counting the number of results or not.
     *
     * @since 1.11.0
     *
     * @param bool $count_only Whether or not to only count the email logs. Default `true`.
     *
     * @return Email_Log_Collection
     */
    public function count( $count_only = true ) {

        $this->count_only = $count_only;

        return $this;
    }

    /**
     * Set the status of the email logs we want to fetch.
     *
     * @since 1.11.0
     *
     * @param int $status
     *
     * @return Email_Log_Collection
     */
    public function status( $status = self::STATUS_ALL ) {

        $this->status = $status;

        return $this;
    }

    /**
     * Set the search term we want the email logs in this collection to match with.
     *
     * @since 1.11.0
     *
     * @param string $search Search term.
     *
     * @return Email_Log_Collection
     */
    public function search( $search ) {

        $this->search = $search;

        return $this;
    }

    /**
     * Set the field where we want to search in.
     *
     * @since 1.12.0
     *
     * @param string $search_place Field to search in.
     *
     * @return $this
     */
    public function search_place( $search_place ) {

        $this->search_place = $search_place;

        return $this;
    }

    /**
     * Set the sorting field of the collection.
     *
     * @since 1.11.0
     *
     * @param string $sort_by Sort by field.
     *
     * @return Email_Log_Collection
     */
    public function sort_by( $sort_by ) {

        $this->sort_by = $sort_by;

        return $this;
    }

    /**
     * Order of the collection.
     *
     * @since 1.11.0
     *
     * @param string $order Only accepts `asc` or `desc`. Case-insensitive.
     *
     * @return Email_Log_Collection
     */
    public function order( $order ) {

        $order = strtolower( $order );

        if ( ! in_array( $order, [ self::ORDER_ASC, self::ORDER_DESC ], true ) ) {
            return $this;
        }

        $this->order = $order;

        return $this;
    }

    /**
     * Set the number of limit of the email logs in the collection.
     *
     * @since 1.11.0
     *
     * @param int $limit Limit of the email logs in the collection.
     *
     * @return Email_Log_Collection
     */
    public function limit( $limit ) {

        $this->limit = absint( $limit );

        return $this;
    }

    /**
     * Set the offset to use when calculating results.
     *
     * @since 1.11.0
     *
     * @param int $offset Offset.
     *
     * @return Email_Log_Collection
     */
    public function offset( $offset ) {

        $this->offset = $offset;

        return $this;
    }

    /**
     * Compose the query and fetch the collection of email logs.
     *
     * @since 1.11.0
     *
     * @return int|array Returns an integer which is the number of results if `$this->count_only` is `true`.
     *                   Otherwise returns an array of email logs.
     */
    public function find_list() {

        global $wpdb;

        // Build `SELECT` clause.
        if ( $this->count_only ) {
            $select = 'SELECT COUNT(*) ';
        } else {
            $select = 'SELECT * ';
        }
        $select .= 'FROM ' . esc_sql( $this->table_name );

        // Build there `WHERE` clause in the context of log status.
        $status_where = '';
        switch( $this->status ) {
            case self::STATUS_SUCCESSFUL:
                $status_where .= " WHERE `error` IS NULL OR `error` = ''";
                break;
            case self::STATUS_FAILED:
                $status_where .= " WHERE `error` IS NOT NULL AND `error` != ''";
                break;
            default:
                break;
        }

        // Build there `WHERE` clause in the context of search term.
        $search_where = '';
        if ( ! empty( $this->search ) ) {
            if ( empty( $status_where ) ) {
                $search_where = ' WHERE (';
            } else {
                $search_where .= ' AND (';
            }

            foreach ( $this->get_search_place() as $field ) {

                $search_where .= $this->get_search_sql( $field );
            }

            // Remove the last ' OR ' and add the closing ')';
            $search_where = substr( $search_where, 0, -4 ) . ')';
        }

        // Build query.
        $query = $select . $status_where . $search_where;

        if ( $this->count_only ) {
            $results = $wpdb->get_var( $query );
        } else {

            // SORT BY, LIMIT, and ORDER are only applicable if we're not counting the results.
            if ( ! empty( $this->sort_by ) ) {
                $query .= ' ORDER BY `' . esc_sql( $this->sort_by ) . '`';

                if ( ! empty( $this->order ) && in_array( $this->order, [ self::ORDER_ASC, self::ORDER_DESC ], true ) ) {
                    $query .= ' ' . esc_sql( $this->order );
                }
            }

            if ( ! empty( $this->limit ) ) {
                $query .= ' LIMIT ' . absint( $this->limit );
            }

            if ( ! empty( $this->offset ) ) {
                $query .= ' OFFSET ' . absint( $this->offset );
            }

            $results = $wpdb->get_results( $query, ARRAY_A );
        }

        if ( empty( $results ) ) {
            if ( $this->count_only ) {
                return 0;
            }

            return [];
        }

        return $results;
    }

    /**
     * Get the fields where the search term will be searched.
     *
     * @since 1.12.0
     *
     * @return string[]
     */
    private function get_search_place() {

        if ( empty( $this->search_place ) || ! in_array( $this->search_place, $this->searchable_fields, true ) ) {
            return $this->searchable_fields;
        }

        return [ $this->search_place ];
    }

    /**
     * Get the search SQL.
     *
     * @since 1.12.0
     *
     * @param string $field Field we are trying to search to.
     *
     * @return string
     */
    private function get_search_sql( $field ) {

        $db_migrate_version = absint( get_option( Migration::OPTION_NAME, 0 ) );

        /*
         * We use `MATCH AGAINST` for the `message` field if the database is migrated to version 2 or higher.
         * We add the FULL TEXT index to the `message` field in version 2.
         */
        if ( $field === 'message' && version_compare( $db_migrate_version, 2, '>=' ) ) {
            return "MATCH (`message`) AGAINST ('" . esc_sql( $this->search ) . "') OR ";
        }

        return '`' . esc_sql( $field ) . '` LIKE "%' . esc_sql( $this->search ) . '%" OR ';
    }

    /**
     * Get the email log statuses for filtering purposes.
     *
     * @since 1.11.0
     *
     * @return array
     */
    public static function get_statuses() {

        return [
            self::STATUS_ALL        => __( 'All', 'wp-mail-logging' ),
            self::STATUS_SUCCESSFUL => __( 'Successful', 'wp-mail-logging' ),
            self::STATUS_FAILED     => __( 'Failed', 'wp-mail-logging' ),
        ];
    }
}

Youez - 2016 - github.com/yon3zu
LinuXploit