export-zip-for-user.php 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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. $parameters = [
  7. 'long' => [
  8. 'user' => ':',
  9. 'max-feed-entries' => ':',
  10. ],
  11. 'short' => [],
  12. 'deprecated' => [],
  13. ];
  14. $options = parseCliParams($parameters);
  15. if (!empty($options['invalid']) || empty($options['valid']['user']) || !is_string($options['valid']['user'])) {
  16. fail('Usage: ' . basename(__FILE__) . " --user username ( --max-feed-entries 100 ) > /path/to/file.zip");
  17. }
  18. if (!extension_loaded('zip')) {
  19. fail('FreshRSS error: Lacking php-zip extension!');
  20. }
  21. $username = cliInitUser($options['valid']['user']);
  22. fwrite(STDERR, 'FreshRSS exporting ZIP for user “' . $username . "”…\n");
  23. $export_service = new FreshRSS_Export_Service($username);
  24. $number_entries = empty($options['valid']['max-feed-entries']) ? 100 : intval($options['valid']['max-feed-entries']);
  25. $exported_files = [];
  26. // First, we generate the OPML file
  27. list($filename, $content) = $export_service->generateOpml();
  28. $exported_files[$filename] = $content;
  29. // Then, labelled and starred entries
  30. list($filename, $content) = $export_service->generateStarredEntries('ST');
  31. $exported_files[$filename] = $content;
  32. // And a list of entries based on the complete list of feeds
  33. $feeds_exported_files = $export_service->generateAllFeedEntries($number_entries);
  34. $exported_files = array_merge($exported_files, $feeds_exported_files);
  35. // Finally, we compress all these files into a single Zip archive and we output
  36. // the content
  37. list($filename, $content) = $export_service->zip($exported_files);
  38. echo $content;
  39. invalidateHttpCache($username);
  40. done();