blob: e67896df9582ced75d6a61e1707a9e44a325dca9 (
plain)
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
28
29
30
31
32
33
34
35
36
37
38
|
#!/usr/bin/env php
<?php
declare(strict_types=1);
require(__DIR__ . '/_cli.php');
performRequirementCheck(FreshRSS_Context::systemConf()->db['type'] ?? '');
$parameters = [
'long' => [
'user' => ':',
'filename' => ':',
],
'short' => [],
'deprecated' => [],
];
$options = parseCliParams($parameters);
if (!empty($options['invalid'])
|| empty($options['valid']['user']) || empty($options['valid']['filename'])
|| !is_string($options['valid']['user']) || !is_string($options['valid']['filename'])
) {
fail('Usage: ' . basename(__FILE__) . ' --user username --filename /path/to/db.sqlite');
}
$username = cliInitUser($options['valid']['user']);
$filename = $options['valid']['filename'];
if (pathinfo($filename, PATHINFO_EXTENSION) !== 'sqlite') {
fail('Only *.sqlite files are supported!');
}
echo 'FreshRSS exporting database to SQLite for user “', $username, "”…\n";
$databaseDAO = FreshRSS_Factory::createDatabaseDAO($username);
$ok = $databaseDAO->dbCopy($filename, FreshRSS_DatabaseDAO::SQLITE_EXPORT);
done($ok);
|