55 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
| <?php
 | |
| 
 | |
| /*
 | |
|  * This file is part of the Symfony package.
 | |
|  *
 | |
|  * (c) Fabien Potencier <fabien@symfony.com>
 | |
|  *
 | |
|  * For the full copyright and license information, please view the LICENSE
 | |
|  * file that was distributed with this source code.
 | |
|  */
 | |
| 
 | |
| namespace Symfony\Component\Cache\Adapter;
 | |
| 
 | |
| use Doctrine\DBAL\Connection;
 | |
| use Symfony\Component\Cache\Exception\InvalidArgumentException;
 | |
| use Symfony\Component\Cache\Marshaller\MarshallerInterface;
 | |
| use Symfony\Component\Cache\PruneableInterface;
 | |
| use Symfony\Component\Cache\Traits\PdoTrait;
 | |
| 
 | |
| class PdoAdapter extends AbstractAdapter implements PruneableInterface
 | |
| {
 | |
|     use PdoTrait;
 | |
| 
 | |
|     protected $maxIdLength = 255;
 | |
| 
 | |
|     /**
 | |
|      * You can either pass an existing database connection as PDO instance or
 | |
|      * a Doctrine DBAL Connection or a DSN string that will be used to
 | |
|      * lazy-connect to the database when the cache is actually used.
 | |
|      *
 | |
|      * When a Doctrine DBAL Connection is passed, the cache table is created
 | |
|      * automatically when possible. Otherwise, use the createTable() method.
 | |
|      *
 | |
|      * List of available options:
 | |
|      *  * db_table: The name of the table [default: cache_items]
 | |
|      *  * db_id_col: The column where to store the cache id [default: item_id]
 | |
|      *  * db_data_col: The column where to store the cache data [default: item_data]
 | |
|      *  * db_lifetime_col: The column where to store the lifetime [default: item_lifetime]
 | |
|      *  * db_time_col: The column where to store the timestamp [default: item_time]
 | |
|      *  * db_username: The username when lazy-connect [default: '']
 | |
|      *  * db_password: The password when lazy-connect [default: '']
 | |
|      *  * db_connection_options: An array of driver-specific connection options [default: []]
 | |
|      *
 | |
|      * @param \PDO|Connection|string $connOrDsn a \PDO or Connection instance or DSN string or null
 | |
|      *
 | |
|      * @throws InvalidArgumentException When first argument is not PDO nor Connection nor string
 | |
|      * @throws InvalidArgumentException When PDO error mode is not PDO::ERRMODE_EXCEPTION
 | |
|      * @throws InvalidArgumentException When namespace contains invalid characters
 | |
|      */
 | |
|     public function __construct($connOrDsn, string $namespace = '', int $defaultLifetime = 0, array $options = [], MarshallerInterface $marshaller = null)
 | |
|     {
 | |
|         $this->init($connOrDsn, $namespace, $defaultLifetime, $options, $marshaller);
 | |
|     }
 | |
| }
 |