Module: Sidekiq::WebHelpers

Defined in:
lib/sidekiq/web_helpers.rb

Overview

This is not a public API

Constant Summary collapse

SAFE_QPARAMS =
%w(page poll)
RETRY_JOB_KEYS =
Set.new(%w(
  queue class args retry_count retried_at failed_at
  jid error_message error_class backtrace
  error_backtrace enqueued_at retry wrapped
))

Instance Method Summary collapse

Instance Method Details

#add_to_head(&block) ⇒ Object

This view helper provide ability display you html code in to head of page. Example:

<% add_to_head do %>
  <link rel="stylesheet" .../>
  <meta .../>
<% end %>


42
43
44
45
# File 'lib/sidekiq/web_helpers.rb', line 42

def add_to_head(&block)
  @head_html ||= []
  @head_html << block if block_given?
end

#capture(&block) ⇒ Object

Simple capture method for erb templates. The origin was capture method from sinatra-contrib library.



54
55
56
57
# File 'lib/sidekiq/web_helpers.rb', line 54

def capture(&block)
  block.call
  eval('', block.binding)
end

#current_pathObject



135
136
137
# File 'lib/sidekiq/web_helpers.rb', line 135

def current_path
  @current_path ||= request.path_info.gsub(/^\//,'')
end

#current_statusObject



139
140
141
# File 'lib/sidekiq/web_helpers.rb', line 139

def current_status
  workers.size == 0 ? 'idle' : 'active'
end

#display_args(args, truncate_after_chars = 2000) ⇒ Object



170
171
172
173
174
175
# File 'lib/sidekiq/web_helpers.rb', line 170

def display_args(args, truncate_after_chars = 2000)
  args.map do |arg|
    a = arg.inspect
    h(truncate(a))
  end.join(", ")
end

#display_custom_headObject



47
48
49
50
# File 'lib/sidekiq/web_helpers.rb', line 47

def display_custom_head
  return unless @head_html
  @head_html.map { |block| capture(&block) }.join
end

#environment_title_prefixObject



224
225
226
227
228
# File 'lib/sidekiq/web_helpers.rb', line 224

def environment_title_prefix
  environment = Sidekiq.options[:environment] || ENV['RAILS_ENV'] || ENV['RACK_ENV'] || 'development'

  "[#{environment.upcase}] " unless environment == "production"
end

#filteringObject

This is a hook for a Sidekiq Pro feature. Please don’t touch.



31
32
# File 'lib/sidekiq/web_helpers.rb', line 31

def filtering(*)
end

#find_locale_files(lang) ⇒ Object



26
27
28
# File 'lib/sidekiq/web_helpers.rb', line 26

def find_locale_files(lang)
  locale_files.select { |file| file =~ /\/#{lang}\.yml$/ }
end

#get_localeObject



76
77
78
# File 'lib/sidekiq/web_helpers.rb', line 76

def get_locale
  strings(locale)
end

#h(text) ⇒ Object



204
205
206
207
208
209
210
# File 'lib/sidekiq/web_helpers.rb', line 204

def h(text)
  ::Rack::Utils.escape_html(text)
rescue ArgumentError => e
  raise unless e.message.eql?('invalid byte sequence in UTF-8')
  text.encode!('UTF-16', 'UTF-8', invalid: :replace, replace: '').encode!('UTF-8', 'UTF-16')
  retry
end

#job_params(job, score) ⇒ Object



147
148
149
# File 'lib/sidekiq/web_helpers.rb', line 147

def job_params(job, score)
  "#{score}-#{job['jid']}"
end

#localeObject

Given a browser request Accept-Language header like “fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4,ru;q=0.2”, this function will return “fr” since that’s the first code with a matching locale in web/locales



63
64
65
66
67
68
69
70
71
72
73
74
# File 'lib/sidekiq/web_helpers.rb', line 63

def locale
  @locale ||= begin
    locale = 'en'.freeze
    languages = request.env['HTTP_ACCEPT_LANGUAGE'.freeze] || 'en'.freeze
    languages.downcase.split(','.freeze).each do |lang|
      next if lang == '*'.freeze
      lang = lang.split(';'.freeze)[0]
      break locale = lang if find_locale_files(lang).any?
    end
    locale
  end
end

#locale_filesObject



20
21
22
23
24
# File 'lib/sidekiq/web_helpers.rb', line 20

def locale_files
  @@locale_files = settings.locales.flat_map do |path|
    Dir["#{path}/*.yml"]
  end
end

#locationObject



107
108
109
# File 'lib/sidekiq/web_helpers.rb', line 107

def location
  Sidekiq.redis { |conn| conn.client.location }
end

#namespaceObject



115
116
117
# File 'lib/sidekiq/web_helpers.rb', line 115

def namespace
  @@ns ||= Sidekiq.redis { |conn| conn.respond_to?(:namespace) ? conn.namespace : nil }
end

#number_with_delimiter(number) ⇒ Object



191
192
193
194
195
196
197
198
199
200
201
202
# File 'lib/sidekiq/web_helpers.rb', line 191

def number_with_delimiter(number)
  begin
    Float(number)
  rescue ArgumentError, TypeError
    return number
  end

  options = {delimiter: ',', separator: '.'}
  parts = number.to_s.to_str.split('.')
  parts[0].gsub!(/(\d)(?=(\d\d\d)+(?!\d))/, "\\1#{options[:delimiter]}")
  parts.join(options[:separator])
end

#parse_params(params) ⇒ Object



151
152
153
154
# File 'lib/sidekiq/web_helpers.rb', line 151

def parse_params(params)
  score, jid = params.split("-")
  [score.to_f, jid]
end

#processesObject



93
94
95
# File 'lib/sidekiq/web_helpers.rb', line 93

def processes
  @processes ||= Sidekiq::ProcessSet.new
end

#product_versionObject



230
231
232
# File 'lib/sidekiq/web_helpers.rb', line 230

def product_version
  "Sidekiq v#{Sidekiq::VERSION}"
end

#qparams(options) ⇒ Object

Merge options with current params, filter safe params, and stringify to query string



159
160
161
162
163
164
# File 'lib/sidekiq/web_helpers.rb', line 159

def qparams(options)
  options = options.stringify_keys
  params.merge(options).map do |key, value|
    SAFE_QPARAMS.include?(key) ? "#{key}=#{value}" : next
  end.join("&")
end

#redirect_with_query(url) ⇒ Object

Any paginated list that performs an action needs to redirect back to the proper page after performing that action.



214
215
216
217
218
219
220
221
222
# File 'lib/sidekiq/web_helpers.rb', line 214

def redirect_with_query(url)
  r = request.referer
  if r && r =~ /\?/
    ref = URI(r)
    redirect("#{url}?#{ref.query}")
  else
    redirect url
  end
end

#redis_connectionObject



111
112
113
# File 'lib/sidekiq/web_helpers.rb', line 111

def redis_connection
  Sidekiq.redis { |conn| conn.client.id }
end

#redis_infoObject



119
120
121
122
123
124
125
126
127
128
129
# File 'lib/sidekiq/web_helpers.rb', line 119

def redis_info
  Sidekiq.redis do |conn|
    # admin commands can't go through redis-namespace starting
    # in redis-namespace 2.0
    if conn.respond_to?(:namespace)
      conn.redis.info
    else
      conn.info
    end
  end
end

#relative_time(time) ⇒ Object



143
144
145
# File 'lib/sidekiq/web_helpers.rb', line 143

def relative_time(time)
  %{<time datetime="#{time.getutc.iso8601}">#{time}</time>}
end

#retries_with_score(score) ⇒ Object



101
102
103
104
105
# File 'lib/sidekiq/web_helpers.rb', line 101

def retries_with_score(score)
  Sidekiq.redis do |conn|
    conn.zrangebyscore('retry', score, score)
  end.map { |msg| Sidekiq.load_json(msg) }
end

#retry_extra_items(retry_job) ⇒ Object



183
184
185
186
187
188
189
# File 'lib/sidekiq/web_helpers.rb', line 183

def retry_extra_items(retry_job)
  @retry_extra_items ||= {}.tap do |extra|
    retry_job.item.each do |key, value|
      extra[key] = value unless RETRY_JOB_KEYS.include?(key)
    end
  end
end

#root_pathObject



131
132
133
# File 'lib/sidekiq/web_helpers.rb', line 131

def root_path
  "#{env['SCRIPT_NAME']}/"
end

#statsObject



97
98
99
# File 'lib/sidekiq/web_helpers.rb', line 97

def stats
  @stats ||= Sidekiq::Stats.new
end

#strings(lang) ⇒ Object



6
7
8
9
10
11
12
13
14
15
16
17
18
# File 'lib/sidekiq/web_helpers.rb', line 6

def strings(lang)
  @@strings ||= {}
  @@strings[lang] ||= begin
    # Allow sidekiq-web extensions to add locale paths
    # so extensions can be localized
    settings.locales.each_with_object({}) do |path, global|
      find_locale_files(lang).each do |file|
        strs = YAML.load(File.open(file))
        global.deep_merge!(strs[lang])
      end
    end
  end
end

#t(msg, options = {}) ⇒ Object



80
81
82
83
84
85
86
87
# File 'lib/sidekiq/web_helpers.rb', line 80

def t(msg, options={})
  string = get_locale[msg] || msg
  if options.empty?
    string
  else
    string % options
  end
end

#truncate(text, truncate_after_chars = 2000) ⇒ Object



166
167
168
# File 'lib/sidekiq/web_helpers.rb', line 166

def truncate(text, truncate_after_chars = 2000)
  truncate_after_chars && text.size > truncate_after_chars ? "#{text[0..truncate_after_chars]}..." : text
end

#workersObject



89
90
91
# File 'lib/sidekiq/web_helpers.rb', line 89

def workers
  @workers ||= Sidekiq::Workers.new
end