mirror of
https://github.com/mastodon/mastodon.git
synced 2025-07-15 08:48:15 +00:00

Some checks failed
Check i18n / check-i18n (push) Waiting to run
Chromatic / Run Chromatic (push) Waiting to run
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (ruby) (push) Waiting to run
Check formatting / lint (push) Waiting to run
CSS Linting / lint (push) Waiting to run
JavaScript Linting / lint (push) Waiting to run
Ruby Linting / lint (push) Waiting to run
JavaScript Testing / test (push) Waiting to run
Historical data migration test / test (14-alpine) (push) Waiting to run
Historical data migration test / test (15-alpine) (push) Waiting to run
Historical data migration test / test (16-alpine) (push) Waiting to run
Historical data migration test / test (17-alpine) (push) Waiting to run
Ruby Testing / build (production) (push) Waiting to run
Ruby Testing / build (test) (push) Waiting to run
Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
Ruby Testing / test (3.2) (push) Blocked by required conditions
Ruby Testing / test (3.3) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (.ruby-version) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.2) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.3) (push) Blocked by required conditions
Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.3) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.3, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Crowdin / Upload translations / upload-translations (push) Has been cancelled
Haml Linting / lint (push) Has been cancelled
77 lines
1.6 KiB
Ruby
77 lines
1.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class AsyncRefresh
|
|
extend Redisable
|
|
include Redisable
|
|
|
|
NEW_REFRESH_EXPIRATION = 1.day
|
|
FINISHED_REFRESH_EXPIRATION = 1.hour
|
|
|
|
def self.find(id)
|
|
redis_key = Rails.application.message_verifier('async_refreshes').verify(id)
|
|
new(redis_key) if redis.exists?(redis_key)
|
|
rescue ActiveSupport::MessageVerifier::InvalidSignature
|
|
nil
|
|
end
|
|
|
|
def self.create(redis_key, count_results: false)
|
|
data = { 'status' => 'running' }
|
|
data['result_count'] = 0 if count_results
|
|
redis.hset(redis_key, data)
|
|
redis.expire(redis_key, NEW_REFRESH_EXPIRATION)
|
|
new(redis_key)
|
|
end
|
|
|
|
attr_reader :status, :result_count
|
|
|
|
def initialize(redis_key)
|
|
@redis_key = redis_key
|
|
fetch_data_from_redis
|
|
end
|
|
|
|
def id
|
|
Rails.application.message_verifier('async_refreshes').generate(@redis_key)
|
|
end
|
|
|
|
def running?
|
|
@status == 'running'
|
|
end
|
|
|
|
def finished?
|
|
@status == 'finished'
|
|
end
|
|
|
|
def finish!
|
|
redis.pipelined do |pipeline|
|
|
pipeline.hset(@redis_key, { 'status' => 'finished' })
|
|
pipeline.expire(@redis_key, FINISHED_REFRESH_EXPIRATION)
|
|
end
|
|
@status = 'finished'
|
|
end
|
|
|
|
def reload
|
|
fetch_data_from_redis
|
|
self
|
|
end
|
|
|
|
def to_json(_options)
|
|
{
|
|
async_refresh: {
|
|
id:,
|
|
status:,
|
|
result_count:,
|
|
},
|
|
}.to_json
|
|
end
|
|
|
|
private
|
|
|
|
def fetch_data_from_redis
|
|
@status, @result_count = redis.pipelined do |pipeline|
|
|
pipeline.hget(@redis_key, 'status')
|
|
pipeline.hget(@redis_key, 'result_count')
|
|
end
|
|
@result_count = @result_count.presence&.to_i
|
|
end
|
|
end
|