|
|
|
@ -23,6 +23,8 @@ |
|
|
|
|
|
|
|
namespace OC\Setup; |
|
|
|
|
|
|
|
use OC\DB\ConnectionFactory; |
|
|
|
|
|
|
|
class Sqlite extends AbstractDatabase { |
|
|
|
public $dbprettyname = 'Sqlite'; |
|
|
|
|
|
|
|
@ -30,14 +32,39 @@ class Sqlite extends AbstractDatabase { |
|
|
|
return array(); |
|
|
|
} |
|
|
|
|
|
|
|
public function initialize($config) { |
|
|
|
/* |
|
|
|
* Web: When using web based installer its not possible to set dbname |
|
|
|
* or dbtableprefix. Defaults used from ConnectionFactory and dbtype = 'sqlite' |
|
|
|
* is written to config.php. |
|
|
|
* |
|
|
|
* Cli: When --database-name or --database-table-prefix empty or default |
|
|
|
* dbtype = 'sqlite' is written to config.php. If you choose a value different |
|
|
|
* from default these values are written to config.php. This is required because |
|
|
|
* in connection factory configuration is obtained from config.php. |
|
|
|
*/ |
|
|
|
|
|
|
|
$this->dbName = $config['dbname'] ?? ConnectionFactory::DEFAULT_DBNAME; |
|
|
|
$this->tablePrefix = $config['dbtableprefix'] ?? ConnectionFactory::DEFAULT_DBTABLEPREFIX; |
|
|
|
|
|
|
|
if ($this->dbName !== ConnectionFactory::DEFAULT_DBNAME) { |
|
|
|
$this->config->setValue('dbname', $this->dbName); |
|
|
|
} |
|
|
|
|
|
|
|
if ($this->tablePrefix !== ConnectionFactory::DEFAULT_DBTABLEPREFIX) { |
|
|
|
$this->config->setValue('dbtableprefix', $this->tablePrefix); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
public function setupDatabase($username) { |
|
|
|
$datadir = $this->config->getValue('datadirectory', \OC::$SERVERROOT . '/data'); |
|
|
|
$datadir = $this->config->getValue( |
|
|
|
'datadirectory', |
|
|
|
\OC::$SERVERROOT . '/data' |
|
|
|
); |
|
|
|
|
|
|
|
//delete the old sqlite database first, might cause infinte loops otherwise
|
|
|
|
if (file_exists("$datadir/owncloud.db")) { |
|
|
|
unlink("$datadir/owncloud.db"); |
|
|
|
$sqliteFile = $datadir . '/' . $this->dbName . 'db'; |
|
|
|
if (file_exists($sqliteFile)) { |
|
|
|
unlink($sqliteFile); |
|
|
|
} |
|
|
|
//in case of sqlite, we can always fill the database
|
|
|
|
error_log("creating sqlite db"); |
|
|
|
} |
|
|
|
} |