export-sqlite-for-user.php 738 B

12345678910111213141516171819202122232425262728
  1. #!/usr/bin/php
  2. <?php
  3. require(__DIR__ . '/_cli.php');
  4. $params = [
  5. 'user:',
  6. 'filename:',
  7. ];
  8. $options = getopt('', $params);
  9. if (!validateOptions($argv, $params) || empty($options['user']) || empty($options['filename'])) {
  10. fail('Usage: ' . basename(__FILE__) . ' --user username --filename /path/to/db.sqlite');
  11. }
  12. $username = cliInitUser($options['user']);
  13. $filename = $options['filename'];
  14. if (pathinfo($filename, PATHINFO_EXTENSION) !== 'sqlite') {
  15. fail('Only *.sqlite files are supported!');
  16. }
  17. echo 'FreshRSS exporting database to SQLite for user “', $username, "”…\n";
  18. $databaseDAO = FreshRSS_Factory::createDatabaseDAO($username);
  19. $ok = $databaseDAO->dbCopy($filename, FreshRSS_DatabaseDAO::SQLITE_EXPORT);
  20. done($ok);