HEX
Server: Apache/2.4.38 (Debian)
System: Linux host457 5.14.0-4-amd64 #1 SMP Debian 5.14.16-1 (2021-11-03) x86_64
User: www-data (33)
PHP: 7.4.21
Disabled: 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_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/vhosts/harpoeditore.it/httpdocs/wp-content/themes/mindig/core/yit/Transient.php
<?php
/**
 * This file belongs to the YIT Framework.
 *
 * This source file is subject to the GNU GENERAL PUBLIC LICENSE (GPL 3.0)
 * that is bundled with this package in the file LICENSE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://www.gnu.org/licenses/gpl-3.0.txt
 */

if (!defined('YIT')) exit('Direct access forbidden.');

/**
 * Advanced managment of the Transient API of wordpress, by the theme.
 *
 * @class YIT_Transient
 * @package	Yithemes
 * @since 1.0.0
 * @author Your Inspiration Themes
 */
class YIT_Transient extends YIT_Object {

    /**
     * Array of used transients in the theme
     *
     * @var int
     * @access protected
     */
    protected $_transients = array();

    /**
     * Prefix of transients name
     *
     * @var int
     * @access protected
     */
    protected $_prefix = 'yit_';

    /**
     * Constructor
     *
     * @since 2.0.0
     * @author Antonino Scarfi <antonino.scarfi@yithemes.com>
     */
    public function __construct() {
        $this->_prefix .= YIT_THEME_NAME . '_';
    }

    /**
     * Add the transient name in the $_transients property
     *
     * @param string Transient name to add in $_transients array property
     * @since 1.0.0
     * @author Antonino Scarfi <antonino.scarfi@yithemes.com>
     */
    protected function _add( $transient ) {
        if ( ! in_array( $transient, $this->_transients ) ) {
            $this->_transients[] = $transient;
        }
    }

    /**
     * Set/update the value of a transient.
     *
     * You do not need to serialize values. If the value needs to be serialized, then
     * it will be serialized before it is set.
     *
     * @uses apply_filters() Calls 'pre_set_transient_$transient' hook to allow overwriting the
     * 	transient value to be stored.
     * @uses do_action() Calls 'set_transient_$transient' and 'setted_transient' hooks on success.
     *
     * @param string $transient Transient name. Expected to not be SQL-escaped.
     * @param mixed $value Transient value. Expected to not be SQL-escaped.
     * @param int $expiration Time until expiration in seconds, default 0
     * @return bool False if value was not set and true if value was set.
     * @since 1.0.0
     * @author Antonino Scarfi <antonino.scarfi@yithemes.com>
     */
    public function set_transient( $transient, $value, $expiration = 0 ) {
        $this->_add( $transient );

        return set_transient( $this->_prefix . $transient, $value, $expiration );
    }

    /**
     * Get the value of a transient.
     *
     * If the transient does not exist or does not have a value, then the return value
     * will be false.
     *
     * @uses apply_filters() Calls 'pre_transient_$transient' hook before checking the transient.
     * 	Any value other than false will "short-circuit" the retrieval of the transient
     *	and return the returned value.
     * @uses apply_filters() Calls 'transient_$option' hook, after checking the transient, with
     * 	the transient value.
     *
     * @param string $transient Transient name. Expected to not be SQL-escaped
     * @return mixed Value of transient
     * @since 1.0.0
     * @author Antonino Scarfi <antonino.scarfi@yithemes.com>
     */
    public function get_transient( $transient ) {
        $this->_add( $transient );

        return get_transient( $this->_prefix . $transient );
    }

    /**
     * Delete a transient.
     *
     * @uses do_action() Calls 'delete_transient_$transient' hook before transient is deleted.
     * @uses do_action() Calls 'deleted_transient' hook on success.
     *
     * @param string $transient Transient name. Expected to not be SQL-escaped.
     * @return bool true if successful, false otherwise
     * @since 1.0.0
     * @author Antonino Scarfi <antonino.scarfi@yithemes.com>
     */
    public function delete_transient( $transient ) {
        $this->_add( $transient );

        return delete_transient( $this->_prefix . $transient );
    }

}