4
0

UserConfiguration.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * @property string $apiPasswordHash
  5. * @property array{keep_period:string|false,keep_max:int|false,keep_min:int|false,keep_favourites:bool,keep_labels:bool,keep_unreads:bool} $archiving
  6. * @property bool $auto_load_more
  7. * @property bool $auto_remove_article
  8. * @property bool $bottomline_date
  9. * @property bool $bottomline_favorite
  10. * @property bool $bottomline_link
  11. * @property bool $bottomline_read
  12. * @property bool $bottomline_sharing
  13. * @property bool $bottomline_tags
  14. * @property bool $bottomline_myLabels
  15. * @property string $content_width
  16. * @property-read int $default_state
  17. * @property string $default_view
  18. * @property string|bool $display_categories
  19. * @property string $show_tags
  20. * @property int $show_tags_max
  21. * @property string $show_author_date
  22. * @property string $show_feed_name
  23. * @property string $show_article_icons
  24. * @property bool $display_posts
  25. * @property string $email_validation_token
  26. * @property-read bool $enabled
  27. * @property string $feverKey
  28. * @property bool $hide_read_feeds
  29. * @property int $html5_notif_timeout
  30. * @property-read bool $is_admin
  31. * @property int|null $keep_history_default
  32. * @property string $language
  33. * @property string $timezone
  34. * @property bool $lazyload
  35. * @property string $mail_login
  36. * @property bool $mark_updated_article_unread
  37. * @property array<string,bool|int> $mark_when
  38. * @property int $max_posts_per_rss
  39. * @property-read array<string,int> $limits
  40. * @property int|null $old_entries
  41. * @property bool $onread_jump_next
  42. * @property string $passwordHash
  43. * @property int $posts_per_page
  44. * @property array<int,array{get?:string,name?:string,order?:string,search?:string,state?:int,url?:string,token?:string}> $queries
  45. * @property bool $reading_confirm
  46. * @property int $since_hours_posts_per_rss
  47. * @property bool $show_fav_unread
  48. * @property bool $show_favicons
  49. * @property bool $icons_as_emojis
  50. * @property int $simplify_over_n_feeds
  51. * @property bool $show_nav_buttons
  52. * @property 'big'|'small'|'none' $mark_read_button
  53. * @property 'ASC'|'DESC' $sort_order
  54. * @property 'id'|'date'|'link'|'title'|'rand' $sort
  55. * @property array<int,array<string,string>> $sharing
  56. * @property array<string,string> $shortcuts
  57. * @property bool $sides_close_article
  58. * @property bool $sticky_post
  59. * @property string $theme
  60. * @property string $darkMode
  61. * @property string $token
  62. * @property bool $topline_date
  63. * @property bool $topline_display_authors
  64. * @property bool $topline_favorite
  65. * @property bool $topline_myLabels
  66. * @property bool $topline_sharing
  67. * @property bool $topline_link
  68. * @property bool $topline_read
  69. * @property bool $topline_summary
  70. * @property string $topline_website
  71. * @property string $topline_thumbnail
  72. * @property int $ttl_default
  73. * @property int $dynamic_opml_ttl_default
  74. * @property-read bool $unsafe_autologin_enabled
  75. * @property string $view_mode
  76. * @property array<string,bool|int|string> $volatile
  77. * @property array<string,array<string,mixed>> $extensions
  78. * @property bool $retrieve_extension_list
  79. */
  80. final class FreshRSS_UserConfiguration extends Minz_Configuration {
  81. use FreshRSS_FilterActionsTrait;
  82. /** @throws Minz_FileNotExistException */
  83. public static function init(string $config_filename, ?string $default_filename = null): FreshRSS_UserConfiguration {
  84. parent::register('user', $config_filename, $default_filename);
  85. try {
  86. return parent::get('user');
  87. } catch (Minz_ConfigurationNamespaceException $ex) {
  88. FreshRSS::killApp($ex->getMessage());
  89. }
  90. }
  91. /**
  92. * Access the default configuration for users.
  93. * @throws Minz_FileNotExistException
  94. */
  95. public static function default(): FreshRSS_UserConfiguration {
  96. /** @var FreshRSS_UserConfiguration|null $default_user_conf */
  97. static $default_user_conf = null;
  98. if ($default_user_conf === null) {
  99. $namespace = 'user_default';
  100. FreshRSS_UserConfiguration::register($namespace, '_', FRESHRSS_PATH . '/config-user.default.php');
  101. $default_user_conf = FreshRSS_UserConfiguration::get($namespace);
  102. }
  103. return $default_user_conf;
  104. }
  105. /**
  106. * @param non-empty-string $key
  107. * @return array<int|string,mixed>|null
  108. */
  109. public function attributeArray(string $key): ?array {
  110. $a = parent::param($key, null);
  111. return is_array($a) ? $a : null;
  112. }
  113. /** @param non-empty-string $key */
  114. public function attributeBool(string $key): ?bool {
  115. $a = parent::param($key, null);
  116. return is_bool($a) ? $a : null;
  117. }
  118. /** @param non-empty-string $key */
  119. public function attributeInt(string $key): ?int {
  120. $a = parent::param($key, null);
  121. return is_numeric($a) ? (int)$a : null;
  122. }
  123. /** @param non-empty-string $key */
  124. public function attributeString(string $key): ?string {
  125. $a = parent::param($key, null);
  126. return is_string($a) ? $a : null;
  127. }
  128. /**
  129. * @param non-empty-string $key
  130. * @param array<string,mixed>|mixed|null $value Value, not HTML-encoded
  131. */
  132. public function _attribute(string $key, $value = null): void {
  133. parent::_param($key, $value);
  134. }
  135. }