eBooru/config/danbooru_default_config.rb

745 lines
18 KiB
Ruby
Raw Permalink Normal View History

# frozen_string_literal: true
2010-02-06 16:48:40 -05:00
module Danbooru
class Configuration
# The version of this Danbooru.
def version
"2.1.0"
2010-02-06 16:48:40 -05:00
end
2013-03-19 08:10:10 -04:00
2010-02-06 16:48:40 -05:00
# The name of this Danbooru.
def app_name
"e621"
2010-02-06 16:48:40 -05:00
end
2013-03-19 08:10:10 -04:00
def description
"Find good furry art, fast"
end
2018-04-26 13:24:20 -04:00
def domain
"e621.net"
2018-04-26 13:24:20 -04:00
end
# Force rating:s on this version of the site.
def safe_mode?
false
end
def adult_content?
true
end
# The canonical hostname of the site.
def hostname
Socket.gethostname
end
2013-03-19 08:10:10 -04:00
2010-02-20 18:08:22 -05:00
# Contact email address of the admin.
def contact_email
"management@#{domain}"
2010-02-20 18:08:22 -05:00
end
2013-03-19 08:10:10 -04:00
2019-02-23 11:45:10 -05:00
def takedown_email
"management@#{domain}"
2019-02-23 11:45:10 -05:00
end
# System actions, such as sending automated dmails, will be performed with
# this account. This account must have Moderator privileges.
#
# Run `rake db:seed` to create this account if it doesn't already exist in your install.
def system_user
"auto_moderator"
end
def source_code_url
2023-01-23 14:43:56 -05:00
"https://github.com/e621ng/e621ng"
end
2010-02-08 01:40:39 -05:00
# Stripped of any special characters.
def safe_app_name
app_name.gsub(/[^a-zA-Z0-9_-]/, "_")
end
2013-03-19 08:10:10 -04:00
2010-02-06 16:48:40 -05:00
# The default name to use for anyone who isn't logged in.
def default_guest_name
"Anonymous"
end
2013-03-19 08:10:10 -04:00
def levels
{
"Anonymous" => 0,
"Blocked" => 10,
"Member" => 20,
"Privileged" => 30,
"Former Staff" => 34,
"Janitor" => 35,
"Moderator" => 40,
"Admin" => 50
}
end
# Prevent new users from going above 80k while allowing those currently above
# it to continue adding new favorites with the old limit.
# { 123 => 200_000 }
def legacy_favorite_limit
{}
end
# Set the default level, permissions, and other settings for new users here.
def customize_new_user(user)
user.blacklisted_tags = default_blacklist.join("\n")
user.comment_threshold = -10
user.enable_auto_complete = true
user.enable_keyboard_navigation = true
user.per_page = records_per_page
user.show_post_statistics = true
user.style_usernames = true
end
def default_blacklist
[]
2010-02-06 16:48:40 -05:00
end
2013-03-19 08:10:10 -04:00
def safeblocked_tags
[]
end
# This allows using statically linked copies of ffmpeg in non default locations. Not universally supported across
# the codebase at this time.
def ffmpeg_path
"/usr/bin/ffmpeg"
end
2010-02-06 16:48:40 -05:00
# Thumbnail size
def small_image_width
150
end
2013-03-19 08:10:10 -04:00
2010-02-08 01:40:39 -05:00
# Large resize image width. Set to nil to disable.
2010-02-06 16:48:40 -05:00
def large_image_width
2013-01-06 14:54:01 -05:00
850
2010-02-06 16:48:40 -05:00
end
2013-03-19 08:10:10 -04:00
def large_image_prefix
"sample-"
end
2013-03-19 08:10:10 -04:00
def protected_path_prefix
"deleted"
end
def protected_file_secret
"abc123"
end
2020-05-10 18:07:43 -04:00
def replacement_path_prefix
"replacements"
end
def replacement_file_secret
"abc123"
end
def deleted_preview_url
"/images/deleted-preview.png"
end
2010-02-06 23:11:26 -05:00
# When calculating statistics based on the posts table, gather this many posts to sample from.
def post_sample_size
300
end
2013-03-19 08:10:10 -04:00
2010-02-06 16:48:40 -05:00
# List of memcached servers
def memcached_servers
2016-10-17 18:53:37 -04:00
%w(127.0.0.1:11211)
2010-02-06 16:48:40 -05:00
end
2013-03-19 08:10:10 -04:00
def alias_implication_forum_category
1
end
2010-02-06 16:48:40 -05:00
# After a post receives this many comments, new comments will no longer bump the post in comment/index.
def comment_threshold
40
end
2013-03-19 08:10:10 -04:00
def disable_throttles?
false
end
def disable_age_checks?
false
end
def disable_cache_store?
false
end
2010-02-06 16:48:40 -05:00
# Members cannot post more than X comments in an hour.
def member_comment_limit
2019-06-27 11:33:02 -04:00
15
end
2019-09-04 00:56:41 -04:00
def comment_vote_limit
10
end
def post_vote_limit
3_000
end
def dmail_minute_limit
1
end
2019-06-27 11:33:02 -04:00
def dmail_limit
10
2019-06-27 11:33:02 -04:00
end
def dmail_day_limit
50
2019-06-27 11:33:02 -04:00
end
def tag_suggestion_limit
15
end
2021-03-04 23:33:56 -05:00
def forum_vote_limit
50
2021-03-04 23:33:56 -05:00
end
2019-06-27 11:33:02 -04:00
# Blips created in the last hour
def blip_limit
25
end
# Artists creator or edited in the last hour
def artist_edit_limit
25
end
# Wiki pages created or edited in the last hour
def wiki_edit_limit
60
end
# Notes applied to posts edited or created in the last hour
def note_edit_limit
50
end
# Pools created in the last hour
def pool_limit
2010-02-06 16:48:40 -05:00
2
end
2019-06-27 11:33:02 -04:00
# Pools created or edited in the last hour
def pool_edit_limit
10
end
# Pools that you can edit the posts for in the last hour
def pool_post_edit_limit
30
end
# Members cannot create more than X post versions in an hour.
def post_edit_limit
150
end
2019-09-04 02:06:30 -04:00
def post_flag_limit
20
2019-09-04 02:06:30 -04:00
end
2019-09-04 00:56:41 -04:00
# Flat limit that applies to all users, regardless of level
def hourly_upload_limit
30
end
2019-09-04 02:06:30 -04:00
def ticket_limit
30
end
# Members cannot change the category of pools with more than this many posts.
def pool_category_change_limit
2019-09-04 00:56:41 -04:00
30
end
2020-11-29 01:01:40 -05:00
def post_replacement_per_day_limit
2
end
def post_replacement_per_post_limit
5
end
2020-04-12 22:08:33 -04:00
def remember_key
"abc123"
end
2019-04-03 21:56:47 -04:00
def tag_type_change_cutoff
100
end
2013-03-19 08:10:10 -04:00
2010-02-06 16:48:40 -05:00
# Users cannot search for more than X regular tags at a time.
def tag_query_limit
40
end
2013-03-19 08:10:10 -04:00
# Return true if the given tag shouldn't count against the user's tag search limit.
def is_unlimited_tag?(tag)
!!(tag =~ /\A(-?status:deleted|rating:s.*|limit:.+)\z/i)
end
2011-06-24 18:22:54 -04:00
# After this many pages, the paginator will switch to sequential mode.
def max_numbered_pages
750
2011-06-24 18:22:54 -04:00
end
def blip_max_size
1_000
end
def comment_max_size
10_000
end
def dmail_max_size
50_000
end
def forum_post_max_size
50_000
end
def note_max_size
1_000
end
def pool_descr_max_size
10_000
end
2024-10-30 19:52:53 -04:00
def post_title_max_size
128
end
def post_descr_max_size
50_000
end
def post_trasc_max_size
50_000
end
def ticket_max_size
5_000
end
def user_about_max_size
50_000
end
def wiki_page_max_size
250_000
end
2013-03-19 08:10:10 -04:00
def user_feedback_max_size
20_000
end
def pool_post_limit(_user)
1_000
end
def set_post_limit(_user) # rubocop:disable Naming/AccessorMethodName
10_000
end
2020-02-02 16:50:20 -05:00
def discord_site
end
def discord_secret
end
# Maximum size of an upload. If you change this, you must also change
# `client_max_body_size` in your nginx.conf.
2010-02-08 01:40:39 -05:00
def max_file_size
100.megabytes
end
def max_file_sizes
{
'jpg' => 100.megabytes,
'png' => 100.megabytes,
'gif' => 20.megabytes,
'webm' => 100.megabytes,
'mp4' => 100.megabytes
}
end
def max_apng_file_size
20.megabytes
end
# Measured in seconds
def max_video_duration
2019-10-30 12:33:57 -04:00
3600
2010-02-08 01:40:39 -05:00
end
2013-03-19 08:10:10 -04:00
# Maximum resolution (width * height) of an upload. Default: 441 megapixels (21000x21000 pixels).
def max_image_resolution
15000 * 15000
end
# Maximum width of an upload.
def max_image_width
15000
end
# Maximum height of an upload.
def max_image_height
15000
end
def max_tags_per_post
2000
end
2018-01-28 20:57:45 -05:00
# Permanently redirect all HTTP requests to HTTPS.
#
# https://en.wikipedia.org/wiki/HTTP_Strict_Transport_Security
# http://api.rubyonrails.org/classes/ActionDispatch/SSL.html
def ssl_options
{
redirect: { exclude: ->(request) { request.subdomain == "insecure" } },
hsts: {
expires: 1.year,
preload: true,
subdomains: false,
},
}
end
# The method to use for storing image files.
def storage_manager
# Store files on the local filesystem.
# base_dir - where to store files (default: under public/data)
# base_url - where to serve files from (default: http://#{hostname}/data)
# hierarchical: false - store files in a single directory
# hierarchical: true - store files in a hierarchical directory structure, based on the MD5 hash
StorageManager::Local.new(base_dir: "#{Rails.root}/public/data", hierarchical: true)
# Select the storage method based on the post's id and type (preview, large, or original).
# StorageManager::Hybrid.new do |id, md5, file_ext, type|
# if type.in?([:large, :original]) && id.in?(0..850_000)
2022-04-07 12:23:02 -04:00
# StorageManager::Local.new(base_dir: "/path/to/files", hierarchical: true)
# else
2022-04-07 12:23:02 -04:00
# StorageManager::Local.new(base_dir: "/path/to/files", hierarchical: true)
# end
# end
end
# The method to use for backing up image files.
def backup_storage_manager
# Don't perform any backups.
StorageManager::Null.new
# Backup files to /mnt/backup on the local filesystem.
# StorageManager::Local.new(base_dir: "/mnt/backup", hierarchical: false)
end
2018-01-03 14:42:08 -05:00
2010-03-11 19:42:04 -05:00
# If enabled, users must verify their email addresses.
def enable_email_verification?
false
2010-03-11 19:42:04 -05:00
end
2013-03-19 08:10:10 -04:00
2019-08-17 12:00:26 -04:00
def enable_signups?
true
end
def flag_reasons
[
{
name: "uploading_guidelines",
reason: "Does not meet the [[uploading_guidelines|uploading guidelines]]",
text: "This post fails to meet the site's standards, be it for artistic worth, image quality, relevancy, or something else.\nKeep in mind that your personal preferences have no bearing on this. If you find the content of a post objectionable, simply [[e621:blacklist|blacklist]] it.",
},
{
name: "young_human",
reason: "Young [[human]]-[[humanoid|like]] character in an explicit situation",
text: "Posts featuring human and human-like characters depicted in a sexual or explicit nude way, are not acceptable on this site.",
},
{
name: "dnp_artist",
reason: "The artist of this post is on the \"avoid posting list\":/static/avoid_posting",
text: "Certain artists have requested that their work is not to be published on this site, and were granted [[avoid_posting|Do Not Post]] status.\nSometimes, that status comes with conditions; see [[conditional_dnp]] for more information",
},
{
name: "pay_content",
reason: "Paysite, commercial, or subscription content",
text: "We do not host paysite or commercial content of any kind. This includes Patreon leaks, reposts from piracy websites, and so on.",
},
{
name: "trace",
reason: "Trace of another artist's work",
text: "Images traced from other artists' artwork are not accepted on this site. Referencing from something is fine, but outright copying someone else's work is not.\nPlease, leave more information in the comments, or simply add the original artwork as the posts's parent if it's hosted on this site.",
},
{
name: "previously_deleted",
reason: "Previously deleted",
text: "Posts usually get removed for a good reason, and reuploading of deleted content is not acceptable.\nPlease, leave more information in the comments, or simply add the original post as this post's parent.",
},
{
name: "real_porn",
reason: "Real-life pornography",
text: "Posts featuring real-life pornography are not acceptable on this site. No exceptions.\nNote that images featuring non-erotic photographs are acceptable.",
},
{
name: "corrupt",
reason: "File is either corrupted, broken, or otherwise does not work",
text: "Something about this post does not work quite right. This may be a broken video, or a corrupted image.\nEither way, in order to avoid confusion, please explain the situation in the comments.",
},
{
name: "inferior",
reason: "Duplicate or inferior version of another post",
text: "A superior version of this post already exists on the site.\nThis may include images with better visual quality (larger, less compressed), but may also feature \"fixed\" versions, with visual mistakes accounted for by the artist.\nNote that edits and alternate versions do not fall under this category.",
parent: true,
},
]
end
def deletion_reasons
[
"Inferior version/duplicate of post #%PARENT_ID%",
"Previously deleted (post #%PARENT_ID%)",
"Excessive same base image set",
"Colored base",
"Advertisement",
"Underage artist",
"",
"Does not meet minimum quality standards (Artistic)",
"Does not meet minimum quality standards (Resolution)",
"Does not meet minimum quality standards (Compression)",
2023-04-02 17:15:51 -04:00
"Does not meet minimum quality standards (Trivial or low quality edit)",
"Does not meet minimum quality standards (Bad digitization of traditional media)",
"Does not meet minimum quality standards (Photo)",
"Does not meet minimum quality standards (%OTHER_ID%)",
"Broken/corrupted file",
"JPG resaved as PNG",
"",
"Irrelevant to site (Human only)",
"Irrelevant to site (Screencap)",
"Irrelevant to site (Zero pictured)",
"Irrelevant to site (AI assisted/generated)",
"Irrelevant to site (%OTHER_ID%)",
"Young [[human]]-[[humanoid|like]] character in an explicit situation",
"",
"Paysite/commercial content",
"Traced artwork",
"Traced artwork (post #%PARENT_ID%)",
"Takedown #%OTHER_ID%",
"The artist of this post is on the \"avoid posting list\":/static/avoid_posting",
"[[conditional_dnp|Conditional DNP]] (Only the artist is allowed to post)",
"[[conditional_dnp|Conditional DNP]] (%OTHER_ID%)",
]
end
# Any custom code you want to insert into the default layout without
# having to modify the templates.
def custom_html_header_content
nil
end
2013-03-19 08:10:10 -04:00
def flag_notice_wiki_page
"help:flag_notice"
end
def replacement_notice_wiki_page
"help:replacement_notice"
end
# The number of records displayed per page. Posts use `user.per_page` which is configurable by the user
def records_per_page
75
2010-03-17 19:20:44 -04:00
end
2010-10-08 18:42:26 -04:00
def is_post_restricted?(post)
false
2010-10-08 18:42:26 -04:00
end
2013-03-19 08:10:10 -04:00
# TODO: Investigate what this does and where it is used.
2010-10-08 18:42:26 -04:00
def is_user_restricted?(user)
!user.is_privileged?
2010-10-08 18:42:26 -04:00
end
2013-03-19 08:10:10 -04:00
2010-10-08 18:42:26 -04:00
def can_user_see_post?(user, post)
return false if post.is_deleted? && !user.is_janitor?
if is_user_restricted?(user) && is_post_restricted?(post)
2010-10-08 18:42:26 -04:00
false
else
true
end
end
2013-03-19 08:10:10 -04:00
def user_needs_login_for_post?(post)
false
end
2010-10-08 18:42:26 -04:00
def select_posts_visible_to_user(user, posts)
2011-11-11 17:50:26 -05:00
posts.select {|x| can_user_see_post?(user, x)}
2010-10-08 18:42:26 -04:00
end
2013-03-19 08:10:10 -04:00
def enable_dimension_autotagging?
2013-03-12 17:01:52 -04:00
true
end
2014-03-21 19:43:02 -04:00
# The default headers to be sent with outgoing http requests. Some external
# services will fail if you don't set a valid User-Agent.
def http_headers
{
user_agent: "#{safe_app_name}/#{version}",
}
end
# https://lostisland.github.io/faraday/#/customization/connection-options
def faraday_options
{
request: {
timeout: 10,
open_timeout: 10,
},
headers: http_headers,
}
2017-06-29 21:07:07 -04:00
end
# you should override this
def email_key
"zDMSATq0W3hmA5p3rKTgD"
end
2019-09-13 15:46:44 -04:00
def mailgun_api_key
''
end
def mailgun_domain
''
end
def mail_from_addr
'noreply@localhost'
end
# disable this for tests
def enable_sock_puppet_validation?
true
end
def iqdb_server
end
def opensearch_host
end
# Use a recaptcha on the signup page to protect against spambots creating new accounts.
# https://developers.google.com/recaptcha/intro
def enable_recaptcha?
Rails.env.production? && Danbooru.config.recaptcha_site_key.present? && Danbooru.config.recaptcha_secret_key.present?
end
def recaptcha_site_key
end
def recaptcha_secret_key
end
2018-07-09 13:06:20 -04:00
def enable_image_cropping?
2018-07-09 13:06:20 -04:00
true
end
2018-11-12 21:02:49 -05:00
def redis_url
end
def bypass_upload_whitelist?(user)
user.is_admin?
end
2019-08-23 15:48:18 -04:00
def ads_enabled?
false
end
# These tags will be sent to the revive server to do filtering on
def ads_keyword_tags
[]
end
2019-10-12 15:42:13 -04:00
def ads_zone_desktop
{zone: nil, revive_id: nil, checksum: nil}
2019-08-23 15:48:18 -04:00
end
2019-10-12 15:42:13 -04:00
def ads_zone_mobile
{zone: nil, revive_id: nil, checksum: nil}
2019-08-23 15:48:18 -04:00
end
2020-03-18 23:18:21 -04:00
# Additional video samples will be generated in these dimensions if it makes sense to do so
# They will be available as additional scale options on applicable posts in the order they appear here
def video_rescales
{'720p' => [1280, 720], '480p' => [640, 480]}
end
def image_rescales
[]
end
2021-07-18 11:50:57 -04:00
def enable_visitor_metrics?
2022-12-17 13:24:15 -05:00
false
end
def janitor_reports_discord_webhook_url
nil
end
2024-01-09 11:24:48 -05:00
def moderator_stats_discord_webhook_url
nil
end
2024-01-21 11:28:46 -05:00
def aibur_stats_discord_webhook_url
nil
end
2025-01-18 13:34:24 -05:00
def no_results_message
"Nobody here but us chicken!"
end
2010-02-06 16:48:40 -05:00
end
class EnvironmentConfiguration
def custom_configuration
@custom_configuration ||= CustomConfiguration.new
end
def env_to_boolean(method, var)
is_boolean = method.to_s.end_with? "?"
return true if is_boolean && var.truthy?
return false if is_boolean && var.falsy?
var
end
def method_missing(method, *)
var = ENV["DANBOORU_#{method.to_s.upcase.chomp("?")}"]
if var.present?
env_to_boolean(method, var)
else
custom_configuration.send(method, *)
end
end
end
def config
@configuration ||= EnvironmentConfiguration.new
end
module_function :config
2010-02-06 16:48:40 -05:00
end