View file application/libraries/Scaffold/libraries/Scaffold/Cache.php

File size: 4.57Kb
<?php
/**
 * Scaffold_Cache
 *
 * Handles the file caching
 *
 * @author Anthony Short
 * @package CSScaffold
 */
final class Scaffold_Cache
{
    /**
     * The server path to the cache directory
     *
     * @var string
     */
    private static $cache_path;

    /**
     * Cache lifetime
     *
     * @var string
     */
    private static $lifetime = 0;

    /**
     * Is the cache locked?
     *
     * @var boolan
     */
    private static $frozen = false;

    /**
     * Sets up the cache path
     */
    public static function setup($path,$lifetime)
    {
        if (!is_dir($path))
            Scaffold::log("Cache path does not exist. $path",0);

        if (!is_writable($path))
            Scaffold::log("Cache path is not writable. $path",0);

        self::$cache_path = $path;
        self::lifetime($lifetime);
    }


    public static function is_fresh($file)
    {
        if( time() <= ( self::$lifetime +  self::modified($file) ) )
        {
            return true;
        }
        else
        {
            return false;
        }
    }

    /**
     * Sets the lifetime of the cache
     *
     * @param $time
     * @return void
     */
    public static function lifetime($time)
    {
        self::$lifetime = $time;
    }

    /**
     * Returns the particular cache file as a string
     *
     * @param $file
     * @return string $string The contents of the file
     */
    public static function open($file)
    {
        if(self::exists($file))
        {
            return file_get_contents(self::find($file));
        }

        return false;
    }

    /**
     * Returns the full path of the cache file, if it exists
     *
     * @param $file
     * @return string
     */
    public static function exists($file)
    {
        if(is_file(self::$cache_path.$file))
            return true;

        if(is_dir(self::$cache_path.$file))
        {
            return true;
        }

        return false;
    }

    /**
     * Returns the last modified date of a cache file
     *
     * @param $file
     * @return int
     */
    public static function modified($file)
    {
        return ( self::exists($file) ) ? (int) filemtime(self::find($file)) : 0 ;
    }

    /**
     * Finds a file inside the cache and returns it's full path
     *
     * @param $file
     * @return string
     */
    public static function find($file)
    {
        if(self::exists($file))
            return self::$cache_path.$file;

        return false;
    }

    /**
     * Write to the set cache
     *
     * @return void
     * @author Anthony Short
     */
    public static function write( $data, $target = '', $append = false )
    {
        # Create the cache file
        self::create(dirname($target));

        $target = self::$cache_path.$target;

        if(is_array($data))
            $data = serialize($data);

        # Put it in the cache
        if($append)
        {
            file_put_contents($target, $data, FILE_APPEND);
        }
        else
        {
            file_put_contents($target, $data);
        }

        # Set its parmissions
        chmod($target, 0777);
        touch($target, time());

        return true;
    }

    /**
     * Removes a cache item
     *
     * @param $file
     * @return boolean
     */
    public static function remove($file)
    {
        if(self::find($file))
        {
            unlink(self::find($file));
            return true;
        }

        return false;
    }

    /**
     * Remove a cache directory and sub-directories
     *
     * @param $dir
     * @return boolean
     */
    public static function remove_dir($dir)
    {
        if(!is_dir($dir))
        {
            $dir = self::find($dir);
        }

        $files = glob( $dir . '*', GLOB_MARK );

        foreach( $files as $file )
        {
            if( is_dir($file) )
            {
                self::remove_dir( $file );
                rmdir( $file );
            }
            else
            {
                unlink( $file );
            }
        }

        return true;
    }

    /**
     * Create the cache file directory
     */
    public static function create($path)
    {
        # If it already exists
        if(is_dir(self::$cache_path.$path))
            return true;

        # Create the directories inside the cache folder
        $next = "";

        foreach(explode('/',$path) as $dir)
        {
            $next = '/' . $next . '/' . $dir;

            if(!is_dir(self::$cache_path.$next))
            {
                mkdir(self::$cache_path.$next);
                chmod(self::$cache_path.$next, 0777);
            }
        }

        return true;
    }
}