about summary refs log tree commit diff
path: root/lib
diff options
context:
space:
mode:
authorClaire <claire.github-309c@sitedethib.com>2021-12-27 16:46:38 +0100
committerGitHub <noreply@github.com>2021-12-27 16:46:38 +0100
commite2933854ac598c5ee7428a654a72cf4f4bd9afea (patch)
treeb477529aea467279c73b35c87124d7355861646a /lib
parent3b9a6049adf3ee6844a81622c297dd893836f79d (diff)
parentf011787003bcb801b487ad3f5229e324a37c9e1d (diff)
Merge pull request #1653 from ClearlyClaire/glitch-soc/merge-upstream
Merge upstream changes
Diffstat (limited to 'lib')
-rw-r--r--lib/sidekiq_error_handler.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/sidekiq_error_handler.rb b/lib/sidekiq_error_handler.rb
new file mode 100644
index 000000000..358afd540
--- /dev/null
+++ b/lib/sidekiq_error_handler.rb
@@ -0,0 +1,24 @@
+# frozen_string_literal: true
+
+class SidekiqErrorHandler
+  BACKTRACE_LIMIT = 3
+
+  def call(*)
+    yield
+  rescue Mastodon::HostValidationError
+    # Do not retry
+  rescue => e
+    limit_backtrace_and_raise(e)
+  ensure
+    socket = Thread.current[:statsd_socket]
+    socket&.close
+    Thread.current[:statsd_socket] = nil
+  end
+
+  private
+
+  def limit_backtrace_and_raise(exception)
+    exception.set_backtrace(exception.backtrace.first(BACKTRACE_LIMIT))
+    raise exception
+  end
+end