import-sqlite-for-user.php 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. #!/usr/bin/env php
  2. <?php
  3. declare(strict_types=1);
  4. require(__DIR__ . '/_cli.php');
  5. performRequirementCheck(FreshRSS_Context::systemConf()->db['type'] ?? '');
  6. $params = [
  7. 'user:',
  8. 'filename:',
  9. 'force-overwrite',
  10. ];
  11. $options = getopt('', $params);
  12. if (!validateOptions($argv, $params) || empty($options['user']) || empty($options['filename']) || !is_string($options['user']) || !is_string($options['filename'])) {
  13. fail('Usage: ' . basename(__FILE__) . ' --user username --force-overwrite --filename /path/to/db.sqlite');
  14. }
  15. $username = cliInitUser($options['user']);
  16. $filename = $options['filename'];
  17. if (pathinfo($filename, PATHINFO_EXTENSION) !== 'sqlite') {
  18. fail('Only *.sqlite files are supported!');
  19. }
  20. echo 'FreshRSS importing database from SQLite for user “', $username, "”…\n";
  21. $databaseDAO = FreshRSS_Factory::createDatabaseDAO($username);
  22. $clearFirst = array_key_exists('force-overwrite', $options);
  23. $ok = $databaseDAO->dbCopy($filename, FreshRSS_DatabaseDAO::SQLITE_IMPORT, $clearFirst);
  24. if (!$ok) {
  25. echo 'If you would like to clear the user database first, use the option --force-overwrite', "\n";
  26. }
  27. invalidateHttpCache($username);
  28. done($ok);