@ -1,2 +1,2 @@ | |||||
web: bundle exec puma -C config/puma.rb | web: bundle exec puma -C config/puma.rb | ||||
worker: bundle exec sidekiq -q default -q mailers -q push | |||||
worker: bundle exec sidekiq -q default -q push -q pull -q mailers |
@ -0,0 +1,68 @@ | |||||
const eo = { | |||||
"column_back_button.label": "Reveni", | |||||
"lightbox.close": "Fermi", | |||||
"loading_indicator.label": "Ŝarĝanta...", | |||||
"status.mention": "Mencii @{name}", | |||||
"status.delete": "Forigi", | |||||
"status.reply": "Respondi", | |||||
"status.reblog": "Diskonigi", | |||||
"status.favourite": "Favori", | |||||
"status.reblogged_by": "{name} diskonigita", | |||||
"status.sensitive_warning": "Tikla enhavo", | |||||
"status.sensitive_toggle": "Alklaki por vidi", | |||||
"video_player.toggle_sound": "Aktivigi sonojn", | |||||
"account.mention": "Mencii @{name}", | |||||
"account.edit_profile": "Redakti la profilon", | |||||
"account.unblock": "Malbloki @{name}", | |||||
"account.unfollow": "Malsekvi", | |||||
"account.block": "Bloki @{name}", | |||||
"account.follow": "Sekvi", | |||||
"account.posts": "Mesaĝoj", | |||||
"account.follows": "Sekvatoj", | |||||
"account.followers": "Sekvantoj", | |||||
"account.follows_you": "Sekvas vin", | |||||
"account.requested": "Atendas aprobon", | |||||
"getting_started.heading": "Por komenci", | |||||
"getting_started.about_addressing": "Vi povas sekvi homojn se vi konas la uzantnomon kaj domajnon tajpinte retpoŝtecan adreson en la serĉilon.", | |||||
"getting_started.about_shortcuts": "Se la celita uzanto troviĝas en la sama domajno de vi, uzi nur la uzantnomon sufiĉos. La sama regulo validas por mencii aliajn uzantojn en mesaĝo.", | |||||
"getting_started.open_source_notice": "Mastodon estas malfermitkoda programo. Vi povas kontribui aŭ raporti problemojn en github je {github}. {apps}.", | |||||
"column.home": "Hejmo", | |||||
"column.community": "Loka tempolinio", | |||||
"column.public": "Fratara tempolinio", | |||||
"column.notifications": "Sciigoj", | |||||
"tabs_bar.compose": "Ekskribi", | |||||
"tabs_bar.home": "Hejmo", | |||||
"tabs_bar.mentions": "Sciigoj", | |||||
"tabs_bar.public": "Fratara tempolinio", | |||||
"tabs_bar.notifications": "Sciigoj", | |||||
"compose_form.placeholder": "Pri kio vi pensas?", | |||||
"compose_form.publish": "Hup", | |||||
"compose_form.sensitive": "Marki ke la enhavo estas tikla", | |||||
"compose_form.spoiler": "Kaŝi la tekston malantaŭ averto", | |||||
"compose_form.private": "Marki ke la enhavo estas privata", | |||||
"compose_form.privacy_disclaimer": "Via privata mesaĝo estos sendita nur al menciitaj uzantoj en {domains}. Ĉu vi fidas {domainsCount, plural, one {tiun servilon} other {tiujn servilojn}}? Mesaĝa privateco funkcias nur en aperaĵoj de Mastodon. Se {domains} {domainsCount, plural, one {ne estas aperaĵo de Mastodon} other {ne estas aperaĵoj de Mastodon}}, estos neniu indiko ke via mesaĝo estas privata, kaj ĝi povus esti diskonigita aŭ videbligita al necelitaj ricevantoj.", | |||||
"compose_form.unlisted": "Ne afiŝi en publikaj tempolinioj", | |||||
"navigation_bar.edit_profile": "Redakti la profilon", | |||||
"navigation_bar.preferences": "Preferoj", | |||||
"navigation_bar.community_timeline": "Loka tempolinio", | |||||
"navigation_bar.public_timeline": "Fratara tempolinio", | |||||
"navigation_bar.logout": "Elsaluti", | |||||
"reply_indicator.cancel": "Rezigni", | |||||
"search.placeholder": "Serĉi", | |||||
"search.account": "Konto", | |||||
"search.hashtag": "Kradvorto", | |||||
"upload_button.label": "Aldoni enhavaĵon", | |||||
"upload_form.undo": "Malfari", | |||||
"notification.follow": "{name} sekvis vin", | |||||
"notification.favourite": "{name} favoris vian mesaĝon", | |||||
"notification.reblog": "{name} diskonigis vian mesaĝon", | |||||
"notification.mention": "{name} menciis vin", | |||||
"notifications.column_settings.alert": "Retumilaj atentigoj", | |||||
"notifications.column_settings.show": "Montri en kolono", | |||||
"notifications.column_settings.follow": "Novaj sekvantoj:", | |||||
"notifications.column_settings.favourite": "Favoroj:", | |||||
"notifications.column_settings.mention": "Mencioj:", | |||||
"notifications.column_settings.reblog": "Diskonigoj:", | |||||
}; | |||||
export default eo; |
@ -0,0 +1,19 @@ | |||||
# frozen_string_literal: true | |||||
module Localized | |||||
extend ActiveSupport::Concern | |||||
included do | |||||
before_action :set_locale | |||||
end | |||||
def set_locale | |||||
I18n.locale = current_user.try(:locale) || default_locale | |||||
rescue I18n::InvalidLocale | |||||
I18n.locale = default_locale | |||||
end | |||||
def default_locale | |||||
ENV.fetch('DEFAULT_LOCALE') { I18n.default_locale } | |||||
end | |||||
end |
@ -0,0 +1,16 @@ | |||||
# frozen_string_literal: true | |||||
class Oauth::AuthorizedApplicationsController < Doorkeeper::AuthorizedApplicationsController | |||||
include Localized | |||||
skip_before_action :authenticate_resource_owner! | |||||
before_action :store_current_location | |||||
before_action :authenticate_resource_owner! | |||||
private | |||||
def store_current_location | |||||
store_location_for(:user, request.url) | |||||
end | |||||
end |
@ -0,0 +1,351 @@ | |||||
# frozen_string_literal: true | |||||
class AtomSerializer | |||||
include RoutingHelper | |||||
class << self | |||||
def render(element) | |||||
document = Ox::Document.new(version: '1.0') | |||||
document << element | |||||
('<?xml version="1.0"?>' + Ox.dump(element)).force_encoding('UTF-8') | |||||
end | |||||
end | |||||
def author(account) | |||||
author = Ox::Element.new('author') | |||||
uri = TagManager.instance.uri_for(account) | |||||
append_element(author, 'id', uri) | |||||
append_element(author, 'activity:object-type', TagManager::TYPES[:person]) | |||||
append_element(author, 'uri', uri) | |||||
append_element(author, 'name', account.username) | |||||
append_element(author, 'email', account.local? ? "#{account.acct}@#{Rails.configuration.x.local_domain}" : account.acct) | |||||
append_element(author, 'summary', account.note) | |||||
append_element(author, 'link', nil, rel: :alternate, type: 'text/html', href: TagManager.instance.url_for(account)) | |||||
append_element(author, 'link', nil, rel: :avatar, type: account.avatar_content_type, 'media:width': 120, 'media:height': 120, href: full_asset_url(account.avatar.url(:original))) | |||||
append_element(author, 'link', nil, rel: :header, type: account.header_content_type, 'media:width': 700, 'media:height': 335, href: full_asset_url(account.header.url(:original))) | |||||
append_element(author, 'poco:preferredUsername', account.username) | |||||
append_element(author, 'poco:displayName', account.display_name) unless account.display_name.blank? | |||||
append_element(author, 'poco:note', Formatter.instance.simplified_format(account).to_str) unless account.note.blank? | |||||
append_element(author, 'mastodon:scope', account.locked? ? :private : :public) | |||||
author | |||||
end | |||||
def feed(account, stream_entries) | |||||
feed = Ox::Element.new('feed') | |||||
add_namespaces(feed) | |||||
append_element(feed, 'id', account_url(account, format: 'atom')) | |||||
append_element(feed, 'title', account.display_name) | |||||
append_element(feed, 'subtitle', account.note) | |||||
append_element(feed, 'updated', account.updated_at.iso8601) | |||||
append_element(feed, 'logo', full_asset_url(account.avatar.url(:original))) | |||||
feed << author(account) | |||||
append_element(feed, 'link', nil, rel: :alternate, type: 'text/html', href: TagManager.instance.url_for(account)) | |||||
append_element(feed, 'link', nil, rel: :self, type: 'application/atom+xml', href: account_url(account, format: 'atom')) | |||||
append_element(feed, 'link', nil, rel: :next, type: 'application/atom+xml', href: account_url(account, format: 'atom', max_id: stream_entries.last.id)) if stream_entries.size == 20 | |||||
append_element(feed, 'link', nil, rel: :hub, href: api_push_url) | |||||
append_element(feed, 'link', nil, rel: :salmon, href: api_salmon_url(account.id)) | |||||
stream_entries.each do |stream_entry| | |||||
feed << entry(stream_entry) | |||||
end | |||||
feed | |||||
end | |||||
def entry(stream_entry, root = false) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) if root | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(stream_entry.created_at, stream_entry.activity_id, stream_entry.activity_type)) | |||||
append_element(entry, 'published', stream_entry.created_at.iso8601) | |||||
append_element(entry, 'updated', stream_entry.updated_at.iso8601) | |||||
append_element(entry, 'title', stream_entry&.status&.title) | |||||
entry << author(stream_entry.account) if root | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[stream_entry.object_type]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[stream_entry.verb]) | |||||
entry << object(stream_entry.target) if stream_entry.targeted? | |||||
serialize_status_attributes(entry, stream_entry.status) unless stream_entry.status.nil? | |||||
append_element(entry, 'link', nil, rel: :alternate, type: 'text/html', href: account_stream_entry_url(stream_entry.account, stream_entry)) | |||||
append_element(entry, 'link', nil, rel: :self, type: 'application/atom+xml', href: account_stream_entry_url(stream_entry.account, stream_entry, format: 'atom')) | |||||
append_element(entry, 'thr:in-reply-to', nil, ref: TagManager.instance.uri_for(stream_entry.thread), href: TagManager.instance.url_for(stream_entry.thread)) if stream_entry.threaded? | |||||
entry | |||||
end | |||||
def object(status) | |||||
object = Ox::Element.new('activity:object') | |||||
append_element(object, 'id', TagManager.instance.uri_for(status)) | |||||
append_element(object, 'published', status.created_at.iso8601) | |||||
append_element(object, 'updated', status.updated_at.iso8601) | |||||
append_element(object, 'title', status.title) | |||||
object << author(status.account) | |||||
append_element(object, 'activity:object-type', TagManager::TYPES[status.object_type]) | |||||
append_element(object, 'activity:verb', TagManager::VERBS[status.verb]) | |||||
serialize_status_attributes(object, status) | |||||
append_element(object, 'link', nil, rel: :alternate, type: 'text/html', href: TagManager.instance.url_for(status)) | |||||
append_element(object, 'thr:in-reply-to', nil, ref: TagManager.instance.uri_for(status.thread), href: TagManager.instance.url_for(status.thread)) if status.reply? && !status.thread.nil? | |||||
object | |||||
end | |||||
def follow_salmon(follow) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{follow.account.acct} started following #{follow.target_account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(follow.created_at, follow.id, 'Follow')) | |||||
append_element(entry, 'title', description) | |||||
append_element(entry, 'content', description, type: :html) | |||||
entry << author(follow.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:follow]) | |||||
object = author(follow.target_account) | |||||
object.value = 'activity:object' | |||||
entry << object | |||||
entry | |||||
end | |||||
def follow_request_salmon(follow_request) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(follow_request.created_at, follow_request.id, 'FollowRequest')) | |||||
append_element(entry, 'title', "#{follow_request.account.acct} requested to follow #{follow_request.target_account.acct}") | |||||
entry << author(follow_request.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:request_friend]) | |||||
object = author(follow_request.target_account) | |||||
object.value = 'activity:object' | |||||
entry << object | |||||
entry | |||||
end | |||||
def authorize_follow_request_salmon(follow_request) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, follow_request.id, 'FollowRequest')) | |||||
append_element(entry, 'title', "#{follow_request.target_account.acct} authorizes follow request by #{follow_request.account.acct}") | |||||
entry << author(follow_request.target_account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:authorize]) | |||||
object = Ox::Element.new('activity:object') | |||||
object << author(follow_request.account) | |||||
append_element(object, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(object, 'activity:verb', TagManager::VERBS[:request_friend]) | |||||
inner_object = author(follow_request.target_account) | |||||
inner_object.value = 'activity:object' | |||||
object << inner_object | |||||
entry << object | |||||
entry | |||||
end | |||||
def reject_follow_request_salmon(follow_request) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, follow_request.id, 'FollowRequest')) | |||||
append_element(entry, 'title', "#{follow_request.target_account.acct} rejects follow request by #{follow_request.account.acct}") | |||||
entry << author(follow_request.target_account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:reject]) | |||||
object = Ox::Element.new('activity:object') | |||||
object << author(follow_request.account) | |||||
append_element(object, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(object, 'activity:verb', TagManager::VERBS[:request_friend]) | |||||
inner_object = author(follow_request.target_account) | |||||
inner_object.value = 'activity:object' | |||||
object << inner_object | |||||
entry << object | |||||
entry | |||||
end | |||||
def unfollow_salmon(follow) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{follow.account.acct} is no longer following #{follow.target_account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, follow.id, 'Follow')) | |||||
append_element(entry, 'title', description) | |||||
append_element(entry, 'content', description, type: :html) | |||||
entry << author(follow.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:unfollow]) | |||||
object = author(follow.target_account) | |||||
object.value = 'activity:object' | |||||
entry << object | |||||
entry | |||||
end | |||||
def block_salmon(block) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{block.account.acct} no longer wishes to interact with #{block.target_account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, block.id, 'Block')) | |||||
append_element(entry, 'title', description) | |||||
entry << author(block.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:block]) | |||||
object = author(block.target_account) | |||||
object.value = 'activity:object' | |||||
entry << object | |||||
entry | |||||
end | |||||
def unblock_salmon(block) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{block.account.acct} no longer blocks #{block.target_account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, block.id, 'Block')) | |||||
append_element(entry, 'title', description) | |||||
entry << author(block.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:unblock]) | |||||
object = author(block.target_account) | |||||
object.value = 'activity:object' | |||||
entry << object | |||||
entry | |||||
end | |||||
def favourite_salmon(favourite) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{favourite.account.acct} favourited a status by #{favourite.status.account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(favourite.created_at, favourite.id, 'Favourite')) | |||||
append_element(entry, 'title', description) | |||||
append_element(entry, 'content', description, type: :html) | |||||
entry << author(favourite.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:favorite]) | |||||
entry << object(favourite.status) | |||||
append_element(entry, 'thr:in-reply-to', nil, ref: TagManager.instance.uri_for(favourite.status), href: TagManager.instance.url_for(favourite.status)) | |||||
entry | |||||
end | |||||
def unfavourite_salmon(favourite) | |||||
entry = Ox::Element.new('entry') | |||||
add_namespaces(entry) | |||||
description = "#{favourite.account.acct} no longer favourites a status by #{favourite.status.account.acct}" | |||||
append_element(entry, 'id', TagManager.instance.unique_tag(Time.now.utc, favourite.id, 'Favourite')) | |||||
append_element(entry, 'title', description) | |||||
append_element(entry, 'content', description, type: :html) | |||||
entry << author(favourite.account) | |||||
append_element(entry, 'activity:object-type', TagManager::TYPES[:activity]) | |||||
append_element(entry, 'activity:verb', TagManager::VERBS[:unfavorite]) | |||||
entry << object(favourite.status) | |||||
append_element(entry, 'thr:in-reply-to', nil, ref: TagManager.instance.uri_for(favourite.status), href: TagManager.instance.url_for(favourite.status)) | |||||
entry | |||||
end | |||||
private | |||||
def append_element(parent, name, content = nil, attributes = {}) | |||||
element = Ox::Element.new(name) | |||||
attributes.each { |k, v| element[k] = v.to_s } | |||||
element << content.to_s unless content.nil? | |||||
parent << element | |||||
end | |||||
def add_namespaces(parent) | |||||
parent['xmlns'] = TagManager::XMLNS | |||||
parent['xmlns:thr'] = TagManager::THR_XMLNS | |||||
parent['xmlns:activity'] = TagManager::AS_XMLNS | |||||
parent['xmlns:poco'] = TagManager::POCO_XMLNS | |||||
parent['xmlns:media'] = TagManager::MEDIA_XMLNS | |||||
parent['xmlns:ostatus'] = TagManager::OS_XMLNS | |||||
parent['xmlns:mastodon'] = TagManager::MTDN_XMLNS | |||||
end | |||||
def serialize_status_attributes(entry, status) | |||||
append_element(entry, 'summary', status.spoiler_text) unless status.spoiler_text.blank? | |||||
append_element(entry, 'content', Formatter.instance.format(status.proper).to_str, type: 'html') | |||||
status.mentions.each do |mentioned| | |||||
append_element(entry, 'link', nil, rel: :mentioned, 'ostatus:object-type': TagManager::TYPES[:person], href: TagManager.instance.uri_for(mentioned.account)) | |||||
end | |||||
append_element(entry, 'link', nil, rel: :mentioned, 'ostatus:object-type': TagManager::TYPES[:collection], href: TagManager::COLLECTIONS[:public]) if status.public_visibility? | |||||
status.tags.each do |tag| | |||||
append_element(entry, 'category', nil, term: tag.name) | |||||
end | |||||
append_element(entry, 'category', nil, term: 'nsfw') if status.sensitive? | |||||
status.media_attachments.each do |media| | |||||
append_element(entry, 'link', nil, rel: :enclosure, type: media.file_content_type, length: media.file_file_size, href: full_asset_url(media.file.url(:original, false))) | |||||
end | |||||
append_element(entry, 'mastodon:scope', status.visibility) | |||||
end | |||||
end |
@ -1,27 +0,0 @@ | |||||
# frozen_string_literal: true | |||||
Nokogiri::XML::Builder.new do |xml| | |||||
feed(xml) do | |||||
simple_id xml, account_url(@account, format: 'atom') | |||||
title xml, @account.display_name | |||||
subtitle xml, @account.note | |||||
updated_at xml, stream_updated_at | |||||
logo xml, full_asset_url(@account.avatar.url(:original)) | |||||
author(xml) do | |||||
include_author xml, @account | |||||
end | |||||
link_alternate xml, TagManager.instance.url_for(@account) | |||||
link_self xml, account_url(@account, format: 'atom') | |||||
link_next xml, account_url(@account, format: 'atom', max_id: @entries.last.id) if @entries.size == 20 | |||||
link_hub xml, api_push_url | |||||
link_salmon xml, api_salmon_url(@account.id) | |||||
@entries.each do |stream_entry| | |||||
entry(xml, false) do | |||||
include_entry xml, stream_entry | |||||
end | |||||
end | |||||
end | |||||
end.to_xml |
@ -1,9 +0,0 @@ | |||||
Nokogiri::XML::Builder.new do |xml| | |||||
entry(xml, true) do | |||||
author(xml) do | |||||
include_author xml, @stream_entry.account | |||||
end | |||||
include_entry xml, @stream_entry | |||||
end | |||||
end.to_xml |
@ -0,0 +1,5 @@ | |||||
<p>Tervetuloa <%= @resource.email %>!</p> | |||||
<p>Voit vahvistaa Mastodon tilisi klikkaamalla alla olevaa linkkiä:</p> | |||||
<p><%= link_to 'Varmista tilini', confirmation_url(@resource, confirmation_token: @token) %></p> |
@ -0,0 +1,5 @@ | |||||
Tervetuloa <%= @resource.email %>! | |||||
Voit vahvistaa Mastodon tilisi klikkaamalla alla olevaa linkkiä: | |||||
<%= confirmation_url(@resource, confirmation_token: @token) %> |
@ -0,0 +1,3 @@ | |||||
<p>Hei <%= @resource.email %>!</p> | |||||
<p>Lähetämme tämän viestin ilmoittaaksemme että salasanasi on vaihdettu.</p> |
@ -0,0 +1,3 @@ | |||||
Hei <%= @resource.email %>! | |||||
Lähetämme tämän viestin ilmoittaaksemme että salasanasi on vaihdettu. |
@ -0,0 +1,8 @@ | |||||
<p>Hei <%= @resource.email %>!</p> | |||||
<p>Joku on pyytänyt salasanvaihto Mastodonissa. Voit tehdä sen allaolevassa linkissä.</p> | |||||
<p><%= link_to 'Vaihda salasanani', edit_password_url(@resource, reset_password_token: @token) %></p> | |||||
<p>Jos et pyytänyt vaihtoa, poista tämä viesti.</p> | |||||
<p>Salasanaasi ei vaihdeta ennen kuin menet ylläolevaan linkkiin ja luot uuden.</p> |
@ -0,0 +1,8 @@ | |||||
Hei <%= @resource.email %>! | |||||
Joku on pyytänyt salasanvaihto Mastodonissa. Voit tehdä sen allaolevassa linkissä. | |||||
<%= edit_password_url(@resource, reset_password_token: @token) %> | |||||
Jos et pyytänyt vaihtoa, poista tämä viesti. | |||||
Salasanaasi ei vaihdeta ennen kuin menet ylläolevaan linkkiin ja luot uuden. |
@ -0,0 +1,61 @@ | |||||
--- | |||||
eo: | |||||
devise: | |||||
confirmations: | |||||
confirmed: Via konto estas konfirmita. | |||||
send_instructions: Vi ricevos instrukciojn por konfirmi vian konton post kelkaj minutoj. | |||||
send_paranoid_instructions: Se via retpoŝt-adreso ekzistas en nia datumbazo, vi baldaŭ ricevos retpoŝt-mesaĝon, kiu enhavas la instrukciojn por konfirmi vian konton. | |||||
failure: | |||||
already_authenticated: Vi jam estas ensalutita. | |||||
inactive: Via konto ankoraŭ ne estas konfirmita. | |||||
invalid: Malĝusta retpoŝt-adreso aŭ pasvorto. | |||||
last_attempt: Vi ankoraŭ povas provi unufoje antaŭ ol via konto estos ŝlosita. | |||||
locked: Via konto estas ŝlosita. | |||||
not_found_in_database: Malĝusta retpoŝt-adreso aŭ pasvorto. | |||||
timeout: Via sesio eksiĝis. Bonvolu reensaluti por daŭrigi. | |||||
unauthenticated: Vi devas ensaluti aŭ membriĝi por daŭrigi. | |||||
unconfirmed: Vi devas konfirmi vian konton por daŭrigi. | |||||
mailer: | |||||
confirmation_instructions: | |||||
subject: Instrukcioj por konfirmi | |||||
password_change: | |||||
subject: Via pasvorto estis ŝanĝita senprobleme. | |||||
reset_password_instructions: | |||||
subject: Instrukcioj por ŝanĝi la pasvorton | |||||
unlock_instructions: | |||||
subject: Instrukcioj por malŝlosi la konton | |||||
omniauth_callbacks: | |||||
failure: 'Ni ne povis aŭtentigi vin per %{kind}: ''%{reason}''.' | |||||
success: Aŭtentigita senprobleme per %{kind}. | |||||
passwords: | |||||
no_token: Vi ne povas iri al tiu paĝo per alia vojo ol retpoŝt-mesaĝo por ŝanĝi pasvorton. Se vi venas de tia retpoŝt-mesaĝo, kontrolu ke vi uzis la tutan URL. | |||||
send_instructions: Vi ricevos retpoŝt-mesaĝon kun instrukcioj por ŝanĝi vian pasvorton post kelkaj minutoj. | |||||
send_paranoid_instructions: Se via retpoŝt-adreso ekzistas en nia datumbazo, vi ricevos ligilon por ŝanĝi vian pasvorton per retpoŝt-mesaĝo. | |||||
updated: Via pasvorto estis redaktita senprobleme, vi nun estas ensalutita. | |||||
updated_not_active: Via pasvorto estis redaktita senprobleme. | |||||
registrations: | |||||
destroyed: Ĝis! Via konto estis forigita senprobleme. Ni esperas revidi vin baldaŭ. | |||||
signed_up: Bonvenon! Vi membriĝis senprobleme. | |||||
signed_up_but_inactive: Vi bone membriĝis, sed vi ankoraŭ ne povas ensaluti ĉar via konto ne estis konfirmita. | |||||
signed_up_but_locked: Vi bone membriĝis, sed vi ne povas ensaluti ĉar via konto estas ŝlosita. | |||||
signed_up_but_unconfirmed: Retpoŝt-mesaĝo kun via ligilo por konfirmi vian konton estis sendita al via retpoŝt-adreso. Bonvolu uzi tiun ligilon por konfirmi vian konton. | |||||
update_needs_confirmation: Vi bone aktualigis vian konton, sed ni bezonas kontroli vian novan retpoŝt-adreson. Bonvolu kontroli viajn retpoŝt-mesaĝojn kaj uzi la ligilon por konfirmi vian novan retpoŝt-adreson. | |||||
updated: Via konto estis aktualigita senprobleme. | |||||
sessions: | |||||
already_signed_out: Elsalutita. | |||||
signed_in: Ensalutita. | |||||
signed_out: Elsalutita. | |||||
unlocks: | |||||
send_instructions: Vi ricevos retpoŝt-mesaĝon kun instrukcioj por malŝlosi vian konton post kelkaj minutoj. | |||||
send_paranoid_instructions: Se via retpoŝt-adreso ekzistas en nia datumbazo, vi ricevos ligilon por malŝlosi vian konton per retpoŝt-mesaĝo. | |||||
unlocked: Via konto estis malŝlosita senprobleme, vi nun estas ensalutita. | |||||
errors: | |||||
messages: | |||||
already_confirmed: jam estis konfirmita, bonvolu provi ensaluti | |||||
confirmation_period_expired: devas esti konfirmita en %{period}, bonvolu repeti | |||||
expired: eksiĝis, bonvolu repeti | |||||
not_found: ne estis trovita | |||||
not_locked: ne estis ŝlosita | |||||
not_saved: | |||||
one: '1 eraro malpermesis al tiu %{resource} esti konservita:' | |||||
other: '%{count} eraroj malpermesis al tiu %{resource} esti konservita:' |
@ -0,0 +1,113 @@ | |||||
--- | |||||
eo: | |||||
activerecord: | |||||
attributes: | |||||
doorkeeper/application: | |||||
name: Nomo | |||||
redirect_uri: URI de plusendo | |||||
errors: | |||||
models: | |||||
doorkeeper/application: | |||||
attributes: | |||||
redirect_uri: | |||||
fragment_present: ne povas enhavi eron. | |||||
invalid_uri: devas esti valida URI. | |||||
relative_uri: devas esti absoluta URI. | |||||
secured_uri: devas esti HTTPS/SSL-a URI. | |||||
doorkeeper: | |||||
applications: | |||||
buttons: | |||||
authorize: Rajtigi | |||||
cancel: Rezigni | |||||
destroy: Detrui | |||||
edit: Redakti | |||||
submit: Sendi | |||||
confirmations: | |||||
destroy: Ĉu vi certas? | |||||
edit: | |||||
title: Redakti aplikaĵon | |||||
form: | |||||
error: Ups! Kontrolu vian formularon ĉu estas eraroj | |||||
help: | |||||
native_redirect_uri: Uzu %{native_redirect_uri} por lokaj provoj | |||||
redirect_uri: Uzu unu linion por ĉiu URI | |||||
scopes: Apartigu ampleksojn per spacetoj. Lasu malplena por uzi la senŝanĝajn ampleksojn. | |||||
index: | |||||
callback_url: URL vokita per referenco | |||||
name: Nomo | |||||
new: Nova Aplikaĵo | |||||
title: Viaj aplikaĵoj | |||||
new: | |||||
title: Nova aplikaĵo | |||||
show: | |||||
actions: Agoj | |||||
application_id: Identigo de la aplikaĵo | |||||
callback_urls: URL-j vokitaj per referenco | |||||
scopes: Ampleksoj | |||||
secret: Sekreto | |||||
title: 'Aplikaĵo: %{name}' | |||||
authorizations: | |||||
buttons: | |||||
authorize: Rajtigi | |||||
deny: Rifuzi | |||||
error: | |||||
title: Eraro okazis | |||||
new: | |||||
able_to: Povos | |||||
prompt: La aplikaĵo %{client_name} petas aliron al via konto | |||||
title: Rajtigo bezonata | |||||
show: | |||||
title: Rajtiga kodo | |||||
authorized_applications: | |||||
buttons: | |||||
revoke: Malrajtigi | |||||
confirmations: | |||||
revoke: Ĉu vi certas? | |||||
index: | |||||
application: Aplikaĵo | |||||
created_at: Rajtigita | |||||
date_format: "%Y-%m-%d %H:%M:%S" | |||||
scopes: Ampleksoj | |||||
title: Viaj rajtigitaj aplikaĵoj | |||||
errors: | |||||
messages: | |||||
access_denied: La posedanto de la rimedo aŭ la rajtiga servilo rifuzis vian peton. | |||||
credential_flow_not_configured: La sendado de la identigiloj de la posedanto de la rimedo malsukcesis ĉar Doorkeeper.configure.resource_owner_from_credentials ne estis agordita. | |||||
invalid_client: La aŭtentigo de la kliento malsukcesis ĉar la kliento estas nekonata, aŭ mankis peto aŭtentigi, aŭ la aŭtentig-metodo ne estas subtenata. | |||||
invalid_grant: La rajtiga konsento ne estas valida, ne plu estas valida, estis forigita, ne kongruas kun la plusenda URI uzita en la aŭtentiga peto, aŭ estis sendita al alia kliento. | |||||
invalid_redirect_uri: La plusenda URI uzita en estas valida. | |||||
invalid_request: Mankis al la peto nepra parametro, enhavas nesubtenatan parametran valoron, aŭ la peto simple estas misformita. | |||||
invalid_resource_owner: La donitaj identigiloj pri la posedanto de la rimedo ne estas validaj, aŭ tiu ne povas esti trovita. | |||||
invalid_scope: La petita amplekso ne estas valida, estas nekonata, aŭ estas misformita. | |||||
invalid_token: | |||||
expired: La atingoĵetono eskiĝis. | |||||
revoked: La atingoĵetono estis rifuzita. | |||||
unknown: La atingoĵetono ne estas valida. | |||||
resource_owner_authenticator_not_configured: La posedanto de la rimedo ne povis esti trovita ĉar Doorkeeper.configure.resource_owner_authenticator ne estas agordita. | |||||
server_error: La rajtiga servilo rimarkis neatenditan kondiĉon, kiu malpermesis al ĝi plenumi la peton. | |||||
temporarily_unavailable: La rajtiga servilo ne povas nun plenumi la peton pro dumtempa superŝarĝo aŭ prizorgado de la servilo. | |||||
unauthorized_client: La kliento ne rajtas fari tian peton uzante tiun metodon. | |||||
unsupported_grant_type: La tipo de la rajtiga konsento ne estas subtenata de la rajtiga servilo. | |||||
unsupported_response_type: La rajtiga servilo ne subtenas tian respondon. | |||||
flash: | |||||
applications: | |||||
create: | |||||
notice: Aplikaĵo kreita. | |||||
destroy: | |||||
notice: Aplikaĵo forigita. | |||||
update: | |||||
notice: Aplikaĵo aktualigita. | |||||
authorized_applications: | |||||
destroy: | |||||
notice: Aplikaĵo malrajtigita. | |||||
layouts: | |||||
admin: | |||||
nav: | |||||
applications: Aplikaĵoj | |||||
oauth2_provider: OAuth2-provizanto | |||||
application: | |||||
title: OAuth-a rajtigo bezonata | |||||
scopes: | |||||
follow: sekvi, bloki, malbloki kaj malsekvi kontojn | |||||
read: legi la datumojn de via konto | |||||
write: mesaĝi kiel vi |
@ -0,0 +1,164 @@ | |||||
--- | |||||
eo: | |||||
about: | |||||
about_mastodon: Mastodon estas <em>senpaga, malfermitkoda</em> socia reto. Ĝi estas <em>sencentra</em> alia eblo al komercaj servoj. Ĝi evitigas, ke unusola firmao regu vian tutan komunikadon. Elektu servilon, kiun vi fidas. Kiu ajn estas via elekto, vi povas interagi kun ĉiuj aliaj uzantoj. Iu ajn povas krei sian propran aperaĵon de Mastodon en sia servilo, kaj partopreni en la <em>socia reto</em> tute glate. | |||||
about_this: Pri tiu aperaĵo | |||||
apps: Aplikaĵoj | |||||
business_email: 'Profesia retpoŝt-adreso:' | |||||
contact: Kontakti | |||||
description_headline: Kio estas %{domain}? | |||||
domain_count_after: aliaj aperaĵoj | |||||
domain_count_before: Konektita al | |||||
features: | |||||
api: Malfermita API por aplikaĵoj kaj servoj | |||||
blocks: Kompletaj iloj por bloki kaj kaŝi | |||||
characters: Po 500 signoj por ĉiu mesaĝo | |||||
chronology: Tempolinioj laŭtempaj | |||||
ethics: 'Etike kreita: neniu reklamo, neniu ŝpurado' | |||||
gifv: Eblo diskonigi etajn videojn kaj GIFV | |||||
privacy: Videbleco agordita laŭ la mesaĝo | |||||
public: Publikaj tempolinioj | |||||
features_headline: Kiel Mastodon estas malsimila | |||||
get_started: Komenci | |||||
links: Ligiloj | |||||
other_instances: Aliaj aperaĵoj | |||||
source_code: Fontkodo | |||||
status_count_after: mesaĝoj | |||||
status_count_before: Kiu publikigis | |||||
terms: Terms | |||||
user_count_after: uzantoj | |||||
user_count_before: Hejmo de | |||||
accounts: | |||||
follow: Sekvi | |||||
followers: Sekvantoj | |||||
following: Sekvatoj | |||||
nothing_here: Estas nenio ĉi tie! | |||||
people_followed_by: Sekvatoj de %{name} | |||||
people_who_follow: Sekvantoj de %{name} | |||||
posts: Mesaĝoj | |||||
remote_follow: Fore sekvi | |||||
unfollow: Malsekvi | |||||
application_mailer: | |||||
settings: 'Ŝanĝi la retpoŝt-mesaĝajn preferojn: %{link}' | |||||
signature: Sciigoj de Mastodon el %{instance} | |||||
view: 'Vidi:' | |||||
applications: | |||||
invalid_url: La URL donita ne estas valida | |||||
auth: | |||||
change_password: Ŝanĝi pasvorton | |||||
didnt_get_confirmation: Ĉu vi ne ricevis la instrukciojn por konfirmi? | |||||
forgot_password: Pasvorto forgesita? | |||||
login: Ensaluti | |||||
logout: Elsaluti | |||||
register: Membriĝi | |||||
resend_confirmation: Resendi la instrukciojn por konfirmi | |||||
reset_password: Ŝanĝi la pasvorton | |||||
set_new_password: Elekti novan pasvorton | |||||
authorize_follow: | |||||
error: Bedaŭrinde, okazis eraro provante konsulti la foran konton | |||||
follow: Sekvi | |||||
prompt_html: 'Vi (<strong>%{self}</strong>) petis sekvi:' | |||||
title: Sekvi %{acct} | |||||
datetime: | |||||
distance_in_words: | |||||
about_x_hours: "%{count}h" | |||||
about_x_months: "%{count}mo" | |||||
about_x_years: "%{count}j" | |||||
almost_x_years: "%{count}j" | |||||
half_a_minute: Ĵus | |||||
less_than_x_minutes: "%{count}m" | |||||
less_than_x_seconds: Ĵus | |||||
over_x_years: "%{count}j" | |||||
x_days: "%{count}t" | |||||
x_minutes: "%{count}m" | |||||
x_months: "%{count}mo" | |||||
x_seconds: "%{count}s" | |||||
exports: | |||||
blocks: Vi blokas | |||||
csv: CSV | |||||
follows: Vi sekvas | |||||
storage: Mediaĵa konservado | |||||
generic: | |||||
changes_saved_msg: Ŝanĝoj senprobleme konservitaj! | |||||
powered_by: povigita de %{link} | |||||
save_changes: Konservi la ŝanĝojn | |||||
validation_errors: | |||||
one: Io ne okazis senprobleme! Bonvolu konsulti la suban erar-raporton. | |||||
other: Io ne okazis senprobleme! Bonvolu konsulti la subajn %{count} erar-raportojn. | |||||
imports: | |||||
preface: Vi povas alporti kelkajn datumojn, kiel listojn de ĉiuj homoj kiujn vi sekvas aŭ blokas, al via konto de ĉi tiu aperaĵo, per dosiero elportita de alia aperaĵo. | |||||
success: Viaj datumoj estis senprobleme alportitaj kaj estos traktitaj kiel planite. | |||||
types: | |||||
blocking: Listo de blokitoj | |||||
following: Listo de sekvatoj | |||||
upload: Alporti | |||||
landing_strip_html: <strong>%{name}</strong> estas uzanto en <strong>%{domain}</strong>. Vi povas sekvi tiun aŭ interagi kun tiu, se vi havas konton ie ajn en la Fediverse. Se vi ne havas, vi povas <a href="%{sign_up_path}">membriĝi ĉi tie.</a>. | |||||
notification_mailer: | |||||
digest: | |||||
body: 'Jen eta resumo de tio, kio okazis en %{instance}, ekde kiam vi laste vizitis en %{since}:' | |||||
mention: "%{name} menciis vin en:" | |||||
new_followers_summary: | |||||
one: Vi ekhavis novan sekvanton! Jej! | |||||
other: Vi ekhavis %{count} novajn sekvantojn! Mirinde! | |||||
subject: | |||||
one: "1 nova sciigo ekde via lasta vizito \U0001F418" | |||||
other: "%{count} novaj sciigoj ekde via lasta vizito \U0001F418" | |||||
favourite: | |||||
body: '%{name} favoris vian mesaĝon:' | |||||
subject: "%{name} favoris vian mesaĝon" | |||||
follow: | |||||
body: "%{name} eksekvis vin:" | |||||
subject: "%{name} eksekvis vin" | |||||
follow_request: | |||||
body: "%{name} petis sekvi vin:" | |||||
subject: '%{name} petis sekvi vin' | |||||
mention: | |||||
body: '%{name} menciis vin en:' | |||||
subject: '%{name} menciis vin' | |||||
reblog: | |||||
body: '%{name} diskonigis vian mesaĝon:' | |||||
subject: "%{name} diskonigis vian mesaĝon" | |||||
pagination: | |||||
next: Sekva | |||||
prev: Malsekva | |||||
remote_follow: | |||||
acct: Enmetu vian uzantnomo@aperaĵo de kie vi volas sekvi tiun uzanton | |||||
missing_resource: La URL de plusendado ne povis esti trovita | |||||
proceed: Daŭrigi por plusendi | |||||
prompt: 'Vi eksekvos:' | |||||
settings: | |||||
authorized_apps: Rajtigitaj aplikaĵoj | |||||
back: Reveni al Mastodon | |||||
edit_profile: Redakti la profilon | |||||
export: Elporti datumojn | |||||
import: Alporti | |||||
preferences: Preferoj | |||||
settings: Agordoj | |||||
two_factor_auth: Dufaktora aŭtentigo | |||||
statuses: | |||||
open_in_web: Malfermi retumile | |||||
over_character_limit: limo de %{max} signoj trapasita | |||||
show_more: Montri pli | |||||
visibilities: | |||||
private: Montri nur al sekvantoj | |||||
public: Publika | |||||
unlisted: Publika, sed ne aperos en publikaj tempolinioj | |||||
stream_entries: | |||||
click_to_show: Alklaki por montri | |||||
reblogged: diskonigita | |||||
sensitive_content: Tikla enhavo | |||||
time: | |||||
formats: | |||||
default: "%b %d, %Y, %H:%M" | |||||
two_factor_auth: | |||||
description_html: Se vi ebligas <strong>dufaktoran aŭtentigon</strong>, vi bezonos vian poŝtelefonon por ensaluti, ĉar ĝi kreos nombrojn, kiujn vi devos entajpi. | |||||
disable: Malebligi | |||||
enable: Ebligi | |||||
instructions_html: "<strong>Skanu tiun QR-kodon per Google Authenticator aŭ per simila aplikaĵo de via poŝtelefono</strong>. De tiam, la aplikaĵo kreos nombrojn, kiujn vi devos entajpi." | |||||
plaintext_secret_html: 'Rekte legebla sekreta kodo: <samp>%{secret}</samp>' | |||||
warning: Se vi ne povas agordi aŭtentigan aplikaĵon nun, elektu "malebligi" aŭ vi ne plu povos ensaluti. | |||||
users: | |||||
invalid_email: La retpoŝt-adreso ne estas valida | |||||
invalid_otp_token: La dufaktora aŭtentigila kodo ne estas valida | |||||
will_paginate: | |||||
page_gap: "…" |
@ -0,0 +1,46 @@ | |||||
--- | |||||
eo: | |||||
simple_form: | |||||
hints: | |||||
defaults: | |||||
avatar: En la formato PNG, GIF aŭ JPG. Ĝis 2Mo. Estos malgrandigita al 120x120px | |||||
display_name: 30 signoj pleje | |||||
header: En la formato PNG, GIF aŭ JPG. Ĝis 2Mo. Estos malgrandigita al 700x335px | |||||
locked: Vi devos aprobi ĉiun peton de sekvado, kaj viaj mesaĝoj estos senŝanĝe nur por viaj sekvantoj. | |||||
note: 160 signoj pleje | |||||
imports: | |||||
data: Dosiero CSV el alia aperaĵo de Mastodon | |||||
labels: | |||||
defaults: | |||||
avatar: Profilbildo | |||||
confirm_new_password: Konfirmi novan pasvorton | |||||
confirm_password: Konfirmi la pasvorton | |||||
current_password: Nuna pasvorto | |||||
data: Datumoj | |||||
display_name: Publika nomo | |||||
email: Retpoŝt-adreso | |||||
header: Kapbildo | |||||
locale: Lingvo | |||||
locked: Privatigi la konton | |||||
new_password: Nova pasvorto | |||||
note: Sinprezento | |||||
otp_attempt: Dufaktora identigilo | |||||
password: Pasvorto | |||||
setting_default_privacy: Videbleco de la mesaĝoj | |||||
type: Tipo de alportado | |||||
username: Uzantnomo | |||||
interactions: | |||||
must_be_follower: Kaŝi la sciigojn de homoj, kiuj ne sekvas vin | |||||
must_be_following: Kaŝi la sciigojn de homoj, kiujn vi ne sekas | |||||
notification_emails: | |||||
digest: Sendi resumajn retpoŝt-mesaĝojn | |||||
favourite: Sendi retpoŝt-mesaĝon, kiam iu favoras mesaĝon de vi | |||||
follow: Sendi retpoŝt-mesaĝon, kiam iu eksekvas vin | |||||
follow_request: Sendi retpoŝt-mesaĝon, kiam iu petas sekvi vin | |||||
mention: Sendi retpoŝt-mesaĝon, kiam iu mencias vin | |||||
reblog: Sendi retpoŝt-mesaĝon, kiam iu diskonigas mesaĝon de vi | |||||
'no': 'Ne' | |||||
required: | |||||
mark: "*" | |||||
text: bezonata | |||||
'yes': 'Jes' |
@ -0,0 +1,7 @@ | |||||
class AddNotificationsAndFavouritesIndices < ActiveRecord::Migration[5.0] | |||||
def change | |||||
add_index :notifications, [:activity_id, :activity_type] | |||||
add_index :accounts, :url | |||||
add_index :favourites, :status_id | |||||
end | |||||
end |
@ -1,3 +1,3 @@ | |||||
Fabricator(:media_attachment) do | Fabricator(:media_attachment) do | ||||
account | |||||
end | end |
@ -1,3 +1,4 @@ | |||||
Fabricator(:status) do | Fabricator(:status) do | ||||
account | |||||
text "Lorem ipsum dolor sit amet" | text "Lorem ipsum dolor sit amet" | ||||
end | end |