CacheFactory.php 1.53 KB
Newer Older
Scott committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
<?php
/*
	Question2Answer by Gideon Greenspan and contributors
	http://www.question2answer.org/

	File: qa-include/Q2A/Storage/CacheManager.php
	Description: Handler for caching system.


	This program is free software; you can redistribute it and/or
	modify it under the terms of the GNU General Public License
	as published by the Free Software Foundation; either version 2
	of the License, or (at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU General Public License for more details.

	More about this license: http://www.question2answer.org/license.php
*/

/**
 * Caches data (typically from database queries) to the filesystem.
 */
class Q2A_Storage_CacheFactory
{
Scott committed
28 29
	private static $cacheDriver = null;

Scott committed
30 31 32 33 34 35
	/**
	 * Get the appropriate cache handler.
	 * @return Q2A_Storage_CacheInterface The cache handler.
	 */
	public static function getCacheDriver()
	{
Scott committed
36 37 38 39 40 41
		if (self::$cacheDriver === null) {
			$config = array(
				'enabled' => (int) qa_opt('caching_enabled') === 1,
				'dir' => defined('QA_CACHE_DIRECTORY') ? QA_CACHE_DIRECTORY : null,
			);

42 43 44 45 46 47 48 49 50 51 52 53 54 55
			$driver = qa_opt('caching_driver');

			switch($driver)
			{
				case 'memcached':
					self::$cacheDriver = new Q2A_Storage_MemcachedDriver($config);
					break;

				case 'filesystem':
				default:
					self::$cacheDriver = new Q2A_Storage_FileCacheDriver($config);
					break;
			}

Scott committed
56
		}
Scott committed
57

Scott committed
58
		return self::$cacheDriver;
Scott committed
59 60
	}
}