forked from GNUsocial/gnu-social
		
	[FORMATTING][DEFAULTS] Fix formatting and remove redundant config defaults
This commit is contained in:
		
							
								
								
									
										2
									
								
								.php_cs
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								.php_cs
									
									
									
									
									
								
							| @@ -273,6 +273,6 @@ return PhpCsFixer\Config::create() | |||||||
|         ->exclude('var') |         ->exclude('var') | ||||||
|         ->exclude('docker') |         ->exclude('docker') | ||||||
|         ->exclude('src/Entity') |         ->exclude('src/Entity') | ||||||
|         ->notPath('src/Core/DefaultSettings.php') |         ->notPath('src/Core/DB/DefaultSettings.php') | ||||||
|         ->in(__DIR__) |         ->in(__DIR__) | ||||||
|     ); |     ); | ||||||
|   | |||||||
| @@ -41,8 +41,10 @@ abstract class DefaultSettings | |||||||
|     public static array $defaults; |     public static array $defaults; | ||||||
|     public static function setDefaults() |     public static function setDefaults() | ||||||
|     { |     { | ||||||
|         self::$defaults = ['site' => ['name' => $_ENV['SOCIAL_SITENAME'] ?? 'Another social instance', |         self::$defaults = [ | ||||||
|             'server'                         => $_ENV['SOCIAL_DOMAIN'] ?? 'localhost', |             'site' => [ | ||||||
|  |                 'name'                 => $_ENV['SOCIAL_SITENAME'] ?? 'Another social instance', | ||||||
|  |                 'server'               => $_ENV['SOCIAL_DOMAIN'], | ||||||
|                 'notice'               => null,  // site wide notice text |                 'notice'               => null,  // site wide notice text | ||||||
|                 'theme'                => 'default', |                 'theme'                => 'default', | ||||||
|                 'logo'                 => null, |                 'logo'                 => null, | ||||||
| @@ -55,55 +57,35 @@ abstract class DefaultSettings | |||||||
|                 'brought_by'           => null, |                 'brought_by'           => null, | ||||||
|                 'brought_by_url'       => null, |                 'brought_by_url'       => null, | ||||||
|                 'closed'               => false, |                 'closed'               => false, | ||||||
|             'invite_only'                    => true, |                 'register_type'        => 'public', | ||||||
|             'private'                        => false, |                 'nickname'             => $_ENV['SOCIAL_ADMIN_NICK'], | ||||||
|                 'ssl'                  => 'always', |                 'ssl'                  => 'always', | ||||||
|                 'ssl_proxy'            => false, // set to true to force GNU social to think it is HTTPS (i.e. using reverse proxy to enable it) |                 'ssl_proxy'            => false, // set to true to force GNU social to think it is HTTPS (i.e. using reverse proxy to enable it) | ||||||
|                 'duplicate_time_limit' => 60,    // default for same person saying the same thing |                 'duplicate_time_limit' => 60,    // default for same person saying the same thing | ||||||
|                 'text_limit'           => 1000,  // in chars; 0 == no limit |                 'text_limit'           => 1000,  // in chars; 0 == no limit | ||||||
|             'x-static-delivery'              => null, |                 'x_static_delivery'    => null, | ||||||
|             ], |             ], | ||||||
|             'security' => ['hash_algos' => ['sha1', 'sha256', 'sha512']],  // set to null for anything that hash_hmac() can handle (and is in hash_algos()) |             'security' => ['hash_algos' => ['sha1', 'sha256', 'sha512']],  // set to null for anything that hash_hmac() can handle (and is in hash_algos()) | ||||||
|             'db'       => ['mirror' => null],                              // TODO implement |             'db'       => ['mirror' => null],                              // TODO implement | ||||||
|             'fix'      => ['fancy_urls' => true,  // makes sure aliases in WebFinger etc. are not f'd by index.php/ URLs |             'cache'    => [ | ||||||
|                 'http'                  => true,         // set this to true if you have upgraded your site from http=>https |                 'notice_max_count' => 128, | ||||||
|             ], |             ], | ||||||
|             'queue' => ['enabled'       => true, |             'avatar' => [ | ||||||
|                 'daemon'                => false, // Use queuedaemon. Default to false |                 'server'      => null, | ||||||
|                 'threads'               => null,  // an empty value here uses processor count to determine |  | ||||||
|                 'subsystem'             => false,  // default to database, or 'stomp' |  | ||||||
|                 'basename'              => '/queue/gnusocial/', |  | ||||||
|                 'control_channel'       => '/topic/gnusocial/control', // broadcasts to all queue daemons |  | ||||||
|                 'monitor'               => null,  // URL to monitor ping endpoint (work in progress) |  | ||||||
|                 'soft_limit'            => '90%', // total size or % of memory_limit at which to restart queue threads gracefully |  | ||||||
|                 'spawn_delay'           => 1,     // Wait at least N seconds between (re)spawns of child processes to avoid slamming the queue server with subscription startup |  | ||||||
|                 'debug_memory'          => false, // true to spit memory usage to log |  | ||||||
|                 'stomp_server'          => null, |  | ||||||
|                 'stomp_username'        => null, |  | ||||||
|                 'stomp_password'        => null, |  | ||||||
|                 'stomp_persistent'      => true,  // keep items across queue server restart, if persistence is enabled |  | ||||||
|                 'stomp_transactions'    => true,  // use STOMP transactions to aid in detecting failures (supported by ActiveMQ, but not by all) |  | ||||||
|                 'stomp_acks'            => true,  // send acknowledgements after successful processing (supported by ActiveMQ, but not by all) |  | ||||||
|                 'stomp_manual_failover' => true,  // if multiple servers are listed, treat them as separate (enqueue on one randomly, listen on all) |  | ||||||
|                 'max_retries'           => 10,    // drop messages after N failed attempts to process (Stomp) |  | ||||||
|                 'dead_letter_dir'       => false, // set to directory to save dropped messages into (Stomp) |  | ||||||
|             ], |  | ||||||
|             'avatar' => ['server' => null, |  | ||||||
|                 'url_base'        => '/avatar/', |  | ||||||
|                 'ssl'         => null, |                 'ssl'         => null, | ||||||
|                 'dir'         => INSTALLDIR . '/file/avatar/', |                 'dir'         => INSTALLDIR . '/file/avatar/', | ||||||
|                 'max_size_px' => 300, |                 'max_size_px' => 300, | ||||||
|             ], |             ], | ||||||
|             'javascript' => ['server' => null, |             'javascript' => [ | ||||||
|                 'url_base'            => '/js/', |                 'server' => null, | ||||||
|                 'ssl'    => null, |                 'ssl'    => null, | ||||||
|                 'bust_frames'         => true, |  | ||||||
|             ], |             ], | ||||||
|             'attachments' => ['server' => null, |             'attachments' => [ | ||||||
|                 'url_base'             => '/file/', |                 'server'    => null, | ||||||
|                 'ssl'       => null, |                 'ssl'       => null, | ||||||
|                 'dir'       => INSTALLDIR . '/file/uploads/', |                 'dir'       => INSTALLDIR . '/file/uploads/', | ||||||
|                 'supported'            => ['application/vnd.oasis.opendocument.chart' => 'odc', |                 'supported' => [ | ||||||
|  |                     'application/vnd.oasis.opendocument.chart'                 => 'odc', | ||||||
|                     'application/vnd.oasis.opendocument.formula'               => 'odf', |                     'application/vnd.oasis.opendocument.formula'               => 'odf', | ||||||
|                     'application/vnd.oasis.opendocument.graphics'              => 'odg', |                     'application/vnd.oasis.opendocument.graphics'              => 'odg', | ||||||
|                     'application/vnd.oasis.opendocument.graphics-template'     => 'otg', |                     'application/vnd.oasis.opendocument.graphics-template'     => 'otg', | ||||||
| @@ -146,11 +128,10 @@ abstract class DefaultSettings | |||||||
|                 'show_thumbs'   => true,    // show thumbnails in notice lists for uploaded images, and photos and videos linked remotely that provide oEmbed info |                 'show_thumbs'   => true,    // show thumbnails in notice lists for uploaded images, and photos and videos linked remotely that provide oEmbed info | ||||||
|                 'process_links' => true,    // check linked resources for embeddable photos and videos; this will hit referenced external web sites when processing new messages. |                 'process_links' => true,    // check linked resources for embeddable photos and videos; this will hit referenced external web sites when processing new messages. | ||||||
|                 'ext_blacklist' => [], |                 'ext_blacklist' => [], | ||||||
|                 'filename'      => 'hash', |  | ||||||
|                 'memory_limit'  => '1024M', // PHP memory limit to use temporarily when handling images |                 'memory_limit'  => '1024M', // PHP memory limit to use temporarily when handling images | ||||||
|             ], |             ], | ||||||
|             'thumbnail' => ['server' => null, |             'thumbnail' => [ | ||||||
|                 'url_base'           => '/thumb/', |                 'server'      => null, | ||||||
|                 'ssl'         => null, |                 'ssl'         => null, | ||||||
|                 'dir'         => INSTALLDIR . '/file/thumbnails/',  // falls back to File::path('thumb') (equivalent to ['attachments']['dir'] .  '/thumb/') |                 'dir'         => INSTALLDIR . '/file/thumbnails/',  // falls back to File::path('thumb') (equivalent to ['attachments']['dir'] .  '/thumb/') | ||||||
|                 'crop'        => false, // overridden to true if thumb height === null |                 'crop'        => false, // overridden to true if thumb height === null | ||||||
| @@ -160,32 +141,30 @@ abstract class DefaultSettings | |||||||
|                 'upscale'     => false, |                 'upscale'     => false, | ||||||
|                 'animated'    => false, // null="UseFileAsThumbnail", false="can use still frame". true="allow animated" |                 'animated'    => false, // null="UseFileAsThumbnail", false="can use still frame". true="allow animated" | ||||||
|             ], |             ], | ||||||
|             'theme' => ['server' => null, |             'theme' => [ | ||||||
|                 'url_base'       => '/theme/', |                 'server' => null, | ||||||
|                 'ssl'    => null, |                 'ssl'    => null, | ||||||
|                 'dir'    => INSTALLDIR . '/public/theme/', |                 'dir'    => INSTALLDIR . '/public/theme/', | ||||||
|             ], |             ], | ||||||
|             'plugins' => ['server' => null, |             'plugins' => [ | ||||||
|                 'url_base'         => null, |                 'server'      => null, | ||||||
|                 'ssl'         => null, |                 'ssl'         => null, | ||||||
|                 'core'        => [], |                 'core'        => [], | ||||||
|                 'default'     => [], |                 'default'     => [], | ||||||
|                 'locale_path' => null, // Set to a path to use *instead of* each plugin's own locale subdirectories |                 'locale_path' => null, // Set to a path to use *instead of* each plugin's own locale subdirectories | ||||||
|             ], |             ], | ||||||
|             'license' => ['type' => 'cc',            // can be 'cc', 'allrightsreserved', 'private' |             'license' => [ | ||||||
|  |                 'type'  => 'cc',  // can be 'cc', 'allrightsreserved', 'private' | ||||||
|                 'owner' => null,  // can be name of content owner e.g. for enterprise |                 'owner' => null,  // can be name of content owner e.g. for enterprise | ||||||
|                 'url'   => 'https://creativecommons.org/licenses/by/4.0/', |                 'url'   => 'https://creativecommons.org/licenses/by/4.0/', | ||||||
|                 'title' => 'Creative Commons Attribution 4.0', |                 'title' => 'Creative Commons Attribution 4.0', | ||||||
|                 'image' => '/theme/licenses/cc_by_4.0.png', |                 'image' => '/theme/licenses/cc_by_4.0.png', | ||||||
|             ], |             ], | ||||||
|             'mail' => ['backend' => 'mail', |             'nickname' => [ | ||||||
|                 'params'         => null, |                 'blacklist' => ['doc', 'main', 'avatar', 'theme'], | ||||||
|                 'domain_check'   => true, |  | ||||||
|             ], |  | ||||||
|             'nickname' => ['blacklist' => ['doc', 'main', 'avatar', 'theme'], |  | ||||||
|                 'featured'  => [], |                 'featured'  => [], | ||||||
|             ], |             ], | ||||||
|             'profile' => ['banned'     => [], |             'profile' => [ | ||||||
|                 'bio_text_limit'       => null, |                 'bio_text_limit'       => null, | ||||||
|                 'allow_nick_change'    => false, |                 'allow_nick_change'    => false, | ||||||
|                 'allow_private_stream' => true,  // whether to allow setting stream to private ("only followers can read") |                 'allow_private_stream' => true,  // whether to allow setting stream to private ("only followers can read") | ||||||
| @@ -195,73 +174,66 @@ abstract class DefaultSettings | |||||||
|                 'move'                 => false, |                 'move'                 => false, | ||||||
|             ], |             ], | ||||||
|             'image'  => ['jpegquality' => 85], |             'image'  => ['jpegquality' => 85], | ||||||
|             'theme_upload' => ['enabled' => true, |  | ||||||
|                 'formats'                => ['zip', 'tar', 'gz', 'tar.gz'], ], |  | ||||||
|             'foaf'   => ['mbox_sha1sum' => false], |             'foaf'   => ['mbox_sha1sum' => false], | ||||||
|             'public' => ['local_only' => false, |             'public' => [ | ||||||
|  |                 'local_only'      => false, | ||||||
|                 'blacklist'       => [], |                 'blacklist'       => [], | ||||||
|                 'exclude_sources' => [], |                 'exclude_sources' => [], | ||||||
|             ], |             ], | ||||||
|             'throttle' => ['enabled' => true, // whether to throttle posting dents |  | ||||||
|                 'count'              => 20,    // number of allowed messages in timespan |  | ||||||
|                 'timespan'           => 600,   // timespan for throttling |  | ||||||
|             ], |  | ||||||
|             'invite' => ['enabled' => true], |             'invite' => ['enabled' => true], | ||||||
|             'tag'    => ['dropoff' => 86400 * 10, // controls weighting based on age |             'tag'    => [ | ||||||
|  |                 'dropoff' => 86400 * 10, // controls weighting based on age | ||||||
|                 'cutoff'  => 86400 * 90, // only look at notices posted in last 90 days |                 'cutoff'  => 86400 * 90, // only look at notices posted in last 90 days | ||||||
|             ], |             ], | ||||||
|             'popular' => ['dropoff' => 86400 * 10, // controls weighting based on age |             'popular' => [ | ||||||
|  |                 'dropoff' => 86400 * 10, // controls weighting based on age | ||||||
|                 'cutoff'  => 86400 * 90, // only look at notices favorited in last 90 days |                 'cutoff'  => 86400 * 90, // only look at notices favorited in last 90 days | ||||||
|             ], |             ], | ||||||
|             'daemon' => ['piddir' => sys_get_temp_dir(), |             'new_users' => [ | ||||||
|                 'user'            => false, |                 'default_subscriptions' => null, | ||||||
|                 'group'           => false, |  | ||||||
|             ], |  | ||||||
|             'ping' => ['notify' => [], |  | ||||||
|                 'timeout'       => 2, |  | ||||||
|             ], |  | ||||||
|             'new_users' => ['default_subscriptions' => null, |  | ||||||
|                 'welcome_user'          => null, |                 'welcome_user'          => null, | ||||||
|             ], |             ], | ||||||
|             'linkify' => // "bare" below means "without schema", like domain.com vs. https://domain.com |             'linkify' => [               // "bare" below means "without schema", like domain.com vs. https://domain.com | ||||||
|                 ['bare_domains'    => false, // convert domain.com to <a href="http://domain.com/" ...>domain.com</a> ? |                 'bare_domains' => false, // convert domain.com to <a href="http://domain.com/" ...>domain.com</a> ? | ||||||
|                     'linkify_ipv4' => false, // convert IPv4 addresses to hyperlinks? |                 'ipv4'         => false, // convert IPv4 addresses to hyperlinks? | ||||||
|                     'linkify_ipv6' => false, // convert IPv6 addresses to hyperlinks? |                 'ipv6'         => false, // convert IPv6 addresses to hyperlinks? | ||||||
|             ], |             ], | ||||||
|             'group' => ['max_aliases' => 3, |             'group' => [ | ||||||
|  |                 'max_aliases'       => 3, | ||||||
|                 'description_limit' => null, |                 'description_limit' => null, | ||||||
|             ], |             ], | ||||||
|             'people_tag' => ['max_tags' => 100,             // maximum number of tags a user can create. |             'people_tag' => [ | ||||||
|  |                 'max_tags'          => 100,  // maximum number of tags a user can create. | ||||||
|                 'max_people'        => 500,  // maximum no. of people with the same tag by the same user |                 'max_people'        => 500,  // maximum no. of people with the same tag by the same user | ||||||
|                 'allow_tagging'         => ['local' => true, 'remote' => true], // equivalent to array() |                 'allow_tagging'     => ['local' => true, 'remote' => true], | ||||||
|                 'description_limit' => null, |                 'description_limit' => null, | ||||||
|             ], |             ], | ||||||
|             'search'      => ['type' => 'like'], |             'search'      => ['type' => 'like'], | ||||||
|             'html_filter' => ['tags' => ['img', 'video', 'audio', 'script']], |             'html_filter' => ['tags' => ['img', 'video', 'audio', 'script']], | ||||||
|             'notice'      => ['content_limit' => null, |             'notice'      => [ | ||||||
|  |                 'content_limit' => null, | ||||||
|                 'allow_private' => false, // whether to allow users to "check the padlock" to publish notices available for their subscribers. |                 'allow_private' => false, // whether to allow users to "check the padlock" to publish notices available for their subscribers. | ||||||
|                 'hide_banned'                 => true,  // Whether to hide silenced users from timelines |                 'hide_banned'   => true,  // whether to hide silenced users from timelines | ||||||
|             ], |             ], | ||||||
|             'message'    => ['content_limit' => null], |             'message'    => ['content_limit' => null], | ||||||
|             'location'   => ['share' => 'user'], |             'location'   => ['share' => 'user'], | ||||||
|             'admin'       => ['panels' => ['site', 'user', 'paths', 'access', 'sessions', 'sitenotice', 'license', 'plugins']], |             'robots_txt' => [ | ||||||
|             'single_user' => ['enabled' => $_ENV['SOCIAL_SITE_PROFILE'] ?? '' == 'single_user', |                 'crawl_delay' => 0, | ||||||
|                 'nickname'              => null, |  | ||||||
|             ], |  | ||||||
|             'robots_txt' => ['crawl_delay' => 0, |  | ||||||
|                 'disallow'    => ['main', 'settings', 'admin', 'search', 'message'], |                 'disallow'    => ['main', 'settings', 'admin', 'search', 'message'], | ||||||
|             ], |             ], | ||||||
|             'nofollow' => ['subscribers' => true, |             'nofollow' => [ | ||||||
|  |                 'subscribers' => true, | ||||||
|                 'members'     => true, |                 'members'     => true, | ||||||
|                 'peopletag'   => true, |                 'peopletag'   => true, | ||||||
|                 'external'    => 'sometimes', // Options: 'sometimes', 'never', default = 'sometimes' |                 'external'    => 'sometimes', // Options: 'sometimes', 'never', default = 'sometimes' | ||||||
|             ], |             ], | ||||||
|             'url_shortener' => ['service' => 'internal', |             'url_shortener' => [ | ||||||
|  |                 'service'           => 'internal', | ||||||
|                 'max_url_length'    => 100, |                 'max_url_length'    => 100, | ||||||
|                 'max_notice_length' => null, |                 'max_notice_length' => null, | ||||||
|             ], |             ], | ||||||
|             'http' => // HTTP client settings when contacting other sites |             'http' => [ // HTTP client settings when contacting other sites | ||||||
|                ['ssl_ca_file'          => '/docker/certbot/files/live/', |                 'ssl_ca_file'       => '/docker/certbot/files/live/', | ||||||
|                 'timeout'           => (int) (ini_get('default_socket_timeout')),   // effectively should be this by default already, but this makes it more explicitly configurable for you users .) |                 'timeout'           => (int) (ini_get('default_socket_timeout')),   // effectively should be this by default already, but this makes it more explicitly configurable for you users .) | ||||||
|                 'proxy_host'        => null, |                 'proxy_host'        => null, | ||||||
|                 'proxy_port'        => null, |                 'proxy_port'        => null, | ||||||
| @@ -270,8 +242,6 @@ abstract class DefaultSettings | |||||||
|                 'proxy_auth_scheme' => null, |                 'proxy_auth_scheme' => null, | ||||||
|             ], |             ], | ||||||
|             'discovery' => ['CORS' => false], // Allow Cross-Origin Resource Sharing for service discovery (host-meta, XRD, etc.) |             'discovery' => ['CORS' => false], // Allow Cross-Origin Resource Sharing for service discovery (host-meta, XRD, etc.) | ||||||
|             'performance'   => ['high' => false], // disable some features for higher performance; default false |  | ||||||
|             'login_command' => ['enabled' => false], |  | ||||||
|         ]; |         ]; | ||||||
|  |  | ||||||
|         self::loadDefaults($_ENV['APP_ENV'] == 'prod'); |         self::loadDefaults($_ENV['APP_ENV'] == 'prod'); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user