check session validity by DatabaseSessionHandler #16
@ -13,14 +13,17 @@ class DatabaseSessionHandler implements ISessionHandler
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    private string $table;
 | 
					    private string $table;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private DateTime $shouldBeNewerThan;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private bool $exists = false;
 | 
					    private bool $exists = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private bool $written = false;
 | 
					    private bool $written = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public function __construct(IConnection $dbConnection, string $table)
 | 
					    public function __construct(IConnection $dbConnection, string $table, DateTime $shouldBeNewerThan)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        $this->dbConnection = $dbConnection;
 | 
					        $this->dbConnection = $dbConnection;
 | 
				
			||||||
        $this->table = $table;
 | 
					        $this->table = $table;
 | 
				
			||||||
 | 
					        $this->shouldBeNewerThan = $shouldBeNewerThan;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public function open($savePath, $sessionName): bool
 | 
					    public function open($savePath, $sessionName): bool
 | 
				
			||||||
@ -36,17 +39,20 @@ class DatabaseSessionHandler implements ISessionHandler
 | 
				
			|||||||
    public function read($id): string
 | 
					    public function read($id): string
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        $select = new Select($this->dbConnection, $this->table);
 | 
					        $select = new Select($this->dbConnection, $this->table);
 | 
				
			||||||
        $select->columns(['data']);
 | 
					        $select->columns(['data', 'updated']);
 | 
				
			||||||
        $select->whereId(substr($id, 0, 32));
 | 
					        $select->whereId(substr($id, 0, 32));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $result = $select->execute()->fetch(IResultSet::FETCH_ASSOC);
 | 
					        $result = $select->execute()->fetch(IResultSet::FETCH_ASSOC);
 | 
				
			||||||
 | 
					 | 
				
			||||||
        if ($result === null) {
 | 
					        if ($result === null) {
 | 
				
			||||||
            return '';
 | 
					            return '';
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $this->exists = true;
 | 
					        $this->exists = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if (new DateTime($result['updated']) < $this->shouldBeNewerThan) {
 | 
				
			||||||
 | 
					            return '';
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        return $result['data'];
 | 
					        return $result['data'];
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user