diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2017-04-05 19:29:46 +0200 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-04-05 19:29:46 +0200 |
commit | d755ce96da00cee1c8e51204cf5ede79764f4fb9 (patch) | |
tree | a3215ee386cca3da0df7cafb91e06c1e841fa7af /app/workers | |
parent | 29ffe1cad3f473c7b6c0b651d065f8ed9373d37e (diff) | |
parent | c9ebd5d19fccaabd1192f5e61537251c2c2d782e (diff) |
Merge branch 'broadcast-to-worker' of https://github.com/krainboltgreene/mastodon into krainboltgreene-broadcast-to-worker
Diffstat (limited to 'app/workers')
-rw-r--r-- | app/workers/push_update_worker.rb | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/app/workers/push_update_worker.rb b/app/workers/push_update_worker.rb new file mode 100644 index 000000000..166a9b449 --- /dev/null +++ b/app/workers/push_update_worker.rb @@ -0,0 +1,22 @@ +# frozen_string_literal: true + +class PushUpdateWorker + include Sidekiq::Worker + + def perform(timeline, account_id, status_id) + account = Account.find(account_id) + status = Status.find(status_id) + + message = Rabl::Renderer.new( + 'api/v1/statuses/show', + status, + view_path: 'app/views', + format: :json, + scope: InlineRablScope.new(account) + ) + + Redis.current.publish("timeline:#{account.id}", Oj.dump({ event: :update, payload: message, queued_at: (Time.now.to_f * 1000.0).to_i })) + rescue ActiveRecord::RecordNotFound + true + end +end |