about summary refs log tree commit diff
path: root/app/lib
diff options
context:
space:
mode:
authorThibG <thib@sitedethib.com>2020-11-14 00:50:43 +0100
committerGitHub <noreply@github.com>2020-11-14 00:50:43 +0100
commitdb01f8b942b72eaa2eacbb144261b002f8079c9c (patch)
tree2391ed3e8c3cb95c50d7e5fe3d35b36148989cb7 /app/lib
parent8ffae82fa61385a33f819e037aa741d0b3e99187 (diff)
parentde5cc20dd8e15eb7e90d65392a6e6f9145746913 (diff)
Merge pull request #1465 from ThibG/glitch-soc/merge-upstream
Merge upstream changes
Diffstat (limited to 'app/lib')
-rw-r--r--app/lib/access_token_extension.rb17
1 files changed, 17 insertions, 0 deletions
diff --git a/app/lib/access_token_extension.rb b/app/lib/access_token_extension.rb
new file mode 100644
index 000000000..3e184e775
--- /dev/null
+++ b/app/lib/access_token_extension.rb
@@ -0,0 +1,17 @@
+# frozen_string_literal: true
+
+module AccessTokenExtension
+  extend ActiveSupport::Concern
+
+  included do
+    after_commit :push_to_streaming_api
+  end
+
+  def revoke(clock = Time)
+    update(revoked_at: clock.now.utc)
+  end
+
+  def push_to_streaming_api
+    Redis.current.publish("timeline:access_token:#{id}", Oj.dump(event: :kill)) if revoked? || destroyed?
+  end
+end