Skip to content

Commit

Permalink
Add telemetry for status / bio formatting (mastodon#32677)
Browse files Browse the repository at this point in the history
  • Loading branch information
oneiros authored Oct 29, 2024
1 parent 244aaf9 commit 9de3fd6
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 40 deletions.
18 changes: 16 additions & 2 deletions app/helpers/formatting_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,14 @@ def extract_status_plain_text(status)
module_function :extract_status_plain_text

def status_content_format(status)
html_aware_format(status.text, status.local?, preloaded_accounts: [status.account] + (status.respond_to?(:active_mentions) ? status.active_mentions.map(&:account) : []))
MastodonOTELTracer.in_span('HtmlAwareFormatter rendering') do |span|
span.add_attributes(
'app.formatter.content.type' => 'status',
'app.formatter.content.origin' => status.local? ? 'local' : 'remote'
)

html_aware_format(status.text, status.local?, preloaded_accounts: [status.account] + (status.respond_to?(:active_mentions) ? status.active_mentions.map(&:account) : []))
end
end

def rss_status_content_format(status)
Expand All @@ -39,7 +46,14 @@ def rss_status_content_format(status)
end

def account_bio_format(account)
html_aware_format(account.note, account.local?)
MastodonOTELTracer.in_span('HtmlAwareFormatter rendering') do |span|
span.add_attributes(
'app.formatter.content.type' => 'account_bio',
'app.formatter.content.origin' => account.local? ? 'local' : 'remote'
)

html_aware_format(account.note, account.local?)
end
end

def account_field_value_format(field, with_rel_me: true)
Expand Down
89 changes: 51 additions & 38 deletions app/lib/text_formatter.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,17 +33,24 @@ def entities
def to_s
return ''.html_safe if text.blank?

html = rewrite do |entity|
if entity[:url]
link_to_url(entity)
elsif entity[:hashtag]
link_to_hashtag(entity)
elsif entity[:screen_name]
link_to_mention(entity)
html = nil
MastodonOTELTracer.in_span('TextFormatter#to_s extract_and_rewrite') do
html = rewrite do |entity|
if entity[:url]
link_to_url(entity)
elsif entity[:hashtag]
link_to_hashtag(entity)
elsif entity[:screen_name]
link_to_mention(entity)
end
end
end

html = simple_format(html, {}, sanitize: false).delete("\n") if multiline?
if multiline?
MastodonOTELTracer.in_span('TextFormatter#to_s simple_format') do
html = simple_format(html, {}, sanitize: false).delete("\n")
end
end

html.html_safe # rubocop:disable Rails/OutputSafety
end
Expand Down Expand Up @@ -93,48 +100,54 @@ def rewrite
end

def link_to_url(entity)
TextFormatter.shortened_link(entity[:url], rel_me: with_rel_me?)
MastodonOTELTracer.in_span('TextFormatter#link_to_url') do
TextFormatter.shortened_link(entity[:url], rel_me: with_rel_me?)
end
end

def link_to_hashtag(entity)
hashtag = entity[:hashtag]
url = tag_url(hashtag)
MastodonOTELTracer.in_span('TextFormatter#link_to_hashtag') do
hashtag = entity[:hashtag]
url = tag_url(hashtag)

<<~HTML.squish
<a href="#{h(url)}" class="mention hashtag" rel="tag">#<span>#{h(hashtag)}</span></a>
HTML
<<~HTML.squish
<a href="#{h(url)}" class="mention hashtag" rel="tag">#<span>#{h(hashtag)}</span></a>
HTML
end
end

def link_to_mention(entity)
username, domain = entity[:screen_name].split('@')
domain = nil if local_domain?(domain)
account = nil

if preloaded_accounts?
same_username_hits = 0

preloaded_accounts.each do |other_account|
same_username = other_account.username.casecmp(username).zero?
same_domain = other_account.domain.nil? ? domain.nil? : other_account.domain.casecmp(domain)&.zero?

if same_username && !same_domain
same_username_hits += 1
elsif same_username && same_domain
account = other_account
MastodonOTELTracer.in_span('TextFormatter#link_to_mention') do
username, domain = entity[:screen_name].split('@')
domain = nil if local_domain?(domain)
account = nil

if preloaded_accounts?
same_username_hits = 0

preloaded_accounts.each do |other_account|
same_username = other_account.username.casecmp(username).zero?
same_domain = other_account.domain.nil? ? domain.nil? : other_account.domain.casecmp(domain)&.zero?

if same_username && !same_domain
same_username_hits += 1
elsif same_username && same_domain
account = other_account
end
end
else
account = entity_cache.mention(username, domain)
end
else
account = entity_cache.mention(username, domain)
end

return "@#{h(entity[:screen_name])}" if account.nil?
return "@#{h(entity[:screen_name])}" if account.nil?

url = ActivityPub::TagManager.instance.url_for(account)
display_username = same_username_hits&.positive? || with_domains? ? account.pretty_acct : account.username
url = ActivityPub::TagManager.instance.url_for(account)
display_username = same_username_hits&.positive? || with_domains? ? account.pretty_acct : account.username

<<~HTML.squish
<span class="h-card" translate="no"><a href="#{h(url)}" class="u-url mention">@<span>#{h(display_username)}</span></a></span>
HTML
<<~HTML.squish
<span class="h-card" translate="no"><a href="#{h(url)}" class="u-url mention">@<span>#{h(display_username)}</span></a></span>
HTML
end
end

def entity_cache
Expand Down

0 comments on commit 9de3fd6

Please sign in to comment.