2016-11-15 14:56:03 -08:00
---
2016-02-20 13:53:20 -08:00
en :
2016-11-15 14:56:03 -08:00
about :
2021-04-21 09:31:24 -07:00
about_hashtag_html : These are public posts tagged with <strong>#%{hashtag}</strong>. You can interact with them if you have an account anywhere in the fediverse.
2019-10-08 13:08:55 -07:00
about_mastodon_html: 'The social network of the future : No ads, no corporate surveillance, ethical design, and decentralization! Own your data with Mastodon!'
2017-07-11 06:27:59 -07:00
about_this : About
2019-03-12 09:34:00 -07:00
active_count_after : active
active_footnote : Monthly Active Users (MAU)
2018-04-03 16:11:26 -07:00
administered_by : 'Administered by:'
2018-07-28 10:25:33 -07:00
api : API
2018-08-18 16:17:44 -07:00
apps : Mobile apps
2019-03-12 09:34:00 -07:00
apps_platforms : Use Mastodon from iOS, Android and other platforms
browse_directory : Browse a profile directory and filter by interests
2019-10-27 04:45:33 -07:00
browse_local_posts : Browse a live stream of public posts from this server
2019-03-12 09:34:00 -07:00
browse_public_posts : Browse a live stream of public posts on Mastodon
2017-04-04 18:31:26 -07:00
contact : Contact
2017-07-24 06:09:08 -07:00
contact_missing : Not set
contact_unavailable : N /A
2019-03-12 09:34:00 -07:00
discover_users : Discover users
2018-07-28 10:25:33 -07:00
documentation : Documentation
2019-03-12 09:34:00 -07:00
federation_hint_html : With an account on %{instance} you'll be able to follow people on any Mastodon server and beyond.
get_apps : Try a mobile app
2017-07-11 06:27:59 -07:00
hosted_on : Mastodon hosted on %{domain}
New Crowdin updates (#14197)
* New translations devise.en.yml (Uyghur)
[ci skip]
* New translations doorkeeper.en.yml (Uyghur)
[ci skip]
* New translations en.json (Sorani (Kurdish))
[ci skip]
* New translations en.yml (Sorani (Kurdish))
[ci skip]
* New translations simple_form.en.yml (Sorani (Kurdish))
[ci skip]
* New translations activerecord.en.yml (Sorani (Kurdish))
[ci skip]
* New translations devise.en.yml (Sorani (Kurdish))
[ci skip]
* New translations doorkeeper.en.yml (Sorani (Kurdish))
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Chinese Traditional, Hong Kong)
[ci skip]
* New translations en.yml (Chinese Simplified)
[ci skip]
* New translations simple_form.en.yml (Chinese Simplified)
[ci skip]
* New translations en.yml (Chinese Simplified)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.yml (Persian)
[ci skip]
* New translations en.json (Persian)
[ci skip]
* New translations en.json (Croatian)
[ci skip]
* New translations en.json (Marathi)
[ci skip]
* New translations en.json (Norwegian Nynorsk)
[ci skip]
* New translations en.json (Bengali)
[ci skip]
* New translations en.json (Spanish, Argentina)
[ci skip]
* New translations en.json (Hindi)
[ci skip]
* New translations en.json (Latvian)
[ci skip]
* New translations en.json (Estonian)
[ci skip]
* New translations en.json (Kazakh)
[ci skip]
* New translations en.json (Galician)
[ci skip]
* New translations en.json (Vietnamese)
[ci skip]
* New translations en.json (Urdu (Pakistan))
[ci skip]
* New translations en.json (Chinese Traditional)
[ci skip]
* New translations en.json (Icelandic)
[ci skip]
* New translations en.json (Tamil)
[ci skip]
* New translations en.json (Persian)
[ci skip]
* New translations en.json (Indonesian)
[ci skip]
* New translations en.json (Portuguese, Brazilian)
[ci skip]
* New translations en.json (Ido)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Corsican)
[ci skip]
* New translations en.json (Serbian (Latin))
[ci skip]
* New translations en.json (Uyghur)
[ci skip]
* New translations en.json (Sorani (Kurdish))
[ci skip]
* New translations en.json (Taigi)
[ci skip]
* New translations en.json (Silesian)
[ci skip]
* New translations en.json (Malay)
[ci skip]
* New translations en.json (Welsh)
[ci skip]
* New translations en.json (Esperanto)
[ci skip]
* New translations en.json (Telugu)
[ci skip]
* New translations en.json (Chinese Traditional, Hong Kong)
[ci skip]
* New translations en.json (Asturian)
[ci skip]
* New translations en.json (Kannada)
[ci skip]
* New translations en.json (Breton)
[ci skip]
* New translations en.json (Malayalam)
[ci skip]
* New translations en.json (Catalan)
[ci skip]
* New translations en.json (Bulgarian)
[ci skip]
* New translations en.json (Arabic)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (Czech)
[ci skip]
* New translations en.json (Greek)
[ci skip]
* New translations en.json (Basque)
[ci skip]
* New translations en.json (Danish)
[ci skip]
* New translations en.json (German)
[ci skip]
* New translations en.json (Finnish)
[ci skip]
* New translations en.json (Thai)
[ci skip]
* New translations en.json (Slovenian)
[ci skip]
* New translations en.json (Sardinian)
[ci skip]
* New translations en.json (Romanian)
[ci skip]
* New translations en.json (Occitan)
[ci skip]
* New translations en.json (Chinese Simplified)
[ci skip]
* New translations en.json (Ukrainian)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Hungarian)
[ci skip]
* New translations en.json (Slovak)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Polish)
[ci skip]
* New translations en.json (Norwegian)
[ci skip]
* New translations en.json (Turkish)
[ci skip]
* New translations en.json (Swedish)
[ci skip]
* New translations en.json (Serbian (Cyrillic))
[ci skip]
* New translations en.json (Albanian)
[ci skip]
* New translations en.json (Italian)
[ci skip]
* New translations en.json (Armenian)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Japanese)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Macedonian)
[ci skip]
* New translations en.json (Lithuanian)
[ci skip]
* New translations en.json (Georgian)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (German)
[ci skip]
* New translations en.json (Japanese)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Vietnamese)
[ci skip]
* New translations en.json (Catalan)
[ci skip]
* New translations en.json (Galician)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Spanish, Argentina)
[ci skip]
* New translations en.json (Hungarian)
[ci skip]
* New translations en.json (Albanian)
[ci skip]
* New translations en.json (Corsican)
[ci skip]
* New translations simple_form.en.yml (Dutch)
[ci skip]
* New translations simple_form.en.yml (Dutch)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.json (Thai)
[ci skip]
* New translations en.yml (Thai)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.yml (Dutch)
[ci skip]
* New translations en.json (Portuguese, Brazilian)
[ci skip]
* New translations en.json (Occitan)
[ci skip]
* New translations en.json (Occitan)
[ci skip]
* New translations en.yml (Occitan)
[ci skip]
* New translations en.json (Italian)
[ci skip]
* New translations en.json (Persian)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.yml (French)
[ci skip]
* New translations en.json (Arabic)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.yml (Kabyle)
[ci skip]
* New translations en.json (Icelandic)
[ci skip]
* New translations en.json (Portuguese, Brazilian)
[ci skip]
* New translations en.json (Indonesian)
[ci skip]
* New translations en.json (Persian)
[ci skip]
* New translations en.json (Galician)
[ci skip]
* New translations en.json (Tamil)
[ci skip]
* New translations en.json (Spanish, Argentina)
[ci skip]
* New translations en.json (Bengali)
[ci skip]
* New translations en.json (Marathi)
[ci skip]
* New translations en.json (Albanian)
[ci skip]
* New translations en.json (Serbian (Cyrillic))
[ci skip]
* New translations en.json (Swedish)
[ci skip]
* New translations en.json (Turkish)
[ci skip]
* New translations en.json (Chinese Traditional)
[ci skip]
* New translations en.json (Urdu (Pakistan))
[ci skip]
* New translations en.json (Vietnamese)
[ci skip]
* New translations en.json (Welsh)
[ci skip]
* New translations en.json (Esperanto)
[ci skip]
* New translations en.json (Chinese Traditional, Hong Kong)
[ci skip]
* New translations en.json (Malayalam)
[ci skip]
* New translations en.json (Telugu)
[ci skip]
* New translations en.json (Breton)
[ci skip]
* New translations en.json (Kannada)
[ci skip]
* New translations en.json (Uyghur)
[ci skip]
* New translations en.json (Croatian)
[ci skip]
* New translations en.json (Norwegian Nynorsk)
[ci skip]
* New translations en.json (Kazakh)
[ci skip]
* New translations en.json (Estonian)
[ci skip]
* New translations en.json (Latvian)
[ci skip]
* New translations en.json (Hindi)
[ci skip]
* New translations en.json (Malay)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (Arabic)
[ci skip]
* New translations en.json (Bulgarian)
[ci skip]
* New translations en.json (Catalan)
[ci skip]
* New translations en.json (Czech)
[ci skip]
* New translations en.json (Danish)
[ci skip]
* New translations en.json (German)
[ci skip]
* New translations en.json (Greek)
[ci skip]
* New translations en.json (Romanian)
[ci skip]
* New translations en.json (Slovenian)
[ci skip]
* New translations en.json (Thai)
[ci skip]
* New translations en.json (Chinese Simplified)
[ci skip]
* New translations en.json (Slovak)
[ci skip]
* New translations en.json (Hungarian)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Ukrainian)
[ci skip]
* New translations en.json (Norwegian)
[ci skip]
* New translations en.json (Lithuanian)
[ci skip]
* New translations en.json (Macedonian)
[ci skip]
* New translations en.json (Dutch)
[ci skip]
* New translations en.json (Polish)
[ci skip]
* New translations en.json (Basque)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.json (Armenian)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (Finnish)
[ci skip]
* New translations en.json (Hebrew)
[ci skip]
* New translations en.json (Georgian)
[ci skip]
* New translations en.json (Japanese)
[ci skip]
* New translations en.json (Italian)
[ci skip]
* New translations en.json (Ido)
[ci skip]
* New translations en.json (Taigi)
[ci skip]
* New translations en.json (Silesian)
[ci skip]
* New translations en.json (Sardinian)
[ci skip]
* New translations en.json (Occitan)
[ci skip]
* New translations en.json (Sorani (Kurdish))
[ci skip]
* New translations en.json (Asturian)
[ci skip]
* New translations en.json (Kabyle)
[ci skip]
* New translations en.json (Serbian (Latin))
[ci skip]
* New translations en.json (Corsican)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (Russian)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (German)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Korean)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Esperanto)
[ci skip]
* New translations en.yml (Esperanto)
[ci skip]
* New translations en.json (Esperanto)
[ci skip]
* New translations en.json (Japanese)
[ci skip]
* New translations en.json (Vietnamese)
[ci skip]
* New translations en.json (Japanese)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (Italian)
[ci skip]
* New translations en.json (Italian)
[ci skip]
* New translations en.json (Corsican)
[ci skip]
* New translations en.json (Corsican)
[ci skip]
* New translations en.json (Persian)
[ci skip]
* New translations en.json (Hungarian)
[ci skip]
* New translations en.json (Portuguese, Brazilian)
[ci skip]
* New translations en.json (Spanish)
[ci skip]
* New translations en.json (French)
[ci skip]
* New translations en.json (Spanish, Argentina)
[ci skip]
* New translations en.json (Galician)
[ci skip]
* New translations en.json (Galician)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Portuguese)
[ci skip]
* New translations en.json (Albanian)
[ci skip]
* i18n-tasks normalize
* yarn manage:translations
2020-07-10 11:57:21 -07:00
instance_actor_flash : |
This account is a virtual actor used to represent the server itself and not any individual user.
It is used for federation purposes and should not be blocked unless you want to block the whole instance, in which case you should use a domain block.
2017-07-11 06:27:59 -07:00
learn_more : Learn more
2018-07-28 10:25:33 -07:00
privacy_policy : Privacy policy
2021-02-21 10:50:12 -08:00
rules : Server rules
rules_html : 'Below is a summary of rules you need to follow if you want to have an account on this server of Mastodon:'
2019-03-12 09:34:00 -07:00
see_whats_happening : See what's happening
server_stats : 'Server stats:'
2016-11-15 14:56:03 -08:00
source_code : Source code
2018-08-22 10:42:47 -07:00
status_count_after :
2021-04-21 09:31:24 -07:00
one : post
other : posts
status_count_before : Who published
2019-03-12 09:34:00 -07:00
tagline : Follow friends and discover new ones
2018-07-28 10:25:33 -07:00
terms : Terms of service
2020-06-09 01:28:02 -07:00
unavailable_content : Moderated servers
2019-09-19 02:09:05 -07:00
unavailable_content_description :
2019-09-29 07:23:01 -07:00
domain : Server
reason : Reason
2020-02-03 14:29:42 -08:00
rejecting_media : 'Media files from these servers will not be processed or stored, and no thumbnails will be displayed, requiring manual click-through to the original file:'
2020-06-09 01:28:02 -07:00
rejecting_media_title : Filtered media
silenced : 'Posts from these servers will be hidden in public timelines and conversations, and no notifications will be generated from their users interactions, unless you are following them:'
2021-07-07 20:31:28 -07:00
silenced_title : Limited servers
2019-09-29 07:23:01 -07:00
suspended : 'No data from these servers will be processed, stored or exchanged, making any interaction or communication with users from these servers impossible:'
2020-06-09 01:28:02 -07:00
suspended_title : Suspended servers
2019-09-19 02:09:05 -07:00
unavailable_content_html : Mastodon generally allows you to view content from and interact with users from any other server in the fediverse. These are the exceptions that have been made on this particular server.
2018-08-22 10:42:47 -07:00
user_count_after :
one : user
other : users
2017-01-13 11:14:21 -08:00
user_count_before : Home to
2017-07-11 06:27:59 -07:00
what_is_mastodon : What is Mastodon?
2016-11-15 14:56:03 -08:00
accounts :
2018-08-09 00:56:53 -07:00
choices_html : "%{name}'s choices:"
2019-08-17 09:07:52 -07:00
endorsements_hint : You can endorse people you follow from the web interface, and they will show up here.
featured_tags_hint : You can feature specific hashtags that will be displayed here.
2016-11-15 14:56:03 -08:00
follow : Follow
2018-08-26 12:30:53 -07:00
followers :
one : Follower
other : Followers
2016-11-15 14:56:03 -08:00
following : Following
2020-12-15 08:23:58 -08:00
instance_actor_flash : This account is a virtual actor used to represent the server itself and not any individual user. It is used for federation purposes and should not be suspended.
2018-07-28 10:25:33 -07:00
joined : Joined %{date}
2018-12-06 08:36:11 -08:00
last_active : last active
2018-09-18 07:45:58 -07:00
link_verified_on : Ownership of this link was checked on %{date}
2017-08-22 15:59:35 -07:00
media : Media
2017-11-18 10:39:02 -08:00
moved_html : "%{name} has moved to %{new_profile_link}:"
2018-05-17 17:26:51 -07:00
network_hidden : This information is not available
2019-09-02 09:12:27 -07:00
never_active : Never
2016-11-15 14:56:03 -08:00
nothing_here : There is nothing here!
people_followed_by : People whom %{name} follows
people_who_follow : People who follow %{name}
2018-08-09 00:56:53 -07:00
pin_errors :
following : You must be already following the person you want to endorse
2018-08-26 12:30:53 -07:00
posts :
2021-04-21 09:31:24 -07:00
one : Post
other : Posts
posts_tab_heading : Posts
posts_with_replies : Posts and replies
2017-08-22 15:59:35 -07:00
roles :
admin : Admin
2018-05-07 00:31:07 -07:00
bot : Bot
2019-12-04 11:36:33 -08:00
group : Group
2017-11-16 16:22:38 -08:00
moderator : Mod
2019-04-06 19:59:13 -07:00
unavailable : Profile unavailable
2017-06-08 05:58:22 -07:00
unfollow : Unfollow
2017-04-13 10:18:32 -07:00
admin :
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
account_actions :
action : Perform action
title : Perform moderation action on %{acct}
2017-10-17 02:45:59 -07:00
account_moderation_notes :
2018-05-05 14:06:29 -07:00
create : Leave note
2017-10-17 02:45:59 -07:00
created_msg : Moderation note successfully created!
delete : Delete
destroyed_msg : Moderation note successfully destroyed!
2017-04-13 12:49:07 -07:00
accounts :
2020-06-27 11:20:11 -07:00
add_email_domain_block : Block e-mail domain
2019-03-13 21:28:30 -07:00
approve : Approve
2020-09-15 05:37:58 -07:00
approved_msg : Successfully approved %{username}'s sign-up application
2017-04-13 12:49:07 -07:00
are_you_sure : Are you sure?
2018-04-02 04:45:07 -07:00
avatar : Avatar
2017-11-01 06:46:05 -07:00
by_domain : Domain
2018-04-10 00:16:06 -07:00
change_email :
changed_msg : Account email successfully changed!
2018-12-27 18:38:41 -08:00
current_email : Current email
label : Change email
new_email : New email
submit : Change email
title : Change email for %{username}
2017-04-22 19:43:42 -07:00
confirm : Confirm
confirmed : Confirmed
2018-05-06 01:59:03 -07:00
confirming : Confirming
2020-09-15 05:37:58 -07:00
delete : Delete data
2018-12-27 18:38:41 -08:00
deleted : Deleted
2017-11-11 11:23:33 -08:00
demote : Demote
2020-09-15 05:37:58 -07:00
destroyed_msg : "%{username}'s data is now queued to be deleted imminently"
disable : Freeze
2021-07-07 20:31:28 -07:00
disable_sign_in_token_auth : Disable e-mail token authentication
2017-05-07 16:46:36 -07:00
disable_two_factor_authentication : Disable 2FA
2020-09-15 05:37:58 -07:00
disabled : Frozen
2017-04-13 12:49:07 -07:00
display_name : Display name
domain : Domain
edit : Edit
2018-12-27 18:38:41 -08:00
email : Email
email_status : Email status
2020-09-15 05:37:58 -07:00
enable : Unfreeze
2021-07-07 20:31:28 -07:00
enable_sign_in_token_auth : Enable e-mail token authentication
2017-11-07 10:06:44 -08:00
enabled : Enabled
2020-09-15 05:37:58 -07:00
enabled_msg : Successfully unfroze %{username}'s account
2017-04-13 12:49:07 -07:00
followers : Followers
follows : Follows
2018-12-18 23:51:02 -08:00
header : Header
2017-08-14 05:09:00 -07:00
inbox_url : Inbox URL
2020-12-14 21:28:14 -08:00
invite_request_text : Reasons for joining
2018-12-27 18:38:41 -08:00
invited_by : Invited by
2017-05-16 18:00:34 -07:00
ip : IP
2018-12-27 18:38:41 -08:00
joined : Joined
2017-04-13 12:49:07 -07:00
location :
all : All
local : Local
remote : Remote
title : Location
2017-11-07 10:06:44 -08:00
login_status : Login status
2017-04-13 12:49:07 -07:00
media_attachments : Media attachments
2017-11-07 10:06:44 -08:00
memorialize : Turn into memoriam
2020-09-15 05:37:58 -07:00
memorialized : Memorialized
memorialized_msg : Successfully turned %{username} into a memorial account
2017-04-13 12:49:07 -07:00
moderation :
2018-12-06 08:36:11 -08:00
active : Active
2017-04-13 12:49:07 -07:00
all : All
2019-03-13 21:28:30 -07:00
pending : Pending
2017-04-13 12:49:07 -07:00
suspended : Suspended
title : Moderation
2017-10-07 11:26:43 -07:00
moderation_notes : Moderation notes
2017-04-13 12:49:07 -07:00
most_recent_activity : Most recent activity
most_recent_ip : Most recent IP
2019-04-08 09:35:41 -07:00
no_account_selected : No accounts were changed as none were selected
2018-09-12 18:44:08 -07:00
no_limits_imposed : No limits imposed
2017-04-13 12:49:07 -07:00
not_subscribed : Not subscribed
2019-03-13 21:28:30 -07:00
pending : Pending review
2018-10-19 17:39:39 -07:00
perform_full_suspension : Suspend
2017-11-11 11:23:33 -08:00
promote : Promote
2017-08-14 05:09:00 -07:00
protocol : Protocol
2017-04-13 12:49:07 -07:00
public : Public
push_subscription_expires : PuSH subscription expires
2018-12-27 18:38:41 -08:00
redownload : Refresh profile
2020-09-15 05:37:58 -07:00
redownloaded_msg : Successfully refreshed %{username}'s profile from origin
2019-03-13 21:28:30 -07:00
reject : Reject
2020-09-15 05:37:58 -07:00
rejected_msg : Successfully rejected %{username}'s sign-up application
2018-04-02 04:45:07 -07:00
remove_avatar : Remove avatar
2018-12-18 23:51:02 -08:00
remove_header : Remove header
2020-09-15 05:37:58 -07:00
removed_avatar_msg : Successfully removed %{username}'s avatar image
removed_header_msg : Successfully removed %{username}'s header image
2018-05-06 01:59:03 -07:00
resend_confirmation :
already_confirmed : This user is already confirmed
send : Resend confirmation email
success : Confirmation email successfully sent!
2017-05-17 15:38:01 -07:00
reset : Reset
2017-04-16 10:37:01 -07:00
reset_password : Reset password
2017-06-08 05:58:22 -07:00
resubscribe : Resubscribe
2017-11-11 11:23:33 -08:00
role : Permissions
roles :
admin : Administrator
moderator : Moderator
2017-12-13 03:15:10 -08:00
staff : Staff
2017-11-11 11:23:33 -08:00
user : User
2017-05-16 18:00:34 -07:00
search : Search
2020-03-12 14:35:20 -07:00
search_same_email_domain : Other users with the same e-mail domain
2019-10-24 13:49:26 -07:00
search_same_ip : Other users with the same IP
2021-07-07 20:31:28 -07:00
security_measures :
only_password : Only password
password_and_2fa : Password and 2FA
password_and_sign_in_token : Password and e-mail token
sensitive : Force-sensitive
sensitized : Marked as sensitive
2018-12-27 18:38:41 -08:00
shared_inbox_url : Shared inbox URL
2017-04-18 10:36:18 -07:00
show :
2018-12-27 18:38:41 -08:00
created_reports : Made reports
targeted_reports : Reported by others
2020-09-15 05:37:58 -07:00
silence : Limit
silenced : Limited
2021-04-21 09:31:24 -07:00
statuses : Posts
2017-06-08 05:58:22 -07:00
subscribe : Subscribe
2018-09-12 18:44:08 -07:00
suspended : Suspended
2020-09-15 05:37:58 -07:00
suspension_irreversible : The data of this account has been irreversibly deleted. You can unsuspend the account to make it usable but it will not recover any data it previously had.
suspension_reversible_hint_html : The account has been suspended, and the data will be fully removed on %{date}. Until then, the account can be restored without any ill effects. If you wish to remove all of the account's data immediately, you can do so below.
2017-04-13 12:49:07 -07:00
title : Accounts
2018-12-27 18:38:41 -08:00
unconfirmed_email : Unconfirmed email
2021-07-07 20:31:28 -07:00
undo_sensitized : Undo force-sensitive
undo_silenced : Undo limit
2017-04-13 12:49:07 -07:00
undo_suspension : Undo suspension
2021-07-07 20:31:28 -07:00
unsilenced_msg : Successfully undid limit of %{username}'s account
2017-06-08 05:58:22 -07:00
unsubscribe : Unsubscribe
2020-09-15 05:37:58 -07:00
unsuspended_msg : Successfully unsuspended %{username}'s account
2017-04-13 12:49:07 -07:00
username : Username
2020-09-15 05:37:58 -07:00
view_domain : View summary for domain
2018-12-27 18:38:41 -08:00
warn : Warn
2017-04-13 12:49:07 -07:00
web : Web
2020-06-27 11:20:11 -07:00
whitelisted : Allowed for federation
2017-11-23 17:05:53 -08:00
action_logs :
2020-04-03 04:06:34 -07:00
action_types :
2021-12-05 12:48:39 -08:00
approve_user : Approve User
2020-04-03 04:06:34 -07:00
assigned_to_self_report : Assign Report
change_email_user : Change E-mail for User
confirm_user : Confirm User
create_account_warning : Create Warning
create_announcement : Create Announcement
create_custom_emoji : Create Custom Emoji
create_domain_allow : Create Domain Allow
create_domain_block : Create Domain Block
create_email_domain_block : Create E-mail Domain Block
2020-10-12 07:33:49 -07:00
create_ip_block : Create IP rule
2021-05-05 14:39:02 -07:00
create_unavailable_domain : Create Unavailable Domain
2020-04-03 04:06:34 -07:00
demote_user : Demote User
destroy_announcement : Delete Announcement
destroy_custom_emoji : Delete Custom Emoji
destroy_domain_allow : Delete Domain Allow
destroy_domain_block : Delete Domain Block
2021-07-07 20:31:28 -07:00
destroy_email_domain_block : Delete E-mail Domain Block
2020-10-12 07:33:49 -07:00
destroy_ip_block : Delete IP rule
2021-04-21 09:31:24 -07:00
destroy_status : Delete Post
2021-05-05 14:39:02 -07:00
destroy_unavailable_domain : Delete Unavailable Domain
2020-04-03 04:06:34 -07:00
disable_2fa_user : Disable 2FA
disable_custom_emoji : Disable Custom Emoji
2021-07-07 20:31:28 -07:00
disable_sign_in_token_auth_user : Disable E-mail Token Authentication for User
2020-04-03 04:06:34 -07:00
disable_user : Disable User
enable_custom_emoji : Enable Custom Emoji
2021-07-07 20:31:28 -07:00
enable_sign_in_token_auth_user : Enable E-mail Token Authentication for User
2020-04-03 04:06:34 -07:00
enable_user : Enable User
memorialize_account : Memorialize Account
promote_user : Promote User
2021-12-05 12:48:39 -08:00
reject_user : Reject User
2020-04-03 04:06:34 -07:00
remove_avatar_user : Remove Avatar
reopen_report : Reopen Report
reset_password_user : Reset Password
resolve_report : Resolve Report
2021-07-07 20:31:28 -07:00
sensitive_account : Force-Sensitive Account
silence_account : Limit Account
2020-04-03 04:06:34 -07:00
suspend_account : Suspend Account
unassigned_report : Unassign Report
2021-07-07 20:31:28 -07:00
unsensitive_account : Undo Force-Sensitive Account
unsilence_account : Undo Limit Account
2020-04-03 04:06:34 -07:00
unsuspend_account : Unsuspend Account
update_announcement : Update Announcement
update_custom_emoji : Update Custom Emoji
2020-12-14 00:06:34 -08:00
update_domain_block : Update Domain Block
2021-04-21 09:31:24 -07:00
update_status : Update Post
2017-11-23 17:05:53 -08:00
actions :
2021-12-05 12:48:39 -08:00
approve_user_html : "%{name} approved sign-up from %{target}"
2021-03-19 15:48:59 -07:00
assigned_to_self_report_html : "%{name} assigned report %{target} to themselves"
change_email_user_html : "%{name} changed the e-mail address of user %{target}"
confirm_user_html : "%{name} confirmed e-mail address of user %{target}"
create_account_warning_html : "%{name} sent a warning to %{target}"
create_announcement_html : "%{name} created new announcement %{target}"
create_custom_emoji_html : "%{name} uploaded new emoji %{target}"
create_domain_allow_html : "%{name} allowed federation with domain %{target}"
create_domain_block_html : "%{name} blocked domain %{target}"
create_email_domain_block_html : "%{name} blocked e-mail domain %{target}"
create_ip_block_html : "%{name} created rule for IP %{target}"
2021-05-05 14:39:02 -07:00
create_unavailable_domain_html : "%{name} stopped delivery to domain %{target}"
2021-03-19 15:48:59 -07:00
demote_user_html : "%{name} demoted user %{target}"
destroy_announcement_html : "%{name} deleted announcement %{target}"
destroy_custom_emoji_html : "%{name} destroyed emoji %{target}"
destroy_domain_allow_html : "%{name} disallowed federation with domain %{target}"
destroy_domain_block_html : "%{name} unblocked domain %{target}"
destroy_email_domain_block_html : "%{name} unblocked e-mail domain %{target}"
destroy_ip_block_html : "%{name} deleted rule for IP %{target}"
2021-04-21 09:31:24 -07:00
destroy_status_html : "%{name} removed post by %{target}"
2021-05-05 14:39:02 -07:00
destroy_unavailable_domain_html : "%{name} resumed delivery to domain %{target}"
2021-03-19 15:48:59 -07:00
disable_2fa_user_html : "%{name} disabled two factor requirement for user %{target}"
disable_custom_emoji_html : "%{name} disabled emoji %{target}"
2021-07-07 20:31:28 -07:00
disable_sign_in_token_auth_user_html : "%{name} disabled e-mail token authentication for %{target}"
2021-03-19 15:48:59 -07:00
disable_user_html : "%{name} disabled login for user %{target}"
enable_custom_emoji_html : "%{name} enabled emoji %{target}"
2021-07-07 20:31:28 -07:00
enable_sign_in_token_auth_user_html : "%{name} enabled e-mail token authentication for %{target}"
2021-03-19 15:48:59 -07:00
enable_user_html : "%{name} enabled login for user %{target}"
memorialize_account_html : "%{name} turned %{target}'s account into a memoriam page"
promote_user_html : "%{name} promoted user %{target}"
2021-12-05 12:48:39 -08:00
reject_user_html : "%{name} rejected sign-up from %{target}"
2021-03-19 15:48:59 -07:00
remove_avatar_user_html : "%{name} removed %{target}'s avatar"
reopen_report_html : "%{name} reopened report %{target}"
reset_password_user_html : "%{name} reset password of user %{target}"
resolve_report_html : "%{name} resolved report %{target}"
sensitive_account_html : "%{name} marked %{target}'s media as sensitive"
2021-07-07 20:31:28 -07:00
silence_account_html : "%{name} limited %{target}'s account"
2021-03-19 15:48:59 -07:00
suspend_account_html : "%{name} suspended %{target}'s account"
unassigned_report_html : "%{name} unassigned report %{target}"
unsensitive_account_html : "%{name} unmarked %{target}'s media as sensitive"
2021-07-07 20:31:28 -07:00
unsilence_account_html : "%{name} undid limit of %{target}'s account"
2021-03-19 15:48:59 -07:00
unsuspend_account_html : "%{name} unsuspended %{target}'s account"
update_announcement_html : "%{name} updated announcement %{target}"
update_custom_emoji_html : "%{name} updated emoji %{target}"
update_domain_block_html : "%{name} updated domain block for %{target}"
2021-04-21 09:31:24 -07:00
update_status_html : "%{name} updated post by %{target}"
deleted_status : "(deleted post)"
2020-04-03 04:06:34 -07:00
empty : No logs found.
filter_by_action : Filter by action
filter_by_user : Filter by user
2017-11-23 17:05:53 -08:00
title : Audit log
2020-01-23 13:00:13 -08:00
announcements :
2020-01-27 02:05:33 -08:00
destroyed_msg : Announcement successfully deleted!
2020-01-23 13:00:13 -08:00
edit :
title : Edit announcement
empty : No announcements found.
live : Live
new :
create : Create announcement
title : New announcement
2021-04-17 02:12:49 -07:00
publish : Publish
2020-01-27 02:05:33 -08:00
published_msg : Announcement successfully published!
2020-01-27 17:21:00 -08:00
scheduled_for : Scheduled for %{time}
2020-01-27 02:05:33 -08:00
scheduled_msg : Announcement scheduled for publication!
2020-01-23 13:00:13 -08:00
title : Announcements
2021-04-17 02:12:49 -07:00
unpublish : Unpublish
2020-01-27 02:05:33 -08:00
unpublished_msg : Announcement successfully unpublished!
updated_msg : Announcement successfully updated!
2017-09-18 18:52:38 -07:00
custom_emojis :
2019-09-09 13:44:17 -07:00
assign_category : Assign category
2017-12-13 04:28:31 -08:00
by_domain : Domain
2017-10-05 14:42:05 -07:00
copied_msg : Successfully created local copy of the emoji
copy : Copy
copy_failed_msg : Could not make a local copy of that emoji
2019-09-09 13:44:17 -07:00
create_new_category : Create new category
2017-09-18 18:52:38 -07:00
created_msg : Emoji successfully created!
delete : Delete
destroyed_msg : Emojo successfully destroyed!
2017-10-05 14:42:05 -07:00
disable : Disable
2019-09-30 16:20:22 -07:00
disabled : Disabled
2017-10-05 14:42:05 -07:00
disabled_msg : Successfully disabled that emoji
2017-09-18 18:52:38 -07:00
emoji : Emoji
2017-10-05 14:42:05 -07:00
enable : Enable
2019-09-26 18:07:19 -07:00
enabled : Enabled
2017-10-05 14:42:05 -07:00
enabled_msg : Successfully enabled that emoji
2017-09-18 18:52:38 -07:00
image_hint : PNG up to 50KB
2019-09-26 18:07:19 -07:00
list : List
2017-10-27 07:11:30 -07:00
listed : Listed
2017-09-18 18:52:38 -07:00
new :
title : Add new custom emoji
2020-06-05 06:23:27 -07:00
not_permitted : You are not permitted to perform this action
2017-11-07 05:49:32 -08:00
overwrite : Overwrite
2017-09-18 18:52:38 -07:00
shortcode : Shortcode
shortcode_hint : At least 2 characters, only alphanumeric characters and underscores
title : Custom emojis
2019-09-09 13:44:17 -07:00
uncategorized : Uncategorized
2019-09-26 18:07:19 -07:00
unlist : Unlist
2017-10-27 07:11:30 -07:00
unlisted : Unlisted
update_failed_msg : Could not update that emoji
updated_msg : Emoji successfully updated!
2017-09-18 18:52:38 -07:00
upload : Upload
2018-07-15 16:11:53 -07:00
dashboard :
2021-10-14 11:44:59 -07:00
active_users : active users
interactions : interactions
media_storage : Media storage
new_users : new users
opened_reports : reports opened
pending_reports_html :
one : "<strong>1</strong> pending reports"
other : "<strong>%{count}</strong> pending reports"
pending_tags_html :
one : "<strong>1</strong> pending hashtags"
other : "<strong>%{count}</strong> pending hashtags"
pending_users_html :
one : "<strong>1</strong> pending users"
other : "<strong>%{count}</strong> pending users"
resolved_reports : reports resolved
2018-07-15 16:11:53 -07:00
software : Software
2021-10-14 11:44:59 -07:00
sources : Sign-up sources
2018-07-15 16:11:53 -07:00
space : Space usage
title : Dashboard
2021-10-14 11:44:59 -07:00
top_languages : Top active languages
top_servers : Top active servers
website : Website
2019-07-30 02:10:46 -07:00
domain_allows :
2020-06-27 11:20:11 -07:00
add_new : Allow federation with domain
created_msg : Domain has been successfully allowed for federation
destroyed_msg : Domain has been disallowed from federation
undo : Disallow federation with domain
2017-04-16 10:37:01 -07:00
domain_blocks :
2019-01-08 04:39:49 -08:00
add_new : Add new domain block
2017-04-16 03:51:30 -07:00
created_msg : Domain block is now being processed
destroyed_msg : Domain block has been undone
2017-04-13 12:49:07 -07:00
domain : Domain
2019-08-07 11:20:23 -07:00
edit : Edit domain block
2019-05-03 11:36:36 -07:00
existing_domain_block_html : You have already imposed stricter limits on %{name}, you need to <a href="%{unblock_url}">unblock it</a> first.
2017-04-13 12:49:07 -07:00
new :
create : Create block
hint : The domain block will not prevent creation of account entries in the database, but will retroactively and automatically apply specific moderation methods on those accounts.
severity :
2017-07-24 05:26:55 -07:00
desc_html : "<strong>Silence</strong> will make the account's posts invisible to anyone who isn't following them. <strong>Suspend</strong> will remove all of the account's content, media, and profile data. Use <strong>None</strong> if you just want to reject media files."
noop : None
2017-04-13 12:49:07 -07:00
silence : Silence
suspend : Suspend
title : New domain block
2020-12-17 23:30:41 -08:00
obfuscate : Obfuscate domain name
obfuscate_hint : Partially obfuscate the domain name in the list if advertising the list of domain limitations is enabled
2019-08-07 11:20:23 -07:00
private_comment : Private comment
private_comment_hint : Comment about this domain limitation for internal use by the moderators.
public_comment : Public comment
public_comment_hint : Comment about this domain limitation for the general public, if advertising the list of domain limitations is enabled.
2017-04-16 03:51:30 -07:00
reject_media : Reject media files
reject_media_hint : Removes locally stored media files and refuses to download any in the future. Irrelevant for suspensions
2018-10-19 23:02:44 -07:00
reject_reports : Reject reports
reject_reports_hint : Ignore all reports coming from this domain. Irrelevant for suspensions
2019-01-08 04:39:49 -08:00
rejecting_media : rejecting media files
rejecting_reports : rejecting reports
severity :
2021-07-07 20:31:28 -07:00
silence : limited
2019-01-08 04:39:49 -08:00
suspend : suspended
2017-04-16 03:51:30 -07:00
show :
affected_accounts :
one : One account in the database affected
other : "%{count} accounts in the database affected"
retroactive :
2021-07-07 20:31:28 -07:00
silence : Undo limit of existing affected accounts from this domain
2019-05-14 10:05:02 -07:00
suspend : Unsuspend existing affected accounts from this domain
2017-04-16 03:51:30 -07:00
title : Undo domain block for %{domain}
2017-04-16 10:37:01 -07:00
undo : Undo
2019-01-08 04:39:49 -08:00
undo : Undo domain block
2019-08-07 11:20:23 -07:00
view : View domain block
2017-10-04 06:16:10 -07:00
email_domain_blocks :
add_new : Add new
2020-06-27 11:20:11 -07:00
created_msg : Successfully blocked e-mail domain
2017-10-04 06:16:10 -07:00
delete : Delete
2020-06-27 11:20:11 -07:00
destroyed_msg : Successfully unblocked e-mail domain
2017-10-04 06:16:10 -07:00
domain : Domain
2020-06-27 11:20:11 -07:00
empty : No e-mail domains currently blocked.
2020-03-12 14:35:20 -07:00
from_html : from %{domain}
2017-10-04 06:16:10 -07:00
new :
2017-11-23 17:05:53 -08:00
create : Add domain
2020-06-27 11:20:11 -07:00
title : Block new e-mail domain
title : Blocked e-mail domains
2021-04-12 03:37:14 -07:00
follow_recommendations :
description_html : "<strong>Follow recommendations help new users quickly find interesting content</strong>. When a user has not interacted with others enough to form personalized follow recommendations, these accounts are recommended instead. They are re-calculated on a daily basis from a mix of accounts with the highest recent engagements and highest local follower counts for a given language."
language : For language
status : Status
suppress : Suppress follow recommendation
suppressed : Suppressed
title : Follow recommendations
unsuppress : Restore follow recommendation
2017-04-18 12:09:07 -07:00
instances :
2021-05-05 14:39:02 -07:00
back_to_all : All
back_to_limited : Limited
back_to_warning : Warning
2019-02-18 05:59:19 -08:00
by_domain : Domain
2021-05-05 14:39:02 -07:00
delivery :
all : All
clear : Clear delivery errors
restart : Restart delivery
stop : Stop delivery
title : Delivery
unavailable : Unavailable
unavailable_message : Delivery unavailable
warning : Warning
warning_message :
one : Delivery failure %{count} day
other : Delivery failure %{count} days
2019-01-08 04:39:49 -08:00
delivery_available : Delivery is available
2021-05-05 14:39:02 -07:00
delivery_error_days : Delivery error days
delivery_error_hint : If delivery is not possible for %{count} days, it will be automatically marked as undeliverable.
2020-12-14 00:06:34 -08:00
empty : No domains found.
2019-01-08 04:39:49 -08:00
known_accounts :
one : "%{count} known account"
other : "%{count} known accounts"
moderation :
all : All
limited : Limited
title : Moderation
2019-08-07 11:20:23 -07:00
private_comment : Private comment
public_comment : Public comment
2019-01-08 04:39:49 -08:00
title : Federation
total_blocked_by_us : Blocked by us
total_followed_by_them : Followed by them
total_followed_by_us : Followed by us
total_reported : Reports about them
total_storage : Media attachments
2017-11-27 07:07:59 -08:00
invites :
2018-08-18 15:58:53 -07:00
deactivate_all : Deactivate all
2017-12-01 07:40:02 -08:00
filter :
all : All
available : Available
expired : Expired
title : Filter
2017-11-27 07:07:59 -08:00
title : Invites
2020-10-12 07:33:49 -07:00
ip_blocks :
add_new : Create rule
created_msg : Successfully added new IP rule
delete : Delete
expires_in :
'1209600' : 2 weeks
'15778476' : 6 months
'2629746' : 1 month
'31556952' : 1 year
'86400' : 1 day
'94670856' : 3 years
new :
title : Create new IP rule
no_ip_block_selected : No IP rules were changed as none were selected
title : IP rules
2020-01-23 11:33:20 -08:00
relationships :
title : "%{acct}'s relationships"
2018-07-12 17:16:06 -07:00
relays :
add_new : Add new relay
2018-09-12 18:44:08 -07:00
delete : Delete
2021-04-21 09:31:24 -07:00
description_html : A <strong>federation relay</strong> is an intermediary server that exchanges large volumes of public posts between servers that subscribe and publish to it. <strong>It can help small and medium servers discover content from the fediverse</strong>, which would otherwise require local users manually following other people on remote servers.
2018-09-12 18:44:08 -07:00
disable : Disable
disabled : Disabled
enable : Enable
2021-04-21 09:31:24 -07:00
enable_hint : Once enabled, your server will subscribe to all public posts from this relay, and will begin sending this server's public posts to it.
2018-09-12 18:44:08 -07:00
enabled : Enabled
2018-07-12 17:16:06 -07:00
inbox_url : Relay URL
2018-08-27 20:39:43 -07:00
pending : Waiting for relay's approval
2018-08-31 06:15:21 -07:00
save_and_enable : Save and enable
2018-07-12 17:16:06 -07:00
setup : Setup a relay connection
2020-06-27 11:20:11 -07:00
signatures_not_enabled : Relays will not work correctly while secure mode or limited federation mode is enabled
2018-07-12 17:16:06 -07:00
status : Status
title : Relays
2018-04-02 13:04:14 -07:00
report_notes :
2018-04-10 11:27:59 -07:00
created_msg : Report note successfully created!
destroyed_msg : Report note successfully deleted!
2017-04-13 12:49:07 -07:00
reports :
2018-04-17 05:58:11 -07:00
account :
2019-12-12 10:50:23 -08:00
notes :
one : "%{count} note"
other : "%{count} notes"
reports :
one : "%{count} report"
other : "%{count} reports"
2017-06-09 06:08:06 -07:00
action_taken_by : Action taken by
2017-06-08 05:58:22 -07:00
are_you_sure : Are you sure?
2018-04-02 13:04:14 -07:00
assign_to_self : Assign to me
2018-04-19 17:28:48 -07:00
assigned : Assigned moderator
2019-11-30 10:53:58 -08:00
by_target_domain : Domain of reported account
2017-04-13 12:49:07 -07:00
comment :
none : None
2018-04-10 11:27:59 -07:00
created_at : Reported
2020-12-14 19:30:15 -08:00
forwarded : Forwarded
forwarded_to : Forwarded to %{domain}
2017-04-13 12:49:07 -07:00
mark_as_resolved : Mark as resolved
2018-04-02 13:04:14 -07:00
mark_as_unresolved : Mark as unresolved
notes :
2018-04-19 17:28:48 -07:00
create : Add note
create_and_resolve : Resolve with note
create_and_unresolve : Reopen with note
2018-04-02 13:04:14 -07:00
delete : Delete
2018-05-22 06:26:42 -07:00
placeholder : Describe what actions have been taken, or any other related updates...
2018-04-19 17:28:48 -07:00
reopen : Reopen report
2017-04-13 12:49:07 -07:00
report : 'Report #%{id}'
reported_account : Reported account
reported_by : Reported by
resolved : Resolved
2018-04-02 13:04:14 -07:00
resolved_msg : Report successfully resolved!
2017-04-13 12:49:07 -07:00
status : Status
2021-07-11 02:01:38 -07:00
target_origin : Origin of reported account
2017-04-13 12:49:07 -07:00
title : Reports
2018-04-02 13:04:14 -07:00
unassign : Unassign
2017-04-13 12:49:07 -07:00
unresolved : Unresolved
2018-04-02 13:04:14 -07:00
updated_at : Updated
2021-02-21 10:50:12 -08:00
rules :
add_new : Add rule
2021-04-17 02:12:49 -07:00
delete : Delete
description_html : While most claim to have read and agree to the terms of service, usually people do not read through until after a problem arises. <strong>Make it easier to see your server's rules at a glance by providing them in a flat bullet point list.</strong> Try to keep individual rules short and simple, but try not to split them up into many separate items either.
2021-02-21 10:50:12 -08:00
edit : Edit rule
2021-04-17 02:12:49 -07:00
empty : No server rules have been defined yet.
2021-02-21 10:50:12 -08:00
title : Server rules
2017-04-13 10:18:32 -07:00
settings :
2017-12-29 10:52:04 -08:00
activity_api_enabled :
2021-04-21 09:31:24 -07:00
desc_html : Counts of locally published posts, active users, and new registrations in weekly buckets
2021-04-20 04:57:45 -07:00
title : Publish aggregate statistics about user activity in the API
2017-09-10 00:58:38 -07:00
bootstrap_timeline_accounts :
2021-04-24 08:01:43 -07:00
desc_html : Separate multiple usernames by comma. These accounts will be guaranteed to be shown in follow recommendations
title : Recommend these accounts to new users
2017-04-13 10:18:32 -07:00
contact_information :
2017-07-11 18:24:04 -07:00
email : Business e-mail
username : Contact username
2018-08-25 13:55:25 -07:00
custom_css :
desc_html : Modify the look with CSS loaded on every page
title : Custom CSS
2019-09-10 23:44:58 -07:00
default_noindex :
desc_html : Affects all users who have not changed this setting themselves
title : Opt users out of search engine indexing by default
2019-08-19 02:35:48 -07:00
domain_blocks :
all : To everyone
disabled : To no one
title : Show domain blocks
users : To logged-in local users
domain_blocks_rationale :
title : Show rationale
2018-02-21 16:03:48 -08:00
hero :
2019-02-05 10:11:24 -08:00
desc_html : Displayed on the frontpage. At least 600x100px recommended. When not set, falls back to server thumbnail
2018-02-21 16:03:48 -08:00
title : Hero image
2018-10-07 15:20:45 -07:00
mascot :
2018-10-13 08:00:15 -07:00
desc_html : Displayed on multiple pages. At least 293× 205px recommended. When not set, falls back to default mascot
2018-10-07 15:20:45 -07:00
title : Mascot image
2017-12-29 10:52:04 -08:00
peers_api_enabled :
2019-02-05 10:11:24 -08:00
desc_html : Domain names this server has encountered in the fediverse
2021-04-20 04:57:45 -07:00
title : Publish list of discovered servers in the API
2018-07-05 17:15:56 -07:00
preview_sensitive_media :
desc_html : Link previews on other websites will display a thumbnail even if the media is marked as sensitive
title : Show sensitive media in OpenGraph previews
2018-12-11 10:18:29 -08:00
profile_directory :
desc_html : Allow users to be discoverable
title : Enable profile directory
2017-04-13 10:18:32 -07:00
registrations :
closed_message :
2017-07-11 18:24:04 -07:00
desc_html : Displayed on frontpage when registrations are closed. You can use HTML tags
2017-04-13 10:18:32 -07:00
title : Closed registration message
2017-07-11 18:24:04 -07:00
deletion :
desc_html : Allow anyone to delete their account
title : Open account deletion
2017-11-27 07:07:59 -08:00
min_invite_role :
disabled : No one
title : Allow invitations by
2020-12-14 01:03:09 -08:00
require_invite_text :
2020-12-18 00:57:54 -08:00
desc_html : When registrations require manual approval, make the “Why do you want to join?” text input mandatory rather than optional
title : Require new users to enter a reason to join
2019-03-13 21:28:30 -07:00
registrations_mode :
modes :
approved : Approval required for sign up
none : Nobody can sign up
open : Anyone can sign up
title : Registrations mode
2018-02-03 21:00:10 -08:00
show_known_fediverse_at_about_page :
2019-10-08 15:30:15 -07:00
desc_html : When disabled, restricts the public timeline linked from the landing page to showing only local content
title : Include federated content on unauthenticated public timeline page
2017-11-18 19:13:57 -08:00
show_staff_badge :
desc_html : Show a staff badge on a user page
title : Show staff badge
2017-04-13 10:18:32 -07:00
site_description :
2019-03-23 08:11:58 -07:00
desc_html : Introductory paragraph on the API. Describe what makes this Mastodon server special and anything else important. You can use HTML tags, in particular <code><a></code> and <code><em></code>.
2019-02-05 10:11:24 -08:00
title : Server description
2017-04-13 10:18:32 -07:00
site_description_extended :
2019-02-05 10:11:24 -08:00
desc_html : A good place for your code of conduct, rules, guidelines and other things that set your server apart. You can use HTML tags
2017-07-11 18:24:04 -07:00
title : Custom extended information
2018-07-31 09:59:34 -07:00
site_short_description :
2019-03-23 08:11:58 -07:00
desc_html : Displayed in sidebar and meta tags. Describe what Mastodon is and what makes this server special in a single paragraph.
2019-02-05 10:11:24 -08:00
title : Short server description
2017-07-04 06:19:24 -07:00
site_terms :
2017-07-11 18:24:04 -07:00
desc_html : You can write your own privacy policy, terms of service or other legalese. You can use HTML tags
title : Custom terms of service
2019-02-05 10:11:24 -08:00
site_title : Server name
2017-09-13 15:04:30 -07:00
thumbnail :
desc_html : Used for previews via OpenGraph and API. 1200x630px recommended
2019-02-05 10:11:24 -08:00
title : Server thumbnail
2017-07-11 18:24:04 -07:00
timeline_preview :
2019-10-08 15:30:15 -07:00
desc_html : Display link to public timeline on landing page and allow API access to the public timeline without authentication
title : Allow unauthenticated access to public timeline
2017-11-23 17:05:53 -08:00
title : Site settings
2019-10-08 15:30:15 -07:00
trendable_by_default :
desc_html : Affects hashtags that have not been previously disallowed
title : Allow hashtags to trend without prior review
2019-08-06 08:57:52 -07:00
trends :
2021-11-25 04:07:38 -08:00
desc_html : Publicly display previously reviewed content that is currently trending
title : Trends
2020-03-08 08:00:24 -07:00
site_uploads :
delete : Delete uploaded file
destroyed_msg : Site upload successfully deleted!
2017-07-18 07:38:22 -07:00
statuses :
back_to_account : Back to account page
batch :
delete : Delete
2018-04-19 17:28:48 -07:00
nsfw_off : Mark as not sensitive
nsfw_on : Mark as sensitive
2019-08-22 12:55:56 -07:00
deleted : Deleted
2017-07-18 07:38:22 -07:00
failed_to_execute : Failed to execute
media :
title : Media
no_media : No media
2021-04-21 09:31:24 -07:00
no_status_selected : No posts were changed as none were selected
title : Account posts
2017-07-22 16:14:57 -07:00
with_media : With media
2021-04-03 05:12:30 -07:00
system_checks :
database_schema_check :
message_html : There are pending database migrations. Please run them to ensure the application behaves as expected
rules_check :
action : Manage server rules
message_html : You haven't defined any server rules.
sidekiq_process_check :
message_html : No Sidekiq process running for the %{value} queue(s). Please review your Sidekiq configuration
2018-12-06 08:36:11 -08:00
tags :
2019-08-05 10:54:29 -07:00
review : Review status
2019-08-07 01:01:55 -07:00
updated_msg : Hashtag settings updated successfully
2017-04-13 12:49:07 -07:00
title : Administration
2021-11-25 04:07:38 -08:00
trends :
allow : Allow
approved : Approved
disallow : Disallow
links :
allow : Allow link
allow_provider : Allow publisher
disallow : Disallow link
disallow_provider : Disallow publisher
shared_by_over_week :
one : Shared by one person over the last week
other : Shared by %{count} people over the last week
title : Trending links
usage_comparison : Shared %{today} times today, compared to %{yesterday} yesterday
pending_review : Pending review
preview_card_providers :
allowed : Links from this publisher can trend
rejected : Links from this publisher won't trend
title : Publishers
rejected : Rejected
tags :
current_score : Current score %{score}
dashboard :
tag_accounts_measure : unique uses
tag_languages_dimension : Top languages
tag_servers_dimension : Top servers
tag_servers_measure : different servers
tag_uses_measure : total uses
listable : Can be suggested
not_listable : Won't be suggested
not_trendable : Won't appear under trends
not_usable : Cannot be used
peaked_on_and_decaying : Peaked on %{date}, now decaying
title : Trending hashtags
trendable : Can appear under trends
trending_rank : 'Trending #%{rank}'
usable : Can be used
usage_comparison : Used %{today} times today, compared to %{yesterday} yesterday
used_by_over_week :
one : Used by one person over the last week
other : Used by %{count} people over the last week
title : Trends
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
warning_presets :
add_new : Add new
delete : Delete
edit_preset : Edit warning preset
2021-04-17 02:12:49 -07:00
empty : You haven't defined any warning presets yet.
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
title : Manage warning presets
2017-06-26 15:04:00 -07:00
admin_mailer :
2019-03-13 21:28:30 -07:00
new_pending_account :
body : The details of the new account are below. You can approve or reject this application.
subject : New account up for review on %{instance} (%{username})
2017-06-26 15:04:00 -07:00
new_report :
body : "%{reporter} has reported %{target}"
2018-05-04 04:26:25 -07:00
body_remote : Someone from %{domain} has reported %{target}
2017-06-26 15:04:00 -07:00
subject : New report for %{instance} (#%{id})
2021-11-25 04:07:38 -08:00
new_trending_links :
body : The following links are trending today, but their publishers have not been previously reviewed. They will not be displayed publicly unless you approve them. Further notifications from the same publishers will not be generated.
no_approved_links : There are currently no approved trending links.
requirements : The lowest approved trending link is currently "%{lowest_link_title}" with a score of %{lowest_link_score}.
subject : New trending links up for review on %{instance}
new_trending_tags :
body : 'The following hashtags are trending today, but they have not been previously reviewed. They will not be displayed publicly unless you approve them:'
no_approved_tags : There are currently no approved trending hashtags.
requirements : 'The lowest approved trending hashtag is currently #%{lowest_tag_name} with a score of %{lowest_tag_score}.'
subject : New trending hashtags up for review on %{instance}
2019-09-19 11:58:19 -07:00
aliases :
add_new : Create alias
created_msg : Successfully created a new alias. You can now initiate the move from the old account.
2021-05-23 18:03:01 -07:00
deleted_msg : Successfully removed the alias. Moving from that account to this one will no longer be possible.
2020-04-12 21:41:43 -07:00
empty : You have no aliases.
2019-09-19 11:58:19 -07:00
hint_html : If you want to move from another account to this one, here you can create an alias, which is required before you can proceed with moving followers from the old account to this one. This action by itself is <strong>harmless and reversible</strong>. <strong>The account migration is initiated from the old account</strong>.
remove : Unlink alias
2019-06-06 18:39:24 -07:00
appearance :
advanced_web_interface : Advanced web interface
advanced_web_interface_hint: 'If you want to make use of your entire screen width, the advanced web interface allows you to configure many different columns to see as much information at the same time as you want : Home, notifications, federated timeline, any number of lists and hashtags.'
animations_and_accessibility : Animations and accessibility
confirmation_dialogs : Confirmation dialogs
2019-08-06 08:57:52 -07:00
discovery : Discovery
2019-12-31 13:15:05 -08:00
localization :
body : Mastodon is translated by volunteers.
guide_link : https://crowdin.com/project/mastodon
guide_link_text : Everyone can contribute.
2019-06-06 18:39:24 -07:00
sensitive_content : Sensitive content
2021-04-21 09:31:24 -07:00
toot_layout : Post layout
2016-11-15 14:56:03 -08:00
application_mailer :
2018-01-15 18:29:11 -08:00
notification_preferences : Change e-mail preferences
2017-08-04 19:24:58 -07:00
salutation : "%{name},"
2017-03-03 14:45:48 -08:00
settings: 'Change e-mail preferences : %{link}'
view : 'View:'
2019-04-06 08:53:45 -07:00
view_profile : View profile
2021-04-21 09:31:24 -07:00
view_status : View post
2017-01-15 05:01:33 -08:00
applications :
2017-08-22 15:59:35 -07:00
created : Application successfully created
destroyed : Application successfully deleted
2017-01-15 05:01:33 -08:00
invalid_url : The provided URL is invalid
2017-08-22 15:59:35 -07:00
regenerate_token : Regenerate access token
token_regenerated : Access token successfully regenerated
warning : Be very careful with this data. Never share it with anyone!
your_token : Your access token
2016-11-15 14:02:57 -08:00
auth :
2019-03-13 21:28:30 -07:00
apply_for_account : Request an invite
2018-03-06 16:39:40 -08:00
change_password : Password
2019-03-12 09:34:00 -07:00
checkbox_agreement_html : I agree to the <a href="%{rules_path}" target="_blank">server rules</a> and <a href="%{terms_path}" target="_blank">terms of service</a>
2019-07-30 02:10:46 -07:00
checkbox_agreement_without_rules_html : I agree to the <a href="%{terms_path}" target="_blank">terms of service</a>
2017-06-14 09:01:27 -07:00
delete_account : Delete account
delete_account_html : If you wish to delete your account, you can <a href="%{path}">proceed here</a>. You will be asked for confirmation.
2019-09-02 19:56:54 -07:00
description :
prefix_invited_by_user : "@%{name} invites you to join this server of Mastodon!"
prefix_sign_up : Sign up on Mastodon today!
suffix : With an account, you will be able to follow people, post updates and exchange messages with users from any Mastodon server and more!
2016-11-15 14:56:03 -08:00
didnt_get_confirmation : Didn't receive confirmation instructions?
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
dont_have_your_security_key : Don't have your security key?
2016-11-15 14:56:03 -08:00
forgot_password : Forgot your password?
2017-08-07 08:20:21 -07:00
invalid_reset_password_token : Password reset token is invalid or expired. Please request a new one.
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
link_to_otp : Enter a two-factor code from your phone or a recovery code
link_to_webauth : Use your security key device
2016-11-15 14:02:57 -08:00
login : Log in
2017-01-27 18:56:10 -08:00
logout : Logout
2017-11-27 13:47:06 -08:00
migrate_account : Move to a different account
migrate_account_html : If you wish to redirect this account to a different one, you can <a href="%{path}">configure it here</a>.
2018-02-03 20:42:13 -08:00
or_log_in_with : Or log in with
providers :
cas : CAS
saml : SAML
2016-11-15 14:02:57 -08:00
register : Sign up
2019-03-12 09:34:00 -07:00
registration_closed : "%{instance} is not accepting new members"
2016-11-15 14:02:57 -08:00
resend_confirmation : Resend confirmation instructions
reset_password : Reset password
2018-03-06 16:39:40 -08:00
security : Security
2016-11-15 14:02:57 -08:00
set_new_password : Set new password
Change unconfirmed user login behaviour (#11375)
Allow access to account settings, 2FA, authorized applications, and
account deletions to unconfirmed and pending users, as well as
users who had their accounts disabled. Suspended users cannot update
their e-mail or password or delete their account.
Display account status on account settings page, for example, when
an account is frozen, limited, unconfirmed or pending review.
After sign up, login users straight away and show a simple page that
tells them the status of their account with links to account settings
and logout, to reduce onboarding friction and allow users to correct
wrongly typed e-mail addresses.
Move the final sign-up step of SSO integrations to be the same
as above to reduce code duplication.
2019-07-22 01:48:50 -07:00
setup :
email_below_hint_html : If the below e-mail address is incorrect, you can change it here and receive a new confirmation e-mail.
email_settings_hint_html : The confirmation e-mail was sent to %{email}. If that e-mail address is not correct, you can change it in account settings.
title : Setup
status :
account_status : Account status
confirming : Waiting for e-mail confirmation to be completed.
2019-08-06 10:40:06 -07:00
functional : Your account is fully operational.
Change unconfirmed user login behaviour (#11375)
Allow access to account settings, 2FA, authorized applications, and
account deletions to unconfirmed and pending users, as well as
users who had their accounts disabled. Suspended users cannot update
their e-mail or password or delete their account.
Display account status on account settings page, for example, when
an account is frozen, limited, unconfirmed or pending review.
After sign up, login users straight away and show a simple page that
tells them the status of their account with links to account settings
and logout, to reduce onboarding friction and allow users to correct
wrongly typed e-mail addresses.
Move the final sign-up step of SSO integrations to be the same
as above to reduce code duplication.
2019-07-22 01:48:50 -07:00
pending : Your application is pending review by our staff. This may take some time. You will receive an e-mail if your application is approved.
2019-09-19 11:58:19 -07:00
redirecting_to : Your account is inactive because it is currently redirecting to %{acct}.
2020-12-09 21:27:26 -08:00
too_fast : Form submitted too fast, try again.
2019-03-12 09:34:00 -07:00
trouble_logging_in : Trouble logging in?
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
use_security_key : Use security key
2016-12-29 07:54:54 -08:00
authorize_follow :
2018-03-24 04:50:41 -07:00
already_following : You are already following this account
2020-02-24 12:19:19 -08:00
already_requested : You have already sent a follow request to that account
2016-12-29 07:54:54 -08:00
error : Unfortunately, there was an error looking up the remote account
follow : Follow
2017-07-10 09:05:06 -07:00
follow_request : 'You have sent a follow request to:'
2017-07-11 18:24:04 -07:00
following : 'Success! You are now following:'
2017-07-10 09:05:06 -07:00
post_follow :
close : Or, you can just close this window.
2018-06-03 18:00:36 -07:00
return : Show the user's profile
2017-07-11 18:24:04 -07:00
web : Go to web
2016-12-29 07:54:54 -08:00
title : Follow %{acct}
2019-09-18 07:37:27 -07:00
challenge :
confirm : Continue
hint_html : "<strong>Tip:</strong> We won't ask you for your password again for the next hour."
invalid_password : Invalid password
prompt : Confirm password to continue
2020-06-02 10:24:53 -07:00
crypto :
errors :
invalid_key : is not a valid Ed25519 or Curve25519 key
invalid_signature : is not a valid Ed25519 signature
2020-01-23 13:00:13 -08:00
date :
formats :
default : "%b %d, %Y"
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
with_month_name : "%B %d, %Y"
2016-12-18 10:47:11 -08:00
datetime :
distance_in_words :
about_x_hours : "%{count}h"
about_x_months : "%{count}mo"
about_x_years : "%{count}y"
almost_x_years : "%{count}y"
half_a_minute : Just now
less_than_x_minutes : "%{count}m"
less_than_x_seconds : Just now
over_x_years : "%{count}y"
x_days : "%{count}d"
x_minutes : "%{count}m"
x_months : "%{count}mo"
x_seconds : "%{count}s"
2017-06-14 09:01:27 -07:00
deletes :
2019-09-15 12:08:39 -07:00
challenge_not_passed : The information you entered was not correct
2017-06-14 09:01:27 -07:00
confirm_password : Enter your current password to verify your identity
2019-09-15 12:08:39 -07:00
confirm_username : Enter your username to confirm the procedure
2017-06-14 09:01:27 -07:00
proceed : Delete account
success_msg : Your account was successfully deleted
2019-09-03 19:13:54 -07:00
warning :
before : 'Before proceeding, please read these notes carefully:'
caches : Content that has been cached by other servers may persist
data_removal : Your posts and other data will be permanently removed
email_change_html : You can <a href="%{path}">change your e-mail address</a> without deleting your account
email_contact_html : If it still doesn't arrive, you can e-mail <a href="mailto:%{email}">%{email}</a> for help
email_reconfirmation_html : If you are not receiving the confirmation e-mail, you can <a href="%{path}">request it again</a>
irreversible : You will not be able to restore or reactivate your account
more_details_html : For more details, see the <a href="%{terms_path}">privacy policy</a>.
username_available : Your username will become available again
username_unavailable : Your username will remain unavailable
2018-12-06 08:36:11 -08:00
directories :
directory : Profile directory
explanation : Discover users based on their interests
explore_mastodon : Explore %{title}
2019-08-08 14:04:19 -07:00
domain_validator :
invalid_domain : is not a valid domain name
2017-04-13 10:18:32 -07:00
errors :
2019-08-29 16:34:47 -07:00
'400' : The request you submitted was invalid or malformed.
2017-04-22 20:21:10 -07:00
'403' : You don't have permission to view this page.
2019-01-31 15:07:08 -08:00
'404' : The page you are looking for isn't here.
2019-08-29 16:34:47 -07:00
'406' : This page is not available in the requested format.
2019-01-31 15:07:08 -08:00
'410' : The page you were looking for doesn't exist here anymore.
2017-04-13 10:18:32 -07:00
'422' :
content : Security verification failed. Are you blocking cookies?
title : Security verification failed
2020-03-08 07:17:39 -07:00
'429' : Too many requests
2017-09-25 14:05:54 -07:00
'500' :
content : We're sorry, but something went wrong on our end.
title : This page is not correct
2019-08-29 16:34:47 -07:00
'503' : The page could not be served due to a temporary server failure.
2018-10-05 22:33:36 -07:00
noscript_html : To use the Mastodon web application, please enable JavaScript. Alternatively, try one of the <a href="%{apps_path}">native apps</a> for Mastodon for your platform.
2019-03-23 06:07:04 -07:00
existing_username_validator :
not_found : could not find a local user with that username
not_found_multiple : could not find %{usernames}
2017-03-19 12:29:41 -07:00
exports :
2018-02-21 14:21:32 -08:00
archive_takeout :
date : Date
download : Download your archive
2021-04-21 09:31:24 -07:00
hint_html : You can request an archive of your <strong>posts and uploaded media</strong>. The exported data will be in the ActivityPub format, readable by any compliant software. You can request an archive every 7 days.
2018-02-21 14:21:32 -08:00
in_progress : Compiling your archive...
request : Request your archive
size : Size
2017-03-19 12:29:41 -07:00
blocks : You block
2020-11-19 08:48:13 -08:00
bookmarks : Bookmarks
2017-03-19 12:29:41 -07:00
csv : CSV
2019-01-05 10:13:11 -08:00
domain_blocks : Domain blocks
lists : Lists
2017-04-13 10:18:32 -07:00
mutes : You mute
2017-03-19 12:29:41 -07:00
storage : Media storage
2019-02-03 19:25:59 -08:00
featured_tags :
add_new : Add new
errors :
limit : You have already featured the maximum amount of hashtags
2019-08-17 09:07:52 -07:00
hint_html : "<strong>What are featured hashtags?</strong> They are displayed prominently on your public profile and allow people to browse your public posts specifically under those hashtags. They are a great tool for keeping track of creative works or long-term projects."
2018-06-29 06:34:36 -07:00
filters :
contexts :
2020-01-23 12:32:00 -08:00
account : Profiles
2020-11-10 16:18:42 -08:00
home : Home and lists
2018-06-29 06:34:36 -07:00
notifications : Notifications
public : Public timelines
thread : Conversations
edit :
title : Edit filter
errors :
invalid_context : None or invalid context supplied
invalid_irreversible : Irreversible filtering only works with home or notifications context
index :
delete : Delete
2020-01-07 01:41:19 -08:00
empty : You have no filters.
2018-06-29 06:34:36 -07:00
title : Filters
new :
title : Add new filter
2018-07-28 10:25:33 -07:00
footer :
developers : Developers
more : More…
resources : Resources
2019-08-18 05:55:32 -07:00
trending_now : Trending now
2016-11-15 14:02:57 -08:00
generic :
2019-03-16 03:23:22 -07:00
all : All
2016-11-15 14:56:03 -08:00
changes_saved_msg : Changes successfully saved!
2018-10-08 15:12:37 -07:00
copy : Copy
2020-01-23 13:00:13 -08:00
delete : Delete
2021-11-25 04:07:38 -08:00
none : None
2019-03-31 20:50:05 -07:00
order_by : Order by
2016-11-15 14:02:57 -08:00
save_changes : Save changes
2021-12-05 12:48:39 -08:00
today : today
2016-11-15 14:02:57 -08:00
validation_errors :
one : Something isn't quite right yet! Please review the error below
other : Something isn't quite right yet! Please review %{count} errors below
2019-03-23 06:07:04 -07:00
html_validator :
2019-03-26 09:33:26 -07:00
invalid_markup: 'contains invalid HTML markup : %{error}'
2017-03-30 10:42:33 -07:00
imports :
2020-12-18 00:18:31 -08:00
errors :
over_rows_processing_limit : contains more than %{count} rows
2019-02-02 18:59:51 -08:00
modes :
merge : Merge
merge_long : Keep existing records and add new ones
overwrite : Overwrite
overwrite_long : Replace current records with the new ones
2019-02-05 10:11:24 -08:00
preface : You can import data that you have exported from another server, such as a list of the people you are following or blocking.
2021-05-23 18:03:01 -07:00
success : Your data was successfully uploaded and will be processed in due time
2017-03-30 10:42:33 -07:00
types :
blocking : Blocking list
2020-11-19 08:48:13 -08:00
bookmarks : Bookmarks
2019-02-02 18:59:51 -08:00
domain_blocking : Domain blocking list
2017-03-30 10:42:33 -07:00
following : Following list
2017-04-12 09:20:44 -07:00
muting : Muting list
2017-03-30 10:42:33 -07:00
upload : Upload
2017-11-07 10:06:44 -08:00
in_memoriam_html : In Memoriam.
2017-11-27 07:07:59 -08:00
invites :
2017-11-28 06:41:02 -08:00
delete : Deactivate
expired : Expired
2017-11-27 07:07:59 -08:00
expires_in :
'1800' : 30 minutes
'21600' : 6 hours
'3600' : 1 hour
'43200' : 12 hours
2018-03-24 04:50:14 -07:00
'604800' : 1 week
2017-11-27 07:07:59 -08:00
'86400' : 1 day
expires_in_prompt : Never
2019-10-03 13:37:13 -07:00
generate : Generate invite link
2018-06-15 09:00:23 -07:00
invited_by : 'You were invited by:'
2017-11-27 07:07:59 -08:00
max_uses :
one : 1 use
other : "%{count} uses"
max_uses_prompt : No limit
2019-02-05 10:11:24 -08:00
prompt : Generate and share links with others to grant access to this server
2017-11-27 07:07:59 -08:00
table :
expires_at : Expires
uses : Uses
title : Invite people
2017-12-08 16:32:29 -08:00
lists :
errors :
limit : You have reached the maximum amount of lists
2021-06-21 08:07:30 -07:00
login_activities :
authentication_methods :
otp : two-factor authentication app
password : password
sign_in_token : e-mail security code
webauthn : security keys
description_html : If you see activity that you don't recognize, consider changing your password and enabling two-factor authentication.
empty : No authentication history available
failed_sign_in_html : Failed sign-in attempt with %{method} from %{ip} (%{browser})
successful_sign_in_html : Successful sign-in with %{method} from %{ip} (%{browser})
title : Authentication history
2017-04-08 13:20:08 -07:00
media_attachments :
validations :
2021-04-21 09:31:24 -07:00
images_and_video : Cannot attach a video to a post that already contains images
2020-03-08 15:56:18 -07:00
not_ready : Cannot attach files that have not finished processing. Try again in a moment!
2017-04-08 13:20:08 -07:00
too_many : Cannot attach more than 4 files
2017-11-27 13:47:06 -08:00
migrations :
2019-09-19 11:58:19 -07:00
acct : Moved to
cancel : Cancel redirect
cancel_explanation : Cancelling the redirect will re-activate your current account, but will not bring back followers that have been moved to that account.
cancelled_msg : Successfully cancelled the redirect.
errors :
already_moved : is the same account you have already moved to
2020-05-12 12:38:24 -07:00
missing_also_known_as : is not an alias of this account
2019-09-19 11:58:19 -07:00
move_to_self : cannot be current account
not_found : could not be found
on_cooldown : You are on cooldown
followers_count : Followers at time of move
incoming_migrations : Moving from a different account
incoming_migrations_html : To move from another account to this one, first you need to <a href="%{path}">create an account alias</a>.
moved_msg : Your account is now redirecting to %{acct} and your followers are being moved over.
not_redirecting : Your account is not redirecting to any other account currently.
on_cooldown : You have recently migrated your account. This function will become available again in %{count} days.
past_migrations : Past migrations
proceed_with_move : Move followers
2020-06-03 11:18:19 -07:00
redirected_msg : Your account is now redirecting to %{acct}.
2019-09-19 11:58:19 -07:00
redirecting_to : Your account is redirecting to %{acct}.
2019-09-28 20:03:19 -07:00
set_redirect : Set redirect
2019-09-19 11:58:19 -07:00
warning :
backreference_required : The new account must first be configured to back-reference this one
before : 'Before proceeding, please read these notes carefully:'
2021-05-23 18:03:01 -07:00
cooldown : After moving there is a waiting period during which you will not be able to move again
2019-09-19 11:58:19 -07:00
disabled_account : Your current account will not be fully usable afterwards. However, you will have access to data export as well as re-activation.
followers : This action will move all followers from the current account to the new account
2019-09-28 20:03:19 -07:00
only_redirect_html : Alternatively, you can <a href="%{path}">only put up a redirect on your profile</a>.
2019-09-19 11:58:19 -07:00
other_data : No other data will be moved automatically
2019-09-28 20:03:19 -07:00
redirect : Your current account's profile will be updated with a redirect notice and be excluded from searches
2017-11-23 17:05:53 -08:00
moderation :
title : Moderation
2020-06-30 10:19:50 -07:00
move_handler :
2020-07-01 04:51:15 -07:00
carry_blocks_over_text : This user moved from %{acct}, which you had blocked.
carry_mutes_over_text : This user moved from %{acct}, which you had muted.
2020-06-30 10:19:50 -07:00
copy_account_note_text : 'This user moved from %{acct}, here were your previous notes about them:'
2016-11-15 14:56:03 -08:00
notification_mailer :
2017-03-19 12:29:41 -07:00
digest :
2018-01-16 11:20:15 -08:00
action : View all notifications
body : Here is a brief summary of the messages you missed since your last visit on %{since}
2017-03-19 12:29:41 -07:00
mention : "%{name} mentioned you in:"
new_followers_summary :
2018-01-16 11:20:15 -08:00
one : Also, you have acquired one new follower while being away! Yay!
other : Also, you have acquired %{count} new followers while being away! Amazing!
2017-03-19 12:29:41 -07:00
subject :
one : "1 new notification since your last visit \U0001F418"
other : "%{count} new notifications since your last visit \U0001F418"
2018-05-22 06:26:42 -07:00
title : In your absence...
2016-11-15 14:56:03 -08:00
favourite :
2021-04-21 09:31:24 -07:00
body : 'Your post was favourited by %{name}:'
subject : "%{name} favourited your post"
2018-01-16 11:20:15 -08:00
title : New favourite
2016-11-15 14:56:03 -08:00
follow :
body : "%{name} is now following you!"
subject : "%{name} is now following you"
2018-01-16 11:20:15 -08:00
title : New follower
2016-12-26 12:52:03 -08:00
follow_request :
2018-01-16 11:20:15 -08:00
action : Manage follow requests
2016-12-26 12:52:03 -08:00
body : "%{name} has requested to follow you"
subject: 'Pending follower : %{name}'
2018-01-16 11:20:15 -08:00
title : New follow request
2016-11-15 14:56:03 -08:00
mention :
2018-01-16 11:20:15 -08:00
action : Reply
2016-11-15 14:56:03 -08:00
body : 'You were mentioned by %{name} in:'
subject : You were mentioned by %{name}
2018-01-16 11:20:15 -08:00
title : New mention
2021-03-19 12:22:49 -07:00
poll :
2021-03-19 15:47:31 -07:00
subject : A poll by %{name} has ended
2016-11-15 14:56:03 -08:00
reblog :
2021-04-21 09:31:24 -07:00
body : 'Your post was boosted by %{name}:'
subject : "%{name} boosted your post"
2018-01-16 11:20:15 -08:00
title : New boost
2021-03-19 09:15:59 -07:00
status :
subject : "%{name} just posted"
2019-11-29 08:03:06 -08:00
notifications :
email_events : Events for e-mail notifications
email_events_hint : 'Select events that you want to receive notifications for:'
other_settings : Other notifications settings
2017-08-27 08:04:45 -07:00
number :
human :
decimal_units :
format : "%n%u"
units :
billion : B
million : M
quadrillion : Q
thousand : K
trillion : T
unit : ''
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
otp_authentication :
code_hint : Enter the code generated by your authenticator app to confirm
description_html : If you enable <strong>two-factor authentication</strong> using an authenticator app, logging in will require you to be in possession of your phone, which will generate tokens for you to enter.
enable : Enable
2021-05-23 18:03:01 -07:00
instructions_html : "<strong>Scan this QR code into Google Authenticator or a similar TOTP app on your phone</strong>. From now on, that app will generate tokens that you will have to enter when logging in."
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
manual_instructions : 'If you can' 't scan the QR code and need to enter it manually, here is the plain-text secret:'
setup : Set up
wrong_code : The entered code was invalid! Are server time and device time correct?
2016-11-15 14:02:57 -08:00
pagination :
2018-02-25 18:31:28 -08:00
newer : Newer
2016-11-15 14:02:57 -08:00
next : Next
2018-02-25 18:31:28 -08:00
older : Older
2016-11-15 14:02:57 -08:00
prev : Prev
2017-04-10 16:11:41 -07:00
truncate : "…"
2019-03-03 13:18:23 -08:00
polls :
errors :
already_voted : You have already voted on this poll
duplicate_options : contain duplicate items
duration_too_long : is too far into the future
duration_too_short : is too soon
expired : The poll has already ended
2020-01-12 05:17:03 -08:00
invalid_choice : The chosen vote option does not exist
2019-03-05 19:54:11 -08:00
over_character_limit : cannot be longer than %{max} characters each
2019-03-03 13:18:23 -08:00
too_few_options : must have more than one item
2019-03-05 19:54:11 -08:00
too_many_options : can't contain more than %{max} items
2017-10-01 01:52:39 -07:00
preferences :
other : Other
2019-06-06 18:39:24 -07:00
posting_defaults : Posting defaults
public_timelines : Public timelines
2020-01-23 13:00:13 -08:00
reactions :
errors :
2020-01-24 20:23:33 -08:00
limit_reached : Limit of different reactions reached
2020-01-23 13:00:13 -08:00
unrecognized_emoji : is not a recognized emoji
2019-03-16 03:23:22 -07:00
relationships :
2019-03-17 19:53:17 -07:00
activity : Account activity
dormant : Dormant
2020-11-12 07:58:00 -08:00
follow_selected_followers : Follow selected followers
2019-11-30 22:08:40 -08:00
followers : Followers
following : Following
2020-01-23 11:33:20 -08:00
invited : Invited
2019-03-27 18:16:01 -07:00
last_active : Last active
most_recent : Most recent
2019-03-17 19:53:17 -07:00
moved : Moved
2019-03-16 03:23:22 -07:00
mutual : Mutual
2019-03-17 19:53:17 -07:00
primary : Primary
2019-03-16 03:23:22 -07:00
relationship : Relationship
remove_selected_domains : Remove all followers from the selected domains
remove_selected_followers : Remove selected followers
remove_selected_follows : Unfollow selected users
status : Account status
2017-01-01 10:52:25 -08:00
remote_follow :
2018-08-17 18:03:12 -07:00
acct : Enter your username@domain you want to act from
2017-01-01 10:52:25 -08:00
missing_resource : Could not find the required redirect URL for your account
2018-06-30 19:12:34 -07:00
no_account_html : Don't have an account? You can <a href='%{sign_up_path}' target='_blank'>sign up here</a>
2017-01-01 10:52:25 -08:00
proceed : Proceed to follow
prompt : 'You are going to follow:'
2019-01-07 06:36:26 -08:00
reason_html : "<strong>Why is this step necessary?</strong> <code>%{instance}</code> might not be the server where you are registered, so we need to redirect you to your home server first."
2018-08-17 18:03:12 -07:00
remote_interaction :
2019-01-07 06:36:26 -08:00
favourite :
proceed : Proceed to favourite
2021-04-21 09:31:24 -07:00
prompt : 'You want to favourite this post:'
2019-01-07 06:36:26 -08:00
reblog :
proceed : Proceed to boost
2021-04-21 09:31:24 -07:00
prompt : 'You want to boost this post:'
2019-01-07 06:36:26 -08:00
reply :
proceed : Proceed to reply
2021-04-21 09:31:24 -07:00
prompt : 'You want to reply to this post:'
2019-01-05 03:43:28 -08:00
scheduled_statuses :
2021-05-23 18:03:01 -07:00
over_daily_limit : You have exceeded the limit of %{limit} scheduled posts for today
2021-04-21 09:31:24 -07:00
over_total_limit : You have exceeded the limit of %{limit} scheduled posts
2019-01-05 03:43:28 -08:00
too_soon : The scheduled date must be in the future
2017-06-25 07:54:30 -07:00
sessions :
activity : Last activity
browser : Browser
browsers :
alipay : Alipay
blackberry : Blackberry
chrome : Chrome
edge : Microsoft Edge
2018-01-14 21:50:29 -08:00
electron : Electron
2017-06-25 07:54:30 -07:00
firefox : Firefox
generic : Unknown browser
ie : Internet Explorer
micro_messenger : MicroMessenger
nokia : Nokia S40 Ovi Browser
opera : Opera
2018-01-14 21:50:29 -08:00
otter : Otter
2017-06-25 07:54:30 -07:00
phantom_js : PhantomJS
qq : QQ Browser
safari : Safari
uc_browser : UCBrowser
weibo : Weibo
current_session : Current session
description : "%{browser} on %{platform}"
explanation : These are the web browsers currently logged in to your Mastodon account.
ip : IP
platforms :
adobe_air : Adobe Air
android : Android
blackberry : Blackberry
2021-05-23 18:03:01 -07:00
chrome_os : Chrome OS
2017-06-25 07:54:30 -07:00
firefox_os : Firefox OS
ios : iOS
linux : Linux
2020-01-23 15:21:13 -08:00
mac : macOS
2017-06-25 07:54:30 -07:00
other : unknown platform
windows : Windows
windows_mobile : Windows Mobile
windows_phone : Windows Phone
2017-07-18 19:59:04 -07:00
revoke : Revoke
revoke_success : Session successfully revoked
2017-06-25 07:54:30 -07:00
title : Sessions
2021-06-21 08:07:30 -07:00
view_authentication_history : View authentication history of your account
2016-11-15 14:02:57 -08:00
settings :
2019-04-09 18:47:11 -07:00
account : Account
account_settings : Account settings
2019-09-19 11:58:19 -07:00
aliases : Account aliases
2019-04-10 08:36:45 -07:00
appearance : Appearance
2017-03-19 12:29:41 -07:00
authorized_apps : Authorized apps
2017-01-15 05:01:33 -08:00
back : Back to Mastodon
2017-06-14 09:01:27 -07:00
delete : Account deletion
2017-08-22 15:59:35 -07:00
development : Development
2016-11-15 14:02:57 -08:00
edit_profile : Edit profile
2017-02-26 15:15:00 -08:00
export : Data export
2019-02-03 19:25:59 -08:00
featured_tags : Featured hashtags
2017-03-30 10:42:33 -07:00
import : Import
2019-04-09 18:47:11 -07:00
import_and_export : Import and export
2017-11-27 13:47:06 -08:00
migrate : Account migration
2017-10-04 01:22:52 -07:00
notifications : Notifications
2016-11-15 14:02:57 -08:00
preferences : Preferences
2019-04-09 18:47:11 -07:00
profile : Profile
2019-03-16 03:23:22 -07:00
relationships : Follows and followers
2021-08-09 14:11:50 -07:00
statuses_cleanup : Automated post deletion
2017-12-12 22:42:22 -08:00
two_factor_authentication : Two-factor Auth
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
webauthn_authentication : Security keys
2017-01-24 15:49:08 -08:00
statuses :
2018-03-18 12:33:07 -07:00
attached :
2020-06-24 16:33:01 -07:00
audio :
one : "%{count} audio"
other : "%{count} audio"
2018-03-18 12:33:07 -07:00
description: 'Attached : %{attached}'
image :
one : "%{count} image"
other : "%{count} images"
video :
one : "%{count} video"
other : "%{count} videos"
2018-05-12 08:44:15 -07:00
boosted_from_html : Boosted from %{acct_link}
2018-03-18 12:33:07 -07:00
content_warning: 'Content warning : %{warning}'
2018-04-23 14:52:58 -07:00
disallowed_hashtags :
one: 'contained a disallowed hashtag : %{tags}'
other: 'contained the disallowed hashtags : %{tags}'
2020-03-28 09:59:45 -07:00
errors :
2021-04-21 09:31:24 -07:00
in_reply_not_found : The post you are trying to reply to does not appear to exist.
2018-06-17 09:57:31 -07:00
language_detection : Automatically detect language
2017-01-30 14:01:37 -08:00
open_in_web : Open in web
2017-02-06 14:16:20 -08:00
over_character_limit : character limit of %{max} exceeded
2017-08-24 16:41:18 -07:00
pin_errors :
2021-04-21 09:31:24 -07:00
limit : You have already pinned the maximum number of posts
ownership : Someone else's post cannot be pinned
private : Non-public posts cannot be pinned
2017-08-24 16:41:18 -07:00
reblog : A boost cannot be pinned
2019-03-04 09:03:12 -08:00
poll :
2019-09-29 13:58:01 -07:00
total_people :
one : "%{count} person"
other : "%{count} people"
2019-03-04 09:03:12 -08:00
total_votes :
one : "%{count} vote"
other : "%{count} votes"
vote : Vote
2017-03-31 04:54:36 -07:00
show_more : Show more
2020-11-04 12:15:45 -08:00
show_newer : Show newer
show_older : Show older
2020-01-29 08:35:54 -08:00
show_thread : Show thread
2018-08-18 03:48:27 -07:00
sign_in_to_participate : Sign in to participate in the conversation
2017-12-11 18:56:30 -08:00
title : '%{name}: "%{quote}"'
2017-02-06 14:16:20 -08:00
visibilities :
2021-04-21 06:40:00 -07:00
direct : Direct
2017-04-23 15:38:37 -07:00
private : Followers-only
private_long : Only show to followers
2017-02-06 14:16:20 -08:00
public : Public
2017-04-23 15:38:37 -07:00
public_long : Everyone can see
unlisted : Unlisted
unlisted_long : Everyone can see, but not listed on public timelines
2021-08-09 14:11:50 -07:00
statuses_cleanup :
enabled : Automatically delete old posts
enabled_hint : Automatically deletes your posts once they reach a specified age threshold, unless they match one of the exceptions below
exceptions : Exceptions
explanation : Because deleting posts is an expensive operation, this is done slowly over time when the server is not otherwise busy. For this reason, your posts may be deleted a while after they reach the age threshold.
ignore_favs : Ignore favourites
ignore_reblogs : Ignore boosts
interaction_exceptions : Exceptions based on interactions
interaction_exceptions_explanation : Note that there is no guarantee for posts to be deleted if they go below the favourite or boost threshold after having once gone over them.
keep_direct : Keep direct messages
keep_direct_hint : Doesn't delete any of your direct messages
keep_media : Keep posts with media attachments
keep_media_hint : Doesn't delete any of your posts that have media attachments
keep_pinned : Keep pinned posts
keep_pinned_hint : Doesn't delete any of your pinned posts
keep_polls : Keep polls
keep_polls_hint : Doesn't delete any of your polls
keep_self_bookmark : Keep posts you bookmarked
keep_self_bookmark_hint : Doesn't delete your own posts if you have bookmarked them
keep_self_fav : Keep posts you favourited
keep_self_fav_hint : Doesn't delete your own posts if you have favourited them
min_age :
'1209600' : 2 weeks
'15778476' : 6 months
'2629746' : 1 month
'31556952' : 1 year
'5259492' : 2 months
'63113904' : 2 years
'7889238' : 3 months
min_age_label : Age threshold
2021-10-14 12:11:14 -07:00
min_favs : Keep posts favourited at least
min_favs_hint : Doesn't delete any of your posts that has received at least this amount of favourites. Leave blank to delete posts regardless of their number of favourites
min_reblogs : Keep posts boosted at least
min_reblogs_hint : Doesn't delete any of your posts that has been boosted at least this number of times. Leave blank to delete posts regardless of their number of boosts
2016-11-15 14:56:03 -08:00
stream_entries :
2021-04-21 09:31:24 -07:00
pinned : Pinned post
2016-12-20 15:13:13 -08:00
reblogged : boosted
2016-12-22 15:04:52 -08:00
sensitive_content : Sensitive content
2019-08-05 10:54:29 -07:00
tags :
does_not_match_previous_name : does not match the previous name
2017-07-04 06:19:24 -07:00
terms :
body_html : |
<h2>Privacy Policy</h2>
<h3 id="collect">What information do we collect?</h3>
2018-04-04 12:47:39 -07:00
<ul>
<li><em>Basic account information</em> : If you register on this server, you may be asked to enter a username, an e-mail address and a password. You may also enter additional profile information such as a display name and biography, and upload a profile picture and header image. The username, display name, biography, profile picture and header image are always listed publicly.</li>
<li><em>Posts, following and other public information</em> : The list of people you follow is listed publicly, the same is true for your followers. When you submit a message, the date and time is stored as well as the application you submitted the message from. Messages may contain media attachments, such as pictures and videos. Public and unlisted posts are available publicly. When you feature a post on your profile, that is also publicly available information. Your posts are delivered to your followers, in some cases it means they are delivered to different servers and copies are stored there. When you delete posts, this is likewise delivered to your followers. The action of reblogging or favouriting another post is always public.</li>
<li><em>Direct and followers-only posts</em> : All posts are stored and processed on the server. Followers-only posts are delivered to your followers and users who are mentioned in them, and direct posts are delivered only to users mentioned in them. In some cases it means they are delivered to different servers and copies are stored there. We make a good faith effort to limit the access to those posts only to authorized persons, but other servers may fail to do so. Therefore it's important to review servers your followers belong to. You may toggle an option to approve and reject new followers manually in the settings. <em>Please keep in mind that the operators of the server and any receiving server may view such messages</em>, and that recipients may screenshot, copy or otherwise re-share them. <em>Do not share any dangerous information over Mastodon.</em></li>
<li><em>IPs and other metadata</em> : When you log in, we record the IP address you log in from, as well as the name of your browser application. All the logged in sessions are available for your review and revocation in the settings. The latest IP address used is stored for up to 12 months. We also may retain server logs which include the IP address of every request to our server.</li>
</ul>
2017-07-04 06:19:24 -07:00
2018-04-04 12:47:39 -07:00
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
<h3 id="use">What do we use your information for?</h3>
2018-04-04 12:47:39 -07:00
<p>Any of the information we collect from you may be used in the following ways:</p>
2017-07-04 06:19:24 -07:00
<ul>
2018-04-04 12:47:39 -07:00
<li>To provide the core functionality of Mastodon. You can only interact with other people's content and post your own content when you are logged in. For example, you may follow other people to view their combined posts in your own personalized home timeline.</li>
<li>To aid moderation of the community, for example comparing your IP address with other known ones to determine ban evasion or other violations.</li>
<li>The email address you provide may be used to send you information, notifications about other people interacting with your content or sending you messages, and to respond to inquiries, and/or other requests or questions.</li>
2017-07-04 06:19:24 -07:00
</ul>
2018-04-04 12:47:39 -07:00
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
<h3 id="protect">How do we protect your information?</h3>
2018-04-04 12:47:39 -07:00
<p>We implement a variety of security measures to maintain the safety of your personal information when you enter, submit, or access your personal information. Among other things, your browser session, as well as the traffic between your applications and the API, are secured with SSL, and your password is hashed using a strong one-way algorithm. You may enable two-factor authentication to further secure access to your account.</p>
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
2018-04-04 12:47:39 -07:00
<h3 id="data-retention">What is our data retention policy?</h3>
2017-07-04 06:19:24 -07:00
<p>We will make a good faith effort to:</p>
<ul>
2018-04-04 12:47:39 -07:00
<li>Retain server logs containing the IP address of all requests to this server, in so far as such logs are kept, no more than 90 days.</li>
<li>Retain the IP addresses associated with registered users no more than 12 months.</li>
2017-07-04 06:19:24 -07:00
</ul>
2018-04-04 12:47:39 -07:00
<p>You can request and download an archive of your content, including your posts, media attachments, profile picture, and header image.</p>
<p>You may irreversibly delete your account at any time.</p>
<hr class="spacer"/>
2017-07-04 06:19:24 -07:00
<h3 id="cookies">Do we use cookies?</h3>
<p>Yes. Cookies are small files that a site or its service provider transfers to your computer's hard drive through your Web browser (if you allow). These cookies enable the site to recognize your browser and, if you have a registered account, associate it with your registered account.</p>
2018-04-04 12:47:39 -07:00
<p>We use cookies to understand and save your preferences for future visits.</p>
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
<h3 id="disclose">Do we disclose any information to outside parties?</h3>
2018-04-04 12:47:39 -07:00
<p>We do not sell, trade, or otherwise transfer to outside parties your personally identifiable information. This does not include trusted third parties who assist us in operating our site, conducting our business, or servicing you, so long as those parties agree to keep this information confidential. We may also release your information when we believe release is appropriate to comply with the law, enforce our site policies, or protect ours or others rights, property, or safety.</p>
<p>Your public content may be downloaded by other servers in the network. Your public and followers-only posts are delivered to the servers where your followers reside, and direct messages are delivered to the servers of the recipients, in so far as those followers or recipients reside on a different server than this.</p>
2017-07-04 06:19:24 -07:00
2018-04-04 12:47:39 -07:00
<p>When you authorize an application to use your account, depending on the scope of permissions you approve, it may access your public profile information, your following list, your followers, your lists, all your posts, and your favourites. Applications can never access your e-mail address or password.</p>
2017-07-04 06:19:24 -07:00
2018-04-04 12:47:39 -07:00
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
2018-05-25 05:27:14 -07:00
<h3 id="children">Site usage by children</h3>
2017-07-04 06:19:24 -07:00
2018-05-25 05:27:14 -07:00
<p>If this server is in the EU or the EEA : Our site, products and services are all directed to people who are at least 16 years old. If you are under the age of 16, per the requirements of the GDPR (<a href="https://en.wikipedia.org/wiki/General_Data_Protection_Regulation">General Data Protection Regulation</a>) do not use this site.</p>
<p>If this server is in the USA : Our site, products and services are all directed to people who are at least 13 years old. If you are under the age of 13, per the requirements of COPPA (<a href="https://en.wikipedia.org/wiki/Children%27s_Online_Privacy_Protection_Act">Children's Online Privacy Protection Act</a>) do not use this site.</p>
<p>Law requirements can be different if this server is in another jurisdiction.</p>
2017-07-04 06:19:24 -07:00
2018-04-04 12:47:39 -07:00
<hr class="spacer" />
2017-07-04 06:19:24 -07:00
<h3 id="changes">Changes to our Privacy Policy</h3>
<p>If we decide to change our privacy policy, we will post those changes on this page.</p>
2018-04-04 12:47:39 -07:00
<p>This document is CC-BY-SA. It was last updated March 7, 2018.</p>
2017-07-04 06:19:24 -07:00
2017-07-19 00:43:46 -07:00
<p>Originally adapted from the <a href="https://github.com/discourse/discourse">Discourse privacy policy</a>.</p>
2017-07-04 06:19:24 -07:00
title : "%{instance} Terms of Service and Privacy Policy"
2017-09-20 10:41:35 -07:00
themes :
2019-01-31 15:15:38 -08:00
contrast : Mastodon (High contrast)
default : Mastodon (Dark)
mastodon-light : Mastodon (Light)
2016-12-18 10:47:11 -08:00
time :
formats :
default : "%b %d, %Y, %H:%M"
2018-07-28 10:25:33 -07:00
month : "%b %Y"
2017-04-21 19:23:17 -07:00
two_factor_authentication :
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
add : Add
disable : Disable 2FA
disabled_success : Two-factor authentication successfully disabled
edit : Edit
2017-06-25 14:51:46 -07:00
enabled : Two-factor authentication is enabled
2017-04-08 13:20:08 -07:00
enabled_success : Two-factor authentication successfully enabled
2017-06-25 14:51:46 -07:00
generate_recovery_codes : Generate recovery codes
2017-04-15 04:26:03 -07:00
lost_recovery_codes : Recovery codes allow you to regain access to your account if you lose your phone. If you've lost your recovery codes, you can regenerate them here. Your old recovery codes will be invalidated.
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
methods : Two-factor methods
otp : Authenticator app
2017-06-25 14:51:46 -07:00
recovery_codes : Backup recovery codes
2017-04-15 04:26:03 -07:00
recovery_codes_regenerated : Recovery codes successfully regenerated
2017-06-26 15:04:00 -07:00
recovery_instructions_html : If you ever lose access to your phone, you can use one of the recovery codes below to regain access to your account. <strong>Keep the recovery codes safe</strong>. For example, you may print them and store them with other important documents.
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
webauthn : Security keys
2018-01-18 10:17:25 -08:00
user_mailer :
2018-02-21 14:21:32 -08:00
backup_ready :
explanation : You requested a full backup of your Mastodon account. It's now ready for download!
subject : Your archive is ready for download
title : Archive takeout
2020-06-09 01:23:06 -07:00
sign_in_token :
details : 'Here are details of the attempt:'
explanation : 'We detected an attempt to sign in to your account from an unrecognized IP address. If this is you, please enter the security code below on the sign in challenge page:'
further_actions : 'If this wasn' 't you, please change your password and enable two-factor authentication on your account. You can do so here:'
subject : Please confirm attempted sign in
title : Sign in attempt
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
warning :
explanation :
2020-09-15 05:37:58 -07:00
disable : You can no longer login to your account or use it in any other way, but your profile and other data remains intact.
2020-11-04 11:45:01 -08:00
sensitive : Your uploaded media files and linked media will be treated as sensitive.
2021-04-21 09:31:24 -07:00
silence : You can still use your account but only people who are already following you will see your posts on this server, and you may be excluded from various public listings. However, others may still manually follow you.
2020-09-15 05:37:58 -07:00
suspend : You can no longer use your account, and your profile and other data are no longer accessible. You can still login to request a backup of your data until the data is fully removed, but we will retain some data to prevent you from evading the suspension.
2019-08-23 13:37:23 -07:00
get_in_touch : You can reply to this e-mail to get in touch with the staff of %{instance}.
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
review_server_policies : Review server policies
2019-08-23 13:37:23 -07:00
statuses : 'Specifically, for:'
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
subject :
disable : Your account %{acct} has been frozen
none : Warning for %{acct}
2020-11-04 11:45:01 -08:00
sensitive : Your account %{acct} posting media has been marked as sensitive
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
silence : Your account %{acct} has been limited
suspend : Your account %{acct} has been suspended
title :
disable : Account frozen
none : Warning
2020-11-04 11:45:01 -08:00
sensitive : Your media has been marked as sensitive
Add moderation warnings (#9519)
* Add moderation warnings
Replace individual routes for disabling, silencing, and suspending
a user, as well as the report update route, with a unified account
action controller that allows you to select an action (none,
disable, silence, suspend) as well as whether it should generate an
e-mail notification with optional custom text. That notification,
with the optional custom text, is saved as a warning.
Additionally, there are warning presets you can configure to save
time when performing the above.
* Use Account#local_username_and_domain
2018-12-22 11:02:09 -08:00
silence : Account limited
suspend : Account suspended
2018-01-18 10:17:25 -08:00
welcome :
edit_profile_action : Setup profile
edit_profile_step : You can customize your profile by uploading an avatar, header, changing your display name and more. If you’ d like to review new followers before they’ re allowed to follow you, you can lock your account.
explanation : Here are some tips to get you started
final_action : Start posting
2021-05-17 13:31:35 -07:00
final_step : 'Start posting! Even without followers your public posts may be seen by others, for example on the local timeline and in hashtags. You may want to introduce yourself on the #introductions hashtag.'
2018-01-18 10:17:25 -08:00
full_handle : Your full handle
2019-02-05 10:11:24 -08:00
full_handle_hint : This is what you would tell your friends so they can message or follow you from another server.
2018-01-18 10:17:25 -08:00
review_preferences_action : Change preferences
review_preferences_step : Make sure to set your preferences, such as which emails you'd like to receive, or what privacy level you’ d like your posts to default to. If you don’ t have motion sickness, you could choose to enable GIF autoplay.
subject : Welcome to Mastodon
tip_federated_timeline : The federated timeline is a firehose view of the Mastodon network. But it only includes people your neighbours are subscribed to, so it's not complete.
tip_following : You follow your server's admin(s) by default. To find more interesting people, check the local and federated timelines.
tip_local_timeline : The local timeline is a firehose view of people on %{instance}. These are your immediate neighbours!
tip_mobile_webapp : If your mobile browser offers you to add Mastodon to your homescreen, you can receive push notifications. It acts like a native app in many ways!
tips : Tips
title : Welcome aboard, %{name}!
2016-12-04 10:07:02 -08:00
users :
2018-10-04 08:36:11 -07:00
follow_limit_reached : You cannot follow more than %{limit} people
2020-06-09 01:23:06 -07:00
generic_access_help_html : Trouble accessing your account? You may get in touch with %{email} for assistance
2017-01-28 11:43:38 -08:00
invalid_otp_token : Invalid two-factor code
2020-06-09 01:23:06 -07:00
invalid_sign_in_token : Invalid security code
2018-05-06 01:52:36 -07:00
otp_lost_help_html : If you lost access to both, you may get in touch with %{email}
2018-02-28 10:04:53 -08:00
seamless_external_login : You are logged in via an external service, so password and e-mail settings are not available.
2017-08-04 19:24:58 -07:00
signed_in_as : 'Signed in as:'
2021-09-04 07:44:50 -07:00
suspicious_sign_in_confirmation : You appear to not have logged in from this device before, so we're sending a security code to your e-mail address to confirm that it's you.
2018-09-18 07:45:58 -07:00
verification :
explanation_html : 'You can <strong>verify yourself as the owner of the links in your profile metadata</strong>. For that, the linked website must contain a link back to your Mastodon profile. The link back <strong>must</strong> have a <code>rel="me"</code> attribute. The text content of the link does not matter. Here is an example:'
verification : Verification
Add WebAuthn as an alternative 2FA method (#14466)
* feat: add possibility of adding WebAuthn security keys to use as 2FA
This adds a basic UI for enabling WebAuthn 2FA. We did a little refactor
to the Settings page for editing the 2FA methods – now it will list the
methods that are available to the user (TOTP and WebAuthn) and from
there they'll be able to add or remove any of them.
Also, it's worth mentioning that for enabling WebAuthn it's required to
have TOTP enabled, so the first time that you go to the 2FA Settings
page, you'll be asked to set it up.
This work was inspired by the one donde by Github in their platform, and
despite it could be approached in different ways, we decided to go with
this one given that we feel that this gives a great UX.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add request for WebAuthn as second factor at login if enabled
This commits adds the feature for using WebAuthn as a second factor for
login when enabled.
If users have WebAuthn enabled, now a page requesting for the use of a
WebAuthn credential for log in will appear, although a link redirecting
to the old page for logging in using a two-factor code will also be
present.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: add possibility of deleting WebAuthn Credentials
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: disable WebAuthn when an Admin disables 2FA for a user
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* feat: remove ability to disable TOTP leaving only WebAuthn as 2FA
Following examples form other platforms like Github, we decided to make
Webauthn 2FA secondary to 2FA with TOTP, so that we removed the
possibility of removing TOTP authentication only, leaving users with
just WEbAuthn as 2FA. Instead, users will have to click on 'Disable 2FA'
in order to remove second factor auth.
The reason for WebAuthn being secondary to TOPT is that in that way,
users will still be able to log in using their code from their phone's
application if they don't have their security keys with them – or maybe
even lost them.
* We had to change a little the flow for setting up TOTP, given that now
it's possible to setting up again if you already had TOTP, in order to
let users modify their authenticator app – given that now it's not
possible for them to disable TOTP and set it up again with another
authenticator app.
So, basically, now instead of storing the new `otp_secret` in the
user, we store it in the session until the process of set up is
finished.
This was because, as it was before, when users clicked on 'Edit' in
the new two-factor methods lists page, but then went back without
finishing the flow, their `otp_secret` had been changed therefore
invalidating their previous authenticator app, making them unable to
log in again using TOTP.
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
* refactor: fix eslint errors
The PR build was failing given that linting returning some errors.
This commit attempts to fix them.
* refactor: normalize i18n translations
The build was failing given that i18n translations files were not
normalized.
This commits fixes that.
* refactor: avoid having the webauthn gem locked to a specific version
* refactor: use symbols for routes without '/'
* refactor: avoid sending webauthn disabled email when 2FA is disabled
When an admins disable 2FA for users, we were sending two mails
to them, one notifying that 2FA was disabled and the other to notify
that WebAuthn was disabled.
As the second one is redundant since the first email includes it, we can
remove it and send just one email to users.
* refactor: avoid creating new env variable for webauthn_origin config
* refactor: improve flash error messages for webauthn pages
Co-authored-by: Facundo Padula <facundo.padula@cedarcode.com>
2020-08-24 07:46:27 -07:00
webauthn_credentials :
add : Add new security key
create :
error : There was a problem adding your security key. Please try again.
success : Your security key was successfully added.
delete : Delete
delete_confirmation : Are you sure you want to delete this security key?
description_html : If you enable <strong>security key authentication</strong>, logging in will require you to use one of your security keys.
destroy :
error : There was a problem deleting you security key. Please try again.
success : Your security key was successfully deleted.
invalid_credential : Invalid security key
nickname_hint : Enter the nickname of your new security key
not_enabled : You haven't enabled WebAuthn yet
not_supported : This browser doesn't support security keys
otp_required : To use security keys please enable two-factor authentication first.
registered_on : Registered on %{date}