Updated rubocop(-* gems) to latest version (0.88.0).
This commit is contained in:
parent
829fc6e5c5
commit
73f6a98e29
37 changed files with 385 additions and 340 deletions
|
@ -451,7 +451,7 @@ GEM
|
||||||
rspec-support (~> 3.8.0)
|
rspec-support (~> 3.8.0)
|
||||||
rspec-support (3.8.0)
|
rspec-support (3.8.0)
|
||||||
rszr (0.5.2)
|
rszr (0.5.2)
|
||||||
rubocop (0.87.0)
|
rubocop (0.88.0)
|
||||||
parallel (~> 1.10)
|
parallel (~> 1.10)
|
||||||
parser (>= 2.7.1.1)
|
parser (>= 2.7.1.1)
|
||||||
rainbow (>= 2.2.2, < 4.0)
|
rainbow (>= 2.2.2, < 4.0)
|
||||||
|
@ -468,8 +468,8 @@ GEM
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
rack (>= 1.1)
|
rack (>= 1.1)
|
||||||
rubocop (>= 0.82.0)
|
rubocop (>= 0.82.0)
|
||||||
rubocop-rspec (1.41.0)
|
rubocop-rspec (1.42.0)
|
||||||
rubocop (>= 0.68.1)
|
rubocop (>= 0.87.0)
|
||||||
ruby-progressbar (1.10.1)
|
ruby-progressbar (1.10.1)
|
||||||
ruby-saml (1.10.2)
|
ruby-saml (1.10.2)
|
||||||
nokogiri (>= 1.5.10)
|
nokogiri (>= 1.5.10)
|
||||||
|
|
|
@ -306,13 +306,14 @@ curl http://localhost/api/v1/monitoring/amount_check?token=XXX&periode=1h
|
||||||
periode = params[:periode][0, params[:periode].length - 1]
|
periode = params[:periode][0, params[:periode].length - 1]
|
||||||
raise Exceptions::UnprocessableEntity, 'periode need to be an integer!' if periode.to_i.zero?
|
raise Exceptions::UnprocessableEntity, 'periode need to be an integer!' if periode.to_i.zero?
|
||||||
|
|
||||||
if scale == 's'
|
case scale
|
||||||
|
when 's'
|
||||||
created_at = Time.zone.now - periode.to_i.seconds
|
created_at = Time.zone.now - periode.to_i.seconds
|
||||||
elsif scale == 'm'
|
when 'm'
|
||||||
created_at = Time.zone.now - periode.to_i.minutes
|
created_at = Time.zone.now - periode.to_i.minutes
|
||||||
elsif scale == 'h'
|
when 'h'
|
||||||
created_at = Time.zone.now - periode.to_i.hours
|
created_at = Time.zone.now - periode.to_i.hours
|
||||||
elsif scale == 'd'
|
when 'd'
|
||||||
created_at = Time.zone.now - periode.to_i.days
|
created_at = Time.zone.now - periode.to_i.days
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -85,9 +85,10 @@ class ObjectManagerAttributesController < ApplicationController
|
||||||
if permitted[:data_option][:options][:true]
|
if permitted[:data_option][:options][:true]
|
||||||
permitted[:data_option][:options][true] = permitted[:data_option][:options].delete(:true)
|
permitted[:data_option][:options][true] = permitted[:data_option][:options].delete(:true)
|
||||||
end
|
end
|
||||||
if permitted[:data_option][:default] == 'true'
|
case permitted[:data_option][:default]
|
||||||
|
when 'true'
|
||||||
permitted[:data_option][:default] = true
|
permitted[:data_option][:default] = true
|
||||||
elsif permitted[:data_option][:default] == 'false'
|
when 'false'
|
||||||
permitted[:data_option][:default] = false
|
permitted[:data_option][:default] = false
|
||||||
end
|
end
|
||||||
# rubocop:enable Lint/BooleanSymbol
|
# rubocop:enable Lint/BooleanSymbol
|
||||||
|
|
|
@ -138,22 +138,23 @@ class ReportsController < ApplicationController
|
||||||
|
|
||||||
metric = local_config[:metric][params[:metric].to_sym]
|
metric = local_config[:metric][params[:metric].to_sym]
|
||||||
|
|
||||||
if params[:timeRange] == 'realtime'
|
case params[:timeRange]
|
||||||
|
when 'realtime'
|
||||||
start_at = (Time.zone.now - 60.minutes)
|
start_at = (Time.zone.now - 60.minutes)
|
||||||
stop_at = Time.zone.now
|
stop_at = Time.zone.now
|
||||||
range = 'minute'
|
range = 'minute'
|
||||||
elsif params[:timeRange] == 'day'
|
when 'day'
|
||||||
date = Date.parse("#{params[:year]}-#{params[:month]}-#{params[:day]}").to_s
|
date = Date.parse("#{params[:year]}-#{params[:month]}-#{params[:day]}").to_s
|
||||||
start_at = Time.zone.parse("#{date}T00:00:00Z")
|
start_at = Time.zone.parse("#{date}T00:00:00Z")
|
||||||
stop_at = Time.zone.parse("#{date}T23:59:59Z")
|
stop_at = Time.zone.parse("#{date}T23:59:59Z")
|
||||||
range = 'hour'
|
range = 'hour'
|
||||||
elsif params[:timeRange] == 'week'
|
when 'week'
|
||||||
start_week_at = Date.commercial(params[:year].to_i, params[:week].to_i)
|
start_week_at = Date.commercial(params[:year].to_i, params[:week].to_i)
|
||||||
stop_week_at = start_week_at.end_of_week
|
stop_week_at = start_week_at.end_of_week
|
||||||
start_at = Time.zone.parse("#{start_week_at.year}-#{start_week_at.month}-#{start_week_at.day}T00:00:00Z")
|
start_at = Time.zone.parse("#{start_week_at.year}-#{start_week_at.month}-#{start_week_at.day}T00:00:00Z")
|
||||||
stop_at = Time.zone.parse("#{stop_week_at.year}-#{stop_week_at.month}-#{stop_week_at.day}T23:59:59Z")
|
stop_at = Time.zone.parse("#{stop_week_at.year}-#{stop_week_at.month}-#{stop_week_at.day}T23:59:59Z")
|
||||||
range = 'week'
|
range = 'week'
|
||||||
elsif params[:timeRange] == 'month'
|
when 'month'
|
||||||
start_at = Time.zone.parse("#{params[:year]}-#{params[:month]}-01T00:00:00Z")
|
start_at = Time.zone.parse("#{params[:year]}-#{params[:month]}-01T00:00:00Z")
|
||||||
stop_at = Time.zone.parse("#{params[:year]}-#{params[:month]}-#{start_at.end_of_month.day}T23:59:59Z")
|
stop_at = Time.zone.parse("#{params[:year]}-#{params[:month]}-#{start_at.end_of_month.day}T23:59:59Z")
|
||||||
range = 'day'
|
range = 'day'
|
||||||
|
|
|
@ -12,16 +12,13 @@ module KnowledgeBaseTopBarHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
def kb_answer_top_bar_color(answer)
|
def kb_answer_top_bar_color(answer)
|
||||||
case answer.can_be_published_aasm.current_state
|
state_color_map = {
|
||||||
when :draft
|
draft: 'yellow',
|
||||||
'yellow'
|
internal: 'blue',
|
||||||
when :internal
|
published: 'green',
|
||||||
'blue'
|
archived: 'grey',
|
||||||
when :published
|
}
|
||||||
'green'
|
state_color_map[answer.can_be_published_aasm.current_state]
|
||||||
when :archived
|
|
||||||
'grey'
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def kb_top_bar_tag(object)
|
def kb_top_bar_tag(object)
|
||||||
|
|
|
@ -13,14 +13,12 @@ module KnowledgeBaseVisibilityClassHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
def visiblity_class_suffix_can_be_published(object)
|
def visiblity_class_suffix_can_be_published(object)
|
||||||
case object.can_be_published_aasm.current_state
|
state_suffix_map = {
|
||||||
when :internal
|
internal: 'internal',
|
||||||
'internal'
|
archived: 'archived',
|
||||||
when :archived
|
draft: 'not-published',
|
||||||
'archived'
|
}
|
||||||
when :draft
|
state_suffix_map[object.can_be_published_aasm.current_state]
|
||||||
'not-published'
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def visiblity_class_suffix_category(object)
|
def visiblity_class_suffix_category(object)
|
||||||
|
|
|
@ -19,14 +19,12 @@ module KnowledgeBaseVisibilityNoteHelper
|
||||||
end
|
end
|
||||||
|
|
||||||
def visiblity_text_can_be_published(object)
|
def visiblity_text_can_be_published(object)
|
||||||
case object.can_be_published_aasm.current_state
|
state_text_map = {
|
||||||
when :internal
|
internal: 'internal',
|
||||||
'internal'
|
archived: 'archived',
|
||||||
when :archived
|
draft: 'not published',
|
||||||
'archived'
|
}
|
||||||
when :draft
|
state_text_map[object.can_be_published_aasm.current_state]
|
||||||
'not published'
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def visiblity_text_category(object)
|
def visiblity_text_category(object)
|
||||||
|
|
|
@ -87,7 +87,7 @@ class Channel::EmailParser
|
||||||
headers,
|
headers,
|
||||||
body,
|
body,
|
||||||
self.class.sender_attributes(headers),
|
self.class.sender_attributes(headers),
|
||||||
raw: msg,
|
{ raw: msg },
|
||||||
]
|
]
|
||||||
message_attributes.reduce({}.with_indifferent_access, &:merge)
|
message_attributes.reduce({}.with_indifferent_access, &:merge)
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,12 +18,13 @@ module Channel::Filter::Database
|
||||||
value = mail[ key.downcase.to_sym ]
|
value = mail[ key.downcase.to_sym ]
|
||||||
match_rule = meta['value']
|
match_rule = meta['value']
|
||||||
min_one_rule_exists = true
|
min_one_rule_exists = true
|
||||||
if meta[:operator] == 'contains not'
|
case meta[:operator]
|
||||||
|
when 'contains not'
|
||||||
if value.present? && Channel::Filter::Match::EmailRegex.match(value: value, match_rule: match_rule)
|
if value.present? && Channel::Filter::Match::EmailRegex.match(value: value, match_rule: match_rule)
|
||||||
all_matches_ok = false
|
all_matches_ok = false
|
||||||
Rails.logger.info " matching #{key.downcase}:'#{value}' on #{match_rule}, but shoud not"
|
Rails.logger.info " matching #{key.downcase}:'#{value}' on #{match_rule}, but shoud not"
|
||||||
end
|
end
|
||||||
elsif meta[:operator] == 'contains'
|
when 'contains'
|
||||||
if value.blank? || !Channel::Filter::Match::EmailRegex.match(value: value, match_rule: match_rule)
|
if value.blank? || !Channel::Filter::Match::EmailRegex.match(value: value, match_rule: match_rule)
|
||||||
all_matches_ok = false
|
all_matches_ok = false
|
||||||
Rails.logger.info " not matching #{key.downcase}:'#{value}' on #{match_rule}, but should"
|
Rails.logger.info " not matching #{key.downcase}:'#{value}' on #{match_rule}, but should"
|
||||||
|
|
|
@ -71,9 +71,10 @@ class Channel::Filter::MonitoringBase
|
||||||
|
|
||||||
# possible event types https://mmonit.com/monit/documentation/#Setting-an-event-filter
|
# possible event types https://mmonit.com/monit/documentation/#Setting-an-event-filter
|
||||||
if result['state'].blank?
|
if result['state'].blank?
|
||||||
result['state'] = if mail[:body].match?(/\s(done|recovery|succeeded|bytes\sok|packets\sok)\s/)
|
result['state'] = case mail[:body]
|
||||||
|
when /\s(done|recovery|succeeded|bytes\sok|packets\sok)\s/
|
||||||
'OK'
|
'OK'
|
||||||
elsif mail[:body].match?(/(instance\schanged\snot|Link\sup|Exists|Saturation\sok|Speed\sok)/)
|
when /(instance\schanged\snot|Link\sup|Exists|Saturation\sok|Speed\sok)/
|
||||||
'OK'
|
'OK'
|
||||||
else
|
else
|
||||||
'CRITICAL'
|
'CRITICAL'
|
||||||
|
|
|
@ -66,7 +66,8 @@ reconnect - chat session already exists, serve agent and session chat messages (
|
||||||
chat_session = Chat::Session.find_by(session_id: session_id, state: %w[waiting running])
|
chat_session = Chat::Session.find_by(session_id: session_id, state: %w[waiting running])
|
||||||
|
|
||||||
if chat_session
|
if chat_session
|
||||||
if chat_session.state == 'running'
|
case chat_session.state
|
||||||
|
when 'running'
|
||||||
user = chat_session.agent_user
|
user = chat_session.agent_user
|
||||||
if user
|
if user
|
||||||
|
|
||||||
|
@ -80,7 +81,7 @@ reconnect - chat session already exists, serve agent and session chat messages (
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
elsif chat_session.state == 'waiting'
|
when 'waiting'
|
||||||
return {
|
return {
|
||||||
state: 'reconnect',
|
state: 'reconnect',
|
||||||
position: chat_session.position,
|
position: chat_session.position,
|
||||||
|
|
|
@ -7,15 +7,16 @@ class Cti::Driver::Placetel < Cti::Driver::Base
|
||||||
def mapping(params)
|
def mapping(params)
|
||||||
|
|
||||||
# do event mapping
|
# do event mapping
|
||||||
if params['event'] == 'IncomingCall'
|
case params['event']
|
||||||
|
when 'IncomingCall'
|
||||||
params['direction'] = 'in'
|
params['direction'] = 'in'
|
||||||
params['event'] = 'newCall'
|
params['event'] = 'newCall'
|
||||||
elsif params['event'] == 'HungUp'
|
when 'HungUp'
|
||||||
params['event'] = 'hangup'
|
params['event'] = 'hangup'
|
||||||
elsif params['event'] == 'OutgoingCall'
|
when 'OutgoingCall'
|
||||||
params['direction'] = 'out'
|
params['direction'] = 'out'
|
||||||
params['event'] = 'newCall'
|
params['event'] = 'newCall'
|
||||||
elsif params['event'] == 'CallAccepted'
|
when 'CallAccepted'
|
||||||
params['event'] = 'answer'
|
params['event'] = 'answer'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -41,13 +42,14 @@ class Cti::Driver::Placetel < Cti::Driver::Base
|
||||||
end
|
end
|
||||||
|
|
||||||
# do case mapping
|
# do case mapping
|
||||||
if params['type'] == 'missed'
|
case params['type']
|
||||||
|
when 'missed'
|
||||||
params['cause'] = 'cancel'
|
params['cause'] = 'cancel'
|
||||||
elsif params['type'] == 'voicemail'
|
when 'voicemail'
|
||||||
params['cause'] = 'voicemail'
|
params['cause'] = 'voicemail'
|
||||||
elsif params['type'] == 'blocked'
|
when 'blocked'
|
||||||
params['cause'] = 'blocked'
|
params['cause'] = 'blocked'
|
||||||
elsif params['type'] == 'accepted'
|
when 'accepted'
|
||||||
params['cause'] = 'normalClearing'
|
params['cause'] = 'normalClearing'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -677,21 +677,23 @@ to send no browser reload event, pass false
|
||||||
end
|
end
|
||||||
|
|
||||||
data_type = nil
|
data_type = nil
|
||||||
if attribute.data_type.match?(/^input|select|tree_select|richtext|textarea|checkbox$/)
|
case attribute.data_type
|
||||||
|
when /^input|select|tree_select|richtext|textarea|checkbox$/
|
||||||
data_type = :string
|
data_type = :string
|
||||||
elsif attribute.data_type.match?(/^integer|user_autocompletion$/)
|
when /^integer|user_autocompletion$/
|
||||||
data_type = :integer
|
data_type = :integer
|
||||||
elsif attribute.data_type.match?(/^boolean|active$/)
|
when /^boolean|active$/
|
||||||
data_type = :boolean
|
data_type = :boolean
|
||||||
elsif attribute.data_type.match?(/^datetime$/)
|
when /^datetime$/
|
||||||
data_type = :datetime
|
data_type = :datetime
|
||||||
elsif attribute.data_type.match?(/^date$/)
|
when /^date$/
|
||||||
data_type = :date
|
data_type = :date
|
||||||
end
|
end
|
||||||
|
|
||||||
# change field
|
# change field
|
||||||
if model.column_names.include?(attribute.name)
|
if model.column_names.include?(attribute.name)
|
||||||
if attribute.data_type.match?(/^input|select|tree_select|richtext|textarea|checkbox$/)
|
case attribute.data_type
|
||||||
|
when /^input|select|tree_select|richtext|textarea|checkbox$/
|
||||||
ActiveRecord::Migration.change_column(
|
ActiveRecord::Migration.change_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -699,7 +701,7 @@ to send no browser reload event, pass false
|
||||||
limit: attribute.data_option[:maxlength],
|
limit: attribute.data_option[:maxlength],
|
||||||
null: true
|
null: true
|
||||||
)
|
)
|
||||||
elsif attribute.data_type.match?(/^integer|user_autocompletion|datetime|date$/)
|
when /^integer|user_autocompletion|datetime|date$/
|
||||||
ActiveRecord::Migration.change_column(
|
ActiveRecord::Migration.change_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -707,7 +709,7 @@ to send no browser reload event, pass false
|
||||||
default: attribute.data_option[:default],
|
default: attribute.data_option[:default],
|
||||||
null: true
|
null: true
|
||||||
)
|
)
|
||||||
elsif attribute.data_type.match?(/^boolean|active$/)
|
when /^boolean|active$/
|
||||||
ActiveRecord::Migration.change_column(
|
ActiveRecord::Migration.change_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -730,7 +732,8 @@ to send no browser reload event, pass false
|
||||||
end
|
end
|
||||||
|
|
||||||
# create field
|
# create field
|
||||||
if attribute.data_type.match?(/^input|select|tree_select|richtext|textarea|checkbox$/)
|
case attribute.data_type
|
||||||
|
when /^input|select|tree_select|richtext|textarea|checkbox$/
|
||||||
ActiveRecord::Migration.add_column(
|
ActiveRecord::Migration.add_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -738,7 +741,7 @@ to send no browser reload event, pass false
|
||||||
limit: attribute.data_option[:maxlength],
|
limit: attribute.data_option[:maxlength],
|
||||||
null: true
|
null: true
|
||||||
)
|
)
|
||||||
elsif attribute.data_type.match?(/^integer|user_autocompletion$/)
|
when /^integer|user_autocompletion$/
|
||||||
ActiveRecord::Migration.add_column(
|
ActiveRecord::Migration.add_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -746,7 +749,7 @@ to send no browser reload event, pass false
|
||||||
default: attribute.data_option[:default],
|
default: attribute.data_option[:default],
|
||||||
null: true
|
null: true
|
||||||
)
|
)
|
||||||
elsif attribute.data_type.match?(/^boolean|active$/)
|
when /^boolean|active$/
|
||||||
ActiveRecord::Migration.add_column(
|
ActiveRecord::Migration.add_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
@ -754,7 +757,7 @@ to send no browser reload event, pass false
|
||||||
default: attribute.data_option[:default],
|
default: attribute.data_option[:default],
|
||||||
null: true
|
null: true
|
||||||
)
|
)
|
||||||
elsif attribute.data_type.match?(/^datetime|date$/)
|
when /^datetime|date$/
|
||||||
ActiveRecord::Migration.add_column(
|
ActiveRecord::Migration.add_column(
|
||||||
model.table_name,
|
model.table_name,
|
||||||
attribute.name,
|
attribute.name,
|
||||||
|
|
|
@ -408,9 +408,10 @@ execute all pending package migrations at once
|
||||||
end
|
end
|
||||||
|
|
||||||
def self._read_file(file, fullpath = false)
|
def self._read_file(file, fullpath = false)
|
||||||
location = if fullpath == false
|
location = case fullpath
|
||||||
|
when false
|
||||||
@@root + '/' + file
|
@@root + '/' + file
|
||||||
elsif fullpath == true
|
when true
|
||||||
file
|
file
|
||||||
else
|
else
|
||||||
fullpath + '/' + file
|
fullpath + '/' + file
|
||||||
|
|
|
@ -547,19 +547,20 @@ condition example
|
||||||
if query != ''
|
if query != ''
|
||||||
query += ' AND '
|
query += ' AND '
|
||||||
end
|
end
|
||||||
if selector[0] == 'customer'
|
case selector[0]
|
||||||
|
when 'customer'
|
||||||
tables += ', users customers'
|
tables += ', users customers'
|
||||||
query += 'tickets.customer_id = customers.id'
|
query += 'tickets.customer_id = customers.id'
|
||||||
elsif selector[0] == 'organization'
|
when 'organization'
|
||||||
tables += ', organizations'
|
tables += ', organizations'
|
||||||
query += 'tickets.organization_id = organizations.id'
|
query += 'tickets.organization_id = organizations.id'
|
||||||
elsif selector[0] == 'owner'
|
when 'owner'
|
||||||
tables += ', users owners'
|
tables += ', users owners'
|
||||||
query += 'tickets.owner_id = owners.id'
|
query += 'tickets.owner_id = owners.id'
|
||||||
elsif selector[0] == 'article'
|
when 'article'
|
||||||
tables += ', ticket_articles articles'
|
tables += ', ticket_articles articles'
|
||||||
query += 'tickets.id = articles.ticket_id'
|
query += 'tickets.id = articles.ticket_id'
|
||||||
elsif selector[0] == 'ticket_state'
|
when 'ticket_state'
|
||||||
tables += ', ticket_states'
|
tables += ', ticket_states'
|
||||||
query += 'tickets.state_id = ticket_states.id'
|
query += 'tickets.state_id = ticket_states.id'
|
||||||
else
|
else
|
||||||
|
@ -786,15 +787,16 @@ condition example
|
||||||
elsif selector['operator'] == 'within last (relative)'
|
elsif selector['operator'] == 'within last (relative)'
|
||||||
query += "#{attribute} >= ?"
|
query += "#{attribute} >= ?"
|
||||||
time = nil
|
time = nil
|
||||||
if selector['range'] == 'minute'
|
case selector['range']
|
||||||
|
when 'minute'
|
||||||
time = Time.zone.now - selector['value'].to_i.minutes
|
time = Time.zone.now - selector['value'].to_i.minutes
|
||||||
elsif selector['range'] == 'hour'
|
when 'hour'
|
||||||
time = Time.zone.now - selector['value'].to_i.hours
|
time = Time.zone.now - selector['value'].to_i.hours
|
||||||
elsif selector['range'] == 'day'
|
when 'day'
|
||||||
time = Time.zone.now - selector['value'].to_i.days
|
time = Time.zone.now - selector['value'].to_i.days
|
||||||
elsif selector['range'] == 'month'
|
when 'month'
|
||||||
time = Time.zone.now - selector['value'].to_i.months
|
time = Time.zone.now - selector['value'].to_i.months
|
||||||
elsif selector['range'] == 'year'
|
when 'year'
|
||||||
time = Time.zone.now - selector['value'].to_i.years
|
time = Time.zone.now - selector['value'].to_i.years
|
||||||
else
|
else
|
||||||
raise "Unknown selector attributes '#{selector.inspect}'"
|
raise "Unknown selector attributes '#{selector.inspect}'"
|
||||||
|
@ -803,15 +805,16 @@ condition example
|
||||||
elsif selector['operator'] == 'within next (relative)'
|
elsif selector['operator'] == 'within next (relative)'
|
||||||
query += "#{attribute} <= ?"
|
query += "#{attribute} <= ?"
|
||||||
time = nil
|
time = nil
|
||||||
if selector['range'] == 'minute'
|
case selector['range']
|
||||||
|
when 'minute'
|
||||||
time = Time.zone.now + selector['value'].to_i.minutes
|
time = Time.zone.now + selector['value'].to_i.minutes
|
||||||
elsif selector['range'] == 'hour'
|
when 'hour'
|
||||||
time = Time.zone.now + selector['value'].to_i.hours
|
time = Time.zone.now + selector['value'].to_i.hours
|
||||||
elsif selector['range'] == 'day'
|
when 'day'
|
||||||
time = Time.zone.now + selector['value'].to_i.days
|
time = Time.zone.now + selector['value'].to_i.days
|
||||||
elsif selector['range'] == 'month'
|
when 'month'
|
||||||
time = Time.zone.now + selector['value'].to_i.months
|
time = Time.zone.now + selector['value'].to_i.months
|
||||||
elsif selector['range'] == 'year'
|
when 'year'
|
||||||
time = Time.zone.now + selector['value'].to_i.years
|
time = Time.zone.now + selector['value'].to_i.years
|
||||||
else
|
else
|
||||||
raise "Unknown selector attributes '#{selector.inspect}'"
|
raise "Unknown selector attributes '#{selector.inspect}'"
|
||||||
|
@ -820,15 +823,16 @@ condition example
|
||||||
elsif selector['operator'] == 'before (relative)'
|
elsif selector['operator'] == 'before (relative)'
|
||||||
query += "#{attribute} <= ?"
|
query += "#{attribute} <= ?"
|
||||||
time = nil
|
time = nil
|
||||||
if selector['range'] == 'minute'
|
case selector['range']
|
||||||
|
when 'minute'
|
||||||
time = Time.zone.now - selector['value'].to_i.minutes
|
time = Time.zone.now - selector['value'].to_i.minutes
|
||||||
elsif selector['range'] == 'hour'
|
when 'hour'
|
||||||
time = Time.zone.now - selector['value'].to_i.hours
|
time = Time.zone.now - selector['value'].to_i.hours
|
||||||
elsif selector['range'] == 'day'
|
when 'day'
|
||||||
time = Time.zone.now - selector['value'].to_i.days
|
time = Time.zone.now - selector['value'].to_i.days
|
||||||
elsif selector['range'] == 'month'
|
when 'month'
|
||||||
time = Time.zone.now - selector['value'].to_i.months
|
time = Time.zone.now - selector['value'].to_i.months
|
||||||
elsif selector['range'] == 'year'
|
when 'year'
|
||||||
time = Time.zone.now - selector['value'].to_i.years
|
time = Time.zone.now - selector['value'].to_i.years
|
||||||
else
|
else
|
||||||
raise "Unknown selector attributes '#{selector.inspect}'"
|
raise "Unknown selector attributes '#{selector.inspect}'"
|
||||||
|
@ -837,15 +841,16 @@ condition example
|
||||||
elsif selector['operator'] == 'after (relative)'
|
elsif selector['operator'] == 'after (relative)'
|
||||||
query += "#{attribute} >= ?"
|
query += "#{attribute} >= ?"
|
||||||
time = nil
|
time = nil
|
||||||
if selector['range'] == 'minute'
|
case selector['range']
|
||||||
|
when 'minute'
|
||||||
time = Time.zone.now + selector['value'].to_i.minutes
|
time = Time.zone.now + selector['value'].to_i.minutes
|
||||||
elsif selector['range'] == 'hour'
|
when 'hour'
|
||||||
time = Time.zone.now + selector['value'].to_i.hours
|
time = Time.zone.now + selector['value'].to_i.hours
|
||||||
elsif selector['range'] == 'day'
|
when 'day'
|
||||||
time = Time.zone.now + selector['value'].to_i.days
|
time = Time.zone.now + selector['value'].to_i.days
|
||||||
elsif selector['range'] == 'month'
|
when 'month'
|
||||||
time = Time.zone.now + selector['value'].to_i.months
|
time = Time.zone.now + selector['value'].to_i.months
|
||||||
elsif selector['range'] == 'year'
|
when 'year'
|
||||||
time = Time.zone.now + selector['value'].to_i.years
|
time = Time.zone.now + selector['value'].to_i.years
|
||||||
else
|
else
|
||||||
raise "Unknown selector attributes '#{selector.inspect}'"
|
raise "Unknown selector attributes '#{selector.inspect}'"
|
||||||
|
@ -944,11 +949,12 @@ perform changes on ticket
|
||||||
next if value['value'].blank?
|
next if value['value'].blank?
|
||||||
|
|
||||||
tags = value['value'].split(/,/)
|
tags = value['value'].split(/,/)
|
||||||
if value['operator'] == 'add'
|
case value['operator']
|
||||||
|
when 'add'
|
||||||
tags.each do |tag|
|
tags.each do |tag|
|
||||||
tag_add(tag, current_user_id || 1)
|
tag_add(tag, current_user_id || 1)
|
||||||
end
|
end
|
||||||
elsif value['operator'] == 'remove'
|
when 'remove'
|
||||||
tags.each do |tag|
|
tags.each do |tag|
|
||||||
tag_remove(tag, current_user_id || 1)
|
tag_remove(tag, current_user_id || 1)
|
||||||
end
|
end
|
||||||
|
@ -1365,7 +1371,8 @@ result
|
||||||
|
|
||||||
recipients_raw = []
|
recipients_raw = []
|
||||||
value_recipient.each do |recipient|
|
value_recipient.each do |recipient|
|
||||||
if recipient == 'article_last_sender'
|
case recipient
|
||||||
|
when 'article_last_sender'
|
||||||
if article.present?
|
if article.present?
|
||||||
if article.reply_to.present?
|
if article.reply_to.present?
|
||||||
recipients_raw.push(article.reply_to)
|
recipients_raw.push(article.reply_to)
|
||||||
|
@ -1379,17 +1386,17 @@ result
|
||||||
recipients_raw.push(email)
|
recipients_raw.push(email)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
elsif recipient == 'ticket_customer'
|
when 'ticket_customer'
|
||||||
email = User.find_by(id: customer_id).email
|
email = User.find_by(id: customer_id).email
|
||||||
recipients_raw.push(email)
|
recipients_raw.push(email)
|
||||||
elsif recipient == 'ticket_owner'
|
when 'ticket_owner'
|
||||||
email = User.find_by(id: owner_id).email
|
email = User.find_by(id: owner_id).email
|
||||||
recipients_raw.push(email)
|
recipients_raw.push(email)
|
||||||
elsif recipient == 'ticket_agents'
|
when 'ticket_agents'
|
||||||
User.group_access(group_id, 'full').sort_by(&:login).each do |user|
|
User.group_access(group_id, 'full').sort_by(&:login).each do |user|
|
||||||
recipients_raw.push(user.email)
|
recipients_raw.push(user.email)
|
||||||
end
|
end
|
||||||
elsif recipient =~ /\Auserid_(\d+)\z/
|
when /\Auserid_(\d+)\z/
|
||||||
user = User.lookup(id: $1)
|
user = User.lookup(id: $1)
|
||||||
if !user
|
if !user
|
||||||
logger.warn "Can't find configured Trigger Email recipient User with ID '#{$1}'"
|
logger.warn "Can't find configured Trigger Email recipient User with ID '#{$1}'"
|
||||||
|
|
|
@ -170,15 +170,16 @@ class Transaction::Notification
|
||||||
# get user based notification template
|
# get user based notification template
|
||||||
# if create, send create message / block update messages
|
# if create, send create message / block update messages
|
||||||
template = nil
|
template = nil
|
||||||
if @item[:type] == 'create'
|
case @item[:type]
|
||||||
|
when 'create'
|
||||||
template = 'ticket_create'
|
template = 'ticket_create'
|
||||||
elsif @item[:type] == 'update'
|
when 'update'
|
||||||
template = 'ticket_update'
|
template = 'ticket_update'
|
||||||
elsif @item[:type] == 'reminder_reached'
|
when 'reminder_reached'
|
||||||
template = 'ticket_reminder_reached'
|
template = 'ticket_reminder_reached'
|
||||||
elsif @item[:type] == 'escalation'
|
when 'escalation'
|
||||||
template = 'ticket_escalation'
|
template = 'ticket_escalation'
|
||||||
elsif @item[:type] == 'escalation_warning'
|
when 'escalation_warning'
|
||||||
template = 'ticket_escalation_warning'
|
template = 'ticket_escalation_warning'
|
||||||
else
|
else
|
||||||
raise "unknown type for notification #{@item[:type]}"
|
raise "unknown type for notification #{@item[:type]}"
|
||||||
|
|
|
@ -60,17 +60,18 @@ class Transaction::Slack
|
||||||
# if create, send create message / block update messages
|
# if create, send create message / block update messages
|
||||||
template = nil
|
template = nil
|
||||||
sent_value = nil
|
sent_value = nil
|
||||||
if @item[:type] == 'create'
|
case @item[:type]
|
||||||
|
when 'create'
|
||||||
template = 'ticket_create'
|
template = 'ticket_create'
|
||||||
elsif @item[:type] == 'update'
|
when 'update'
|
||||||
template = 'ticket_update'
|
template = 'ticket_update'
|
||||||
elsif @item[:type] == 'reminder_reached'
|
when 'reminder_reached'
|
||||||
template = 'ticket_reminder_reached'
|
template = 'ticket_reminder_reached'
|
||||||
sent_value = ticket.pending_time
|
sent_value = ticket.pending_time
|
||||||
elsif @item[:type] == 'escalation'
|
when 'escalation'
|
||||||
template = 'ticket_escalation'
|
template = 'ticket_escalation'
|
||||||
sent_value = ticket.escalation_at
|
sent_value = ticket.escalation_at
|
||||||
elsif @item[:type] == 'escalation_warning'
|
when 'escalation_warning'
|
||||||
template = 'ticket_escalation_warning'
|
template = 'ticket_escalation_warning'
|
||||||
sent_value = ticket.escalation_at
|
sent_value = ticket.escalation_at
|
||||||
else
|
else
|
||||||
|
|
|
@ -1058,9 +1058,10 @@ try to find correct name
|
||||||
return true if !preferences[:notification_sound]
|
return true if !preferences[:notification_sound]
|
||||||
return true if !preferences[:notification_sound][:enabled]
|
return true if !preferences[:notification_sound][:enabled]
|
||||||
|
|
||||||
if preferences[:notification_sound][:enabled] == 'true'
|
case preferences[:notification_sound][:enabled]
|
||||||
|
when 'true'
|
||||||
preferences[:notification_sound][:enabled] = true
|
preferences[:notification_sound][:enabled] = true
|
||||||
elsif preferences[:notification_sound][:enabled] == 'false'
|
when 'false'
|
||||||
preferences[:notification_sound][:enabled] = false
|
preferences[:notification_sound][:enabled] = false
|
||||||
end
|
end
|
||||||
class_name = preferences[:notification_sound][:enabled].class.to_s
|
class_name = preferences[:notification_sound][:enabled].class.to_s
|
||||||
|
|
|
@ -14,25 +14,25 @@ class ForeignKeys < ActiveRecord::Migration[4.2]
|
||||||
foreign_keys = [
|
foreign_keys = [
|
||||||
# Base
|
# Base
|
||||||
%i[users organizations],
|
%i[users organizations],
|
||||||
[:users, :users, column: :created_by_id],
|
[:users, :users, { column: :created_by_id }],
|
||||||
[:users, :users, column: :updated_by_id],
|
[:users, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:signatures, :users, column: :created_by_id],
|
[:signatures, :users, { column: :created_by_id }],
|
||||||
[:signatures, :users, column: :updated_by_id],
|
[:signatures, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:email_addresses, :users, column: :created_by_id],
|
[:email_addresses, :users, { column: :created_by_id }],
|
||||||
[:email_addresses, :users, column: :updated_by_id],
|
[:email_addresses, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[groups signatures],
|
%i[groups signatures],
|
||||||
%i[groups email_addresses],
|
%i[groups email_addresses],
|
||||||
[:groups, :users, column: :created_by_id],
|
[:groups, :users, { column: :created_by_id }],
|
||||||
[:groups, :users, column: :updated_by_id],
|
[:groups, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:roles, :users, column: :created_by_id],
|
[:roles, :users, { column: :created_by_id }],
|
||||||
[:roles, :users, column: :updated_by_id],
|
[:roles, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:organizations, :users, column: :created_by_id],
|
[:organizations, :users, { column: :created_by_id }],
|
||||||
[:organizations, :users, column: :updated_by_id],
|
[:organizations, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[roles_users users],
|
%i[roles_users users],
|
||||||
%i[roles_users roles],
|
%i[roles_users roles],
|
||||||
|
@ -45,108 +45,108 @@ class ForeignKeys < ActiveRecord::Migration[4.2]
|
||||||
|
|
||||||
%i[authorizations users],
|
%i[authorizations users],
|
||||||
|
|
||||||
[:translations, :users, column: :created_by_id],
|
[:translations, :users, { column: :created_by_id }],
|
||||||
[:translations, :users, column: :updated_by_id],
|
[:translations, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[tokens users],
|
%i[tokens users],
|
||||||
|
|
||||||
[:packages, :users, column: :created_by_id],
|
[:packages, :users, { column: :created_by_id }],
|
||||||
[:packages, :users, column: :updated_by_id],
|
[:packages, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[taskbars users],
|
%i[taskbars users],
|
||||||
|
|
||||||
%i[tags tag_items],
|
%i[tags tag_items],
|
||||||
%i[tags tag_objects],
|
%i[tags tag_objects],
|
||||||
[:tags, :users, column: :created_by_id],
|
[:tags, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:recent_views, :object_lookups, column: :recent_view_object_id],
|
[:recent_views, :object_lookups, { column: :recent_view_object_id }],
|
||||||
[:recent_views, :users, column: :created_by_id],
|
[:recent_views, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:activity_streams, :type_lookups, column: :activity_stream_type_id],
|
[:activity_streams, :type_lookups, { column: :activity_stream_type_id }],
|
||||||
[:activity_streams, :object_lookups, column: :activity_stream_object_id],
|
[:activity_streams, :object_lookups, { column: :activity_stream_object_id }],
|
||||||
%i[activity_streams permissions],
|
%i[activity_streams permissions],
|
||||||
%i[activity_streams groups],
|
%i[activity_streams groups],
|
||||||
[:activity_streams, :users, column: :created_by_id],
|
[:activity_streams, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
%i[histories history_types],
|
%i[histories history_types],
|
||||||
%i[histories history_objects],
|
%i[histories history_objects],
|
||||||
%i[histories history_attributes],
|
%i[histories history_attributes],
|
||||||
[:histories, :users, column: :created_by_id],
|
[:histories, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
%i[stores store_objects],
|
%i[stores store_objects],
|
||||||
%i[stores store_files],
|
%i[stores store_files],
|
||||||
[:stores, :users, column: :created_by_id],
|
[:stores, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:avatars, :users, column: :created_by_id],
|
[:avatars, :users, { column: :created_by_id }],
|
||||||
[:avatars, :users, column: :updated_by_id],
|
[:avatars, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:online_notifications, :users, column: :created_by_id],
|
[:online_notifications, :users, { column: :created_by_id }],
|
||||||
[:online_notifications, :users, column: :updated_by_id],
|
[:online_notifications, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:schedulers, :users, column: :created_by_id],
|
[:schedulers, :users, { column: :created_by_id }],
|
||||||
[:schedulers, :users, column: :updated_by_id],
|
[:schedulers, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:calendars, :users, column: :created_by_id],
|
[:calendars, :users, { column: :created_by_id }],
|
||||||
[:calendars, :users, column: :updated_by_id],
|
[:calendars, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[user_devices users],
|
%i[user_devices users],
|
||||||
|
|
||||||
%i[object_manager_attributes object_lookups],
|
%i[object_manager_attributes object_lookups],
|
||||||
[:object_manager_attributes, :users, column: :created_by_id],
|
[:object_manager_attributes, :users, { column: :created_by_id }],
|
||||||
[:object_manager_attributes, :users, column: :updated_by_id],
|
[:object_manager_attributes, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[cti_caller_ids users],
|
%i[cti_caller_ids users],
|
||||||
|
|
||||||
[:stats_stores, :users, column: :created_by_id],
|
[:stats_stores, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:http_logs, :users, column: :created_by_id],
|
[:http_logs, :users, { column: :created_by_id }],
|
||||||
[:http_logs, :users, column: :updated_by_id],
|
[:http_logs, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
# Ticket
|
# Ticket
|
||||||
[:ticket_state_types, :users, column: :created_by_id],
|
[:ticket_state_types, :users, { column: :created_by_id }],
|
||||||
[:ticket_state_types, :users, column: :updated_by_id],
|
[:ticket_state_types, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:ticket_states, :ticket_state_types, column: :state_type_id],
|
[:ticket_states, :ticket_state_types, { column: :state_type_id }],
|
||||||
[:ticket_states, :users, column: :created_by_id],
|
[:ticket_states, :users, { column: :created_by_id }],
|
||||||
[:ticket_states, :users, column: :updated_by_id],
|
[:ticket_states, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:ticket_priorities, :users, column: :created_by_id],
|
[:ticket_priorities, :users, { column: :created_by_id }],
|
||||||
[:ticket_priorities, :users, column: :updated_by_id],
|
[:ticket_priorities, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[tickets groups],
|
%i[tickets groups],
|
||||||
[:tickets, :users, column: :owner_id],
|
[:tickets, :users, { column: :owner_id }],
|
||||||
[:tickets, :users, column: :customer_id],
|
[:tickets, :users, { column: :customer_id }],
|
||||||
[:tickets, :ticket_priorities, column: :priority_id],
|
[:tickets, :ticket_priorities, { column: :priority_id }],
|
||||||
[:tickets, :ticket_states, column: :state_id],
|
[:tickets, :ticket_states, { column: :state_id }],
|
||||||
%i[tickets organizations],
|
%i[tickets organizations],
|
||||||
[:tickets, :users, column: :created_by_id],
|
[:tickets, :users, { column: :created_by_id }],
|
||||||
[:tickets, :users, column: :updated_by_id],
|
[:tickets, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:ticket_flags, :tickets, column: :ticket_id],
|
[:ticket_flags, :tickets, { column: :ticket_id }],
|
||||||
[:ticket_flags, :users, column: :created_by_id],
|
[:ticket_flags, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:ticket_article_types, :users, column: :created_by_id],
|
[:ticket_article_types, :users, { column: :created_by_id }],
|
||||||
[:ticket_article_types, :users, column: :updated_by_id],
|
[:ticket_article_types, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:ticket_article_senders, :users, column: :created_by_id],
|
[:ticket_article_senders, :users, { column: :created_by_id }],
|
||||||
[:ticket_article_senders, :users, column: :updated_by_id],
|
[:ticket_article_senders, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[ticket_articles tickets],
|
%i[ticket_articles tickets],
|
||||||
[:ticket_articles, :ticket_article_types, column: :type_id],
|
[:ticket_articles, :ticket_article_types, { column: :type_id }],
|
||||||
[:ticket_articles, :ticket_article_senders, column: :sender_id],
|
[:ticket_articles, :ticket_article_senders, { column: :sender_id }],
|
||||||
[:ticket_articles, :users, column: :created_by_id],
|
[:ticket_articles, :users, { column: :created_by_id }],
|
||||||
[:ticket_articles, :users, column: :updated_by_id],
|
[:ticket_articles, :users, { column: :updated_by_id }],
|
||||||
[:ticket_articles, :users, column: :origin_by_id],
|
[:ticket_articles, :users, { column: :origin_by_id }],
|
||||||
|
|
||||||
[:ticket_article_flags, :ticket_articles, column: :ticket_article_id],
|
[:ticket_article_flags, :ticket_articles, { column: :ticket_article_id }],
|
||||||
[:ticket_article_flags, :users, column: :created_by_id],
|
[:ticket_article_flags, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
%i[ticket_time_accountings tickets],
|
%i[ticket_time_accountings tickets],
|
||||||
%i[ticket_time_accountings ticket_articles],
|
%i[ticket_time_accountings ticket_articles],
|
||||||
[:ticket_time_accountings, :users, column: :created_by_id],
|
[:ticket_time_accountings, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:overviews, :users, column: :created_by_id],
|
[:overviews, :users, { column: :created_by_id }],
|
||||||
[:overviews, :users, column: :updated_by_id],
|
[:overviews, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[overviews_roles overviews],
|
%i[overviews_roles overviews],
|
||||||
%i[overviews_roles roles],
|
%i[overviews_roles roles],
|
||||||
|
@ -157,65 +157,65 @@ class ForeignKeys < ActiveRecord::Migration[4.2]
|
||||||
%i[overviews_groups overviews],
|
%i[overviews_groups overviews],
|
||||||
%i[overviews_groups groups],
|
%i[overviews_groups groups],
|
||||||
|
|
||||||
[:triggers, :users, column: :created_by_id],
|
[:triggers, :users, { column: :created_by_id }],
|
||||||
[:triggers, :users, column: :updated_by_id],
|
[:triggers, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:jobs, :users, column: :created_by_id],
|
[:jobs, :users, { column: :created_by_id }],
|
||||||
[:jobs, :users, column: :updated_by_id],
|
[:jobs, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[links link_types],
|
%i[links link_types],
|
||||||
|
|
||||||
[:postmaster_filters, :users, column: :created_by_id],
|
[:postmaster_filters, :users, { column: :created_by_id }],
|
||||||
[:postmaster_filters, :users, column: :updated_by_id],
|
[:postmaster_filters, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[text_modules users],
|
%i[text_modules users],
|
||||||
[:text_modules, :users, column: :created_by_id],
|
[:text_modules, :users, { column: :created_by_id }],
|
||||||
[:text_modules, :users, column: :updated_by_id],
|
[:text_modules, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[text_modules_groups text_modules],
|
%i[text_modules_groups text_modules],
|
||||||
%i[text_modules_groups groups],
|
%i[text_modules_groups groups],
|
||||||
|
|
||||||
%i[templates users],
|
%i[templates users],
|
||||||
[:templates, :users, column: :created_by_id],
|
[:templates, :users, { column: :created_by_id }],
|
||||||
[:templates, :users, column: :updated_by_id],
|
[:templates, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[templates_groups templates],
|
%i[templates_groups templates],
|
||||||
%i[templates_groups groups],
|
%i[templates_groups groups],
|
||||||
|
|
||||||
%i[channels groups],
|
%i[channels groups],
|
||||||
[:channels, :users, column: :created_by_id],
|
[:channels, :users, { column: :created_by_id }],
|
||||||
[:channels, :users, column: :updated_by_id],
|
[:channels, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:slas, :users, column: :created_by_id],
|
[:slas, :users, { column: :created_by_id }],
|
||||||
[:slas, :users, column: :updated_by_id],
|
[:slas, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:macros, :users, column: :created_by_id],
|
[:macros, :users, { column: :created_by_id }],
|
||||||
[:macros, :users, column: :updated_by_id],
|
[:macros, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:chats, :users, column: :created_by_id],
|
[:chats, :users, { column: :created_by_id }],
|
||||||
[:chats, :users, column: :updated_by_id],
|
[:chats, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:chat_topics, :users, column: :created_by_id],
|
[:chat_topics, :users, { column: :created_by_id }],
|
||||||
[:chat_topics, :users, column: :updated_by_id],
|
[:chat_topics, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[chat_sessions chats],
|
%i[chat_sessions chats],
|
||||||
%i[chat_sessions users],
|
%i[chat_sessions users],
|
||||||
[:chat_sessions, :users, column: :created_by_id],
|
[:chat_sessions, :users, { column: :created_by_id }],
|
||||||
[:chat_sessions, :users, column: :updated_by_id],
|
[:chat_sessions, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[chat_messages chat_sessions],
|
%i[chat_messages chat_sessions],
|
||||||
[:chat_messages, :users, column: :created_by_id],
|
[:chat_messages, :users, { column: :created_by_id }],
|
||||||
|
|
||||||
[:chat_agents, :users, column: :created_by_id],
|
[:chat_agents, :users, { column: :created_by_id }],
|
||||||
[:chat_agents, :users, column: :updated_by_id],
|
[:chat_agents, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
[:report_profiles, :users, column: :created_by_id],
|
[:report_profiles, :users, { column: :created_by_id }],
|
||||||
[:report_profiles, :users, column: :updated_by_id],
|
[:report_profiles, :users, { column: :updated_by_id }],
|
||||||
|
|
||||||
%i[karma_users users],
|
%i[karma_users users],
|
||||||
|
|
||||||
%i[karma_activity_logs users],
|
%i[karma_activity_logs users],
|
||||||
[:karma_activity_logs, :karma_activities, column: :activity_id],
|
[:karma_activity_logs, :karma_activities, { column: :activity_id }],
|
||||||
]
|
]
|
||||||
|
|
||||||
foreign_keys.each do |foreign_key|
|
foreign_keys.each do |foreign_key|
|
||||||
|
|
|
@ -23,11 +23,12 @@ module Import
|
||||||
|
|
||||||
def booleanize_values(properties)
|
def booleanize_values(properties)
|
||||||
properties.each do |key, value|
|
properties.each do |key, value|
|
||||||
if value.is_a?(String)
|
case value
|
||||||
|
when String
|
||||||
next if !%w[true false].include?(value)
|
next if !%w[true false].include?(value)
|
||||||
|
|
||||||
properties[key] = value == 'true'
|
properties[key] = value == 'true'
|
||||||
elsif value.is_a?(Hash)
|
when Hash
|
||||||
properties[key] = booleanize_values(value)
|
properties[key] = booleanize_values(value)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -48,9 +48,10 @@ returns
|
||||||
|
|
||||||
owned_by_nobody = false
|
owned_by_nobody = false
|
||||||
owned_by_me = false
|
owned_by_me = false
|
||||||
if ticket.owner_id == 1
|
case ticket.owner_id
|
||||||
|
when 1
|
||||||
owned_by_nobody = true
|
owned_by_nobody = true
|
||||||
elsif ticket.owner_id == user.id
|
when user.id
|
||||||
owned_by_me = true
|
owned_by_me = true
|
||||||
else
|
else
|
||||||
# check the replacement chain of max 10
|
# check the replacement chain of max 10
|
||||||
|
|
|
@ -23,32 +23,36 @@ returns
|
||||||
params = params_origin.dup
|
params = params_origin.dup
|
||||||
|
|
||||||
result = []
|
result = []
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
stop_interval = 12
|
stop_interval = 12
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
stop_interval = 7
|
stop_interval = 7
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
stop_interval = 31
|
stop_interval = 31
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
stop_interval = 24
|
stop_interval = 24
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
stop_interval = 60
|
stop_interval = 60
|
||||||
end
|
end
|
||||||
(1..stop_interval).each do |_counter|
|
|
||||||
if params[:interval] == 'month'
|
|
||||||
params[:range_end] = params[:range_start].next_month
|
|
||||||
elsif params[:interval] == 'week'
|
|
||||||
params[:range_end] = params[:range_start].next_day
|
|
||||||
elsif params[:interval] == 'day'
|
|
||||||
params[:range_end] = params[:range_start].next_day
|
|
||||||
elsif params[:interval] == 'hour'
|
|
||||||
params[:range_end] = params[:range_start] + 1.hour
|
|
||||||
elsif params[:interval] == 'minute'
|
|
||||||
params[:range_end] = params[:range_start] + 1.minute
|
|
||||||
end
|
|
||||||
query, bind_params, tables = Ticket.selector2sql(params[:selector])
|
query, bind_params, tables = Ticket.selector2sql(params[:selector])
|
||||||
sender = Ticket::Article::Sender.lookup(name: params[:params][:sender])
|
sender = Ticket::Article::Sender.lookup(name: params[:params][:sender])
|
||||||
type = Ticket::Article::Type.lookup(name: params[:params][:type])
|
type = Ticket::Article::Type.lookup(name: params[:params][:type])
|
||||||
|
|
||||||
|
(1..stop_interval).each do |_counter|
|
||||||
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
|
params[:range_end] = params[:range_start].next_month
|
||||||
|
when 'week'
|
||||||
|
params[:range_end] = params[:range_start].next_day
|
||||||
|
when 'day'
|
||||||
|
params[:range_end] = params[:range_start].next_day
|
||||||
|
when 'hour'
|
||||||
|
params[:range_end] = params[:range_start] + 1.hour
|
||||||
|
when 'minute'
|
||||||
|
params[:range_end] = params[:range_start] + 1.minute
|
||||||
|
end
|
||||||
count = Ticket::Article.joins('INNER JOIN tickets ON tickets.id = ticket_articles.ticket_id')
|
count = Ticket::Article.joins('INNER JOIN tickets ON tickets.id = ticket_articles.ticket_id')
|
||||||
.where(query, *bind_params).joins(tables)
|
.where(query, *bind_params).joins(tables)
|
||||||
.where(
|
.where(
|
||||||
|
|
|
@ -19,27 +19,29 @@ returns
|
||||||
params = params_origin.dup
|
params = params_origin.dup
|
||||||
|
|
||||||
result = []
|
result = []
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
stop_interval = 12
|
stop_interval = 12
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
stop_interval = 7
|
stop_interval = 7
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
stop_interval = 31
|
stop_interval = 31
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
stop_interval = 24
|
stop_interval = 24
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
stop_interval = 60
|
stop_interval = 60
|
||||||
end
|
end
|
||||||
(1..stop_interval).each do |_counter|
|
(1..stop_interval).each do |_counter|
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
params[:range_end] = params[:range_start].next_month
|
params[:range_end] = params[:range_start].next_month
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
params[:range_end] = params[:range_start] + 1.hour
|
params[:range_end] = params[:range_start] + 1.hour
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
params[:range_end] = params[:range_start] + 1.minute
|
params[:range_end] = params[:range_start] + 1.minute
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -46,15 +46,16 @@ returns
|
||||||
selector.merge!(without_merged_tickets) # do not show merged tickets in reports
|
selector.merge!(without_merged_tickets) # do not show merged tickets in reports
|
||||||
|
|
||||||
result_es = SearchIndexBackend.selectors('Ticket', selector, {}, aggs_interval)
|
result_es = SearchIndexBackend.selectors('Ticket', selector, {}, aggs_interval)
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
stop_interval = 12
|
stop_interval = 12
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
stop_interval = 7
|
stop_interval = 7
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
stop_interval = ((params[:range_end] - params[:range_start]) / 86_400).to_i + 1
|
stop_interval = ((params[:range_end] - params[:range_start]) / 86_400).to_i + 1
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
stop_interval = 24
|
stop_interval = 24
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
stop_interval = 60
|
stop_interval = 60
|
||||||
end
|
end
|
||||||
result = []
|
result = []
|
||||||
|
@ -80,9 +81,10 @@ returns
|
||||||
|
|
||||||
# only compare date - in certain cases elasticsearch timezone offset will not match
|
# only compare date - in certain cases elasticsearch timezone offset will not match
|
||||||
replace = ':\d\dZ$'
|
replace = ':\d\dZ$'
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
replace = '\d\dT\d\d:\d\d:\d\dZ$'
|
replace = '\d\dT\d\d:\d\d:\d\dZ$'
|
||||||
elsif params[:interval] == 'day' || params[:interval] == 'week'
|
when 'day', 'week'
|
||||||
replace = '\d\d:\d\d:\d\dZ$'
|
replace = '\d\d:\d\d:\d\dZ$'
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -91,30 +93,32 @@ returns
|
||||||
|
|
||||||
match = true
|
match = true
|
||||||
result.push item['doc_count']
|
result.push item['doc_count']
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
params[:range_start] = params[:range_start].next_month
|
params[:range_start] = params[:range_start].next_month
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
params[:range_start] = params[:range_start].next_day
|
params[:range_start] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
params[:range_start] = params[:range_start].next_day
|
params[:range_start] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
params[:range_start] = params[:range_start] + 1.hour
|
params[:range_start] = params[:range_start] + 1.hour
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
params[:range_start] = params[:range_start] + 1.minute
|
params[:range_start] = params[:range_start] + 1.minute
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
next if match
|
next if match
|
||||||
|
|
||||||
result.push 0
|
result.push 0
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
params[:range_start] = params[:range_start].next_month
|
params[:range_start] = params[:range_start].next_month
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
params[:range_start] = params[:range_start].next_day
|
params[:range_start] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
params[:range_start] = params[:range_start] + 1.day
|
params[:range_start] = params[:range_start] + 1.day
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
params[:range_start] = params[:range_start] + 1.hour
|
params[:range_start] = params[:range_start] + 1.hour
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
params[:range_start] = params[:range_start] + 1.minute
|
params[:range_start] = params[:range_start] + 1.minute
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -27,27 +27,29 @@ returns
|
||||||
end
|
end
|
||||||
|
|
||||||
result = []
|
result = []
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
stop_interval = 12
|
stop_interval = 12
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
stop_interval = 7
|
stop_interval = 7
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
stop_interval = 31
|
stop_interval = 31
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
stop_interval = 24
|
stop_interval = 24
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
stop_interval = 60
|
stop_interval = 60
|
||||||
end
|
end
|
||||||
(1..stop_interval).each do |_counter|
|
(1..stop_interval).each do |_counter|
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
params[:range_end] = params[:range_start].next_month
|
params[:range_end] = params[:range_start].next_month
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
params[:range_end] = params[:range_start] + 1.hour
|
params[:range_end] = params[:range_start] + 1.hour
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
params[:range_end] = params[:range_start] + 1.minute
|
params[:range_end] = params[:range_start] + 1.minute
|
||||||
end
|
end
|
||||||
local_params = group_attributes(selector, params)
|
local_params = group_attributes(selector, params)
|
||||||
|
@ -141,7 +143,8 @@ returns
|
||||||
|
|
||||||
def self.group_attributes(selector, params)
|
def self.group_attributes(selector, params)
|
||||||
group_id = selector['value']
|
group_id = selector['value']
|
||||||
if selector['operator'] == 'is'
|
case selector['operator']
|
||||||
|
when 'is'
|
||||||
if params[:params][:type] == 'in'
|
if params[:params][:type] == 'in'
|
||||||
return {
|
return {
|
||||||
id_not_from: group_id,
|
id_not_from: group_id,
|
||||||
|
@ -153,7 +156,7 @@ returns
|
||||||
id_not_to: group_id,
|
id_not_to: group_id,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
elsif selector['operator'] == 'is not'
|
when 'is not'
|
||||||
if params[:params][:type] == 'in'
|
if params[:params][:type] == 'in'
|
||||||
return {
|
return {
|
||||||
id_from: group_id,
|
id_from: group_id,
|
||||||
|
|
|
@ -21,27 +21,29 @@ returns
|
||||||
ticket_state_ids = ticket_ids
|
ticket_state_ids = ticket_ids
|
||||||
|
|
||||||
result = []
|
result = []
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
stop_interval = 12
|
stop_interval = 12
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
stop_interval = 7
|
stop_interval = 7
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
stop_interval = 31
|
stop_interval = 31
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
stop_interval = 24
|
stop_interval = 24
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
stop_interval = 60
|
stop_interval = 60
|
||||||
end
|
end
|
||||||
(1..stop_interval).each do |_counter|
|
(1..stop_interval).each do |_counter|
|
||||||
if params[:interval] == 'month'
|
case params[:interval]
|
||||||
|
when 'month'
|
||||||
params[:range_end] = params[:range_start].next_month
|
params[:range_end] = params[:range_start].next_month
|
||||||
elsif params[:interval] == 'week'
|
when 'week'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'day'
|
when 'day'
|
||||||
params[:range_end] = params[:range_start].next_day
|
params[:range_end] = params[:range_start].next_day
|
||||||
elsif params[:interval] == 'hour'
|
when 'hour'
|
||||||
params[:range_end] = params[:range_start] + 1.hour
|
params[:range_end] = params[:range_start] + 1.hour
|
||||||
elsif params[:interval] == 'minute'
|
when 'minute'
|
||||||
params[:range_end] = params[:range_start] + 1.minute
|
params[:range_end] = params[:range_start] + 1.minute
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -524,33 +524,36 @@ example for aggregations within one year
|
||||||
end
|
end
|
||||||
|
|
||||||
# is/is not/contains/contains not
|
# is/is not/contains/contains not
|
||||||
if data['operator'] == 'is' || data['operator'] == 'is not' || data['operator'] == 'contains' || data['operator'] == 'contains not'
|
case data['operator']
|
||||||
|
when 'is', 'is not', 'contains', 'contains not'
|
||||||
t[wildcard_or_term] = {}
|
t[wildcard_or_term] = {}
|
||||||
t[wildcard_or_term][key_tmp] = data['value']
|
t[wildcard_or_term][key_tmp] = data['value']
|
||||||
if data['operator'] == 'is' || data['operator'] == 'contains'
|
case data['operator']
|
||||||
|
when 'is', 'contains'
|
||||||
query_must.push t
|
query_must.push t
|
||||||
elsif data['operator'] == 'is not' || data['operator'] == 'contains not'
|
when 'is not', 'contains not'
|
||||||
query_must_not.push t
|
query_must_not.push t
|
||||||
end
|
end
|
||||||
elsif data['operator'] == 'contains all' || data['operator'] == 'contains one' || data['operator'] == 'contains all not' || data['operator'] == 'contains one not'
|
when 'contains all', 'contains one', 'contains all not', 'contains one not'
|
||||||
values = data['value'].split(',').map(&:strip)
|
values = data['value'].split(',').map(&:strip)
|
||||||
t[:query_string] = {}
|
t[:query_string] = {}
|
||||||
if data['operator'] == 'contains all'
|
case data['operator']
|
||||||
|
when 'contains all'
|
||||||
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" AND "')}\""
|
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" AND "')}\""
|
||||||
query_must.push t
|
query_must.push t
|
||||||
elsif data['operator'] == 'contains one not'
|
when 'contains one not'
|
||||||
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" OR "')}\""
|
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" OR "')}\""
|
||||||
query_must_not.push t
|
query_must_not.push t
|
||||||
elsif data['operator'] == 'contains one'
|
when 'contains one'
|
||||||
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" OR "')}\""
|
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" OR "')}\""
|
||||||
query_must.push t
|
query_must.push t
|
||||||
elsif data['operator'] == 'contains all not'
|
when 'contains all not'
|
||||||
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" AND "')}\""
|
t[:query_string][:query] = "#{key_tmp}:\"#{values.join('" AND "')}\""
|
||||||
query_must_not.push t
|
query_must_not.push t
|
||||||
end
|
end
|
||||||
|
|
||||||
# within last/within next (relative)
|
# within last/within next (relative)
|
||||||
elsif data['operator'] == 'within last (relative)' || data['operator'] == 'within next (relative)'
|
when 'within last (relative)', 'within next (relative)'
|
||||||
range = relative_map[data['range'].to_sym]
|
range = relative_map[data['range'].to_sym]
|
||||||
if range.blank?
|
if range.blank?
|
||||||
raise "Invalid relative_map for range '#{data['range']}'."
|
raise "Invalid relative_map for range '#{data['range']}'."
|
||||||
|
@ -566,7 +569,7 @@ example for aggregations within one year
|
||||||
query_must.push t
|
query_must.push t
|
||||||
|
|
||||||
# before/after (relative)
|
# before/after (relative)
|
||||||
elsif data['operator'] == 'before (relative)' || data['operator'] == 'after (relative)'
|
when 'before (relative)', 'after (relative)'
|
||||||
range = relative_map[data['range'].to_sym]
|
range = relative_map[data['range'].to_sym]
|
||||||
if range.blank?
|
if range.blank?
|
||||||
raise "Invalid relative_map for range '#{data['range']}'."
|
raise "Invalid relative_map for range '#{data['range']}'."
|
||||||
|
@ -582,7 +585,7 @@ example for aggregations within one year
|
||||||
query_must.push t
|
query_must.push t
|
||||||
|
|
||||||
# before/after (absolute)
|
# before/after (absolute)
|
||||||
elsif data['operator'] == 'before (absolute)' || data['operator'] == 'after (absolute)'
|
when 'before (absolute)', 'after (absolute)'
|
||||||
t[:range] = {}
|
t[:range] = {}
|
||||||
t[:range][key_tmp] = {}
|
t[:range][key_tmp] = {}
|
||||||
if data['operator'] == 'before (absolute)'
|
if data['operator'] == 'before (absolute)'
|
||||||
|
|
|
@ -794,9 +794,10 @@ returns
|
||||||
# we use it in rails and non rails context
|
# we use it in rails and non rails context
|
||||||
def self.log(level, message)
|
def self.log(level, message)
|
||||||
if defined?(Rails)
|
if defined?(Rails)
|
||||||
if level == 'debug'
|
case level
|
||||||
|
when 'debug'
|
||||||
Rails.logger.debug { message }
|
Rails.logger.debug { message }
|
||||||
elsif level == 'notice'
|
when 'notice'
|
||||||
Rails.logger.notice message
|
Rails.logger.notice message
|
||||||
else
|
else
|
||||||
Rails.logger.error message
|
Rails.logger.error message
|
||||||
|
|
|
@ -145,13 +145,14 @@ generate filename based on Store model
|
||||||
def self.filename(file)
|
def self.filename(file)
|
||||||
hash = Digest::MD5.hexdigest(file.content)
|
hash = Digest::MD5.hexdigest(file.content)
|
||||||
extention = ''
|
extention = ''
|
||||||
if file.preferences['Content-Type'].match?(/jpg|jpeg/i)
|
case file.preferences['Content-Type']
|
||||||
|
when /jpg|jpeg/i
|
||||||
extention = '.jpg'
|
extention = '.jpg'
|
||||||
elsif file.preferences['Content-Type'].match?(/png/i)
|
when /png/i
|
||||||
extention = '.png'
|
extention = '.png'
|
||||||
elsif file.preferences['Content-Type'].match?(/gif/i)
|
when /gif/i
|
||||||
extention = '.gif'
|
extention = '.gif'
|
||||||
elsif file.preferences['Content-Type'].match?(/svg/i)
|
when /svg/i
|
||||||
extention = '.svg'
|
extention = '.svg'
|
||||||
end
|
end
|
||||||
"#{hash}#{extention}"
|
"#{hash}#{extention}"
|
||||||
|
|
|
@ -480,7 +480,8 @@ create a tweet or direct message from an article
|
||||||
def from_article(article)
|
def from_article(article)
|
||||||
|
|
||||||
tweet = nil
|
tweet = nil
|
||||||
if article[:type] == 'twitter direct-message'
|
case article[:type]
|
||||||
|
when 'twitter direct-message'
|
||||||
|
|
||||||
Rails.logger.debug { "Create twitter direct message from article to '#{article[:to]}'..." }
|
Rails.logger.debug { "Create twitter direct message from article to '#{article[:to]}'..." }
|
||||||
|
|
||||||
|
@ -509,7 +510,7 @@ create a tweet or direct message from an article
|
||||||
|
|
||||||
tweet = Twitter::REST::Request.new(@client, :json_post, '/1.1/direct_messages/events/new.json', data).perform
|
tweet = Twitter::REST::Request.new(@client, :json_post, '/1.1/direct_messages/events/new.json', data).perform
|
||||||
|
|
||||||
elsif article[:type] == 'twitter status'
|
when 'twitter status'
|
||||||
|
|
||||||
Rails.logger.debug { 'Create tweet from article...' }
|
Rails.logger.debug { 'Create tweet from article...' }
|
||||||
|
|
||||||
|
|
|
@ -77,10 +77,10 @@ RSpec.describe Sessions::Event::ChatSessionStart do
|
||||||
messages = Sessions.queue(client_id)
|
messages = Sessions.queue(client_id)
|
||||||
expect(messages.count).to eq(1)
|
expect(messages.count).to eq(1)
|
||||||
expect(messages).to eq([
|
expect(messages).to eq([
|
||||||
'event' => 'chat_error',
|
{ 'event' => 'chat_error',
|
||||||
'data' => {
|
'data' => {
|
||||||
'state' => 'no_permission'
|
'state' => 'no_permission'
|
||||||
}
|
} }
|
||||||
])
|
])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -53,10 +53,10 @@ RSpec.describe Sessions::Event::ChatTransfer do
|
||||||
messages = Sessions.queue(client_id)
|
messages = Sessions.queue(client_id)
|
||||||
expect(messages.count).to eq(1)
|
expect(messages.count).to eq(1)
|
||||||
expect(messages).to eq([
|
expect(messages).to eq([
|
||||||
'event' => 'chat_error',
|
{ 'event' => 'chat_error',
|
||||||
'data' => {
|
'data' => {
|
||||||
'state' => 'no_permission'
|
'state' => 'no_permission'
|
||||||
}
|
} }
|
||||||
])
|
])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -84,9 +84,9 @@ AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
|
||||||
body: 'some body',
|
body: 'some body',
|
||||||
type: 'note',
|
type: 'note',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => 'dGVzdCAxMjM=',
|
'data' => 'dGVzdCAxMjM=',
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
post '/api/v1/ticket_articles', params: params, as: :json
|
post '/api/v1/ticket_articles', params: params, as: :json
|
||||||
|
|
|
@ -429,9 +429,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => 'dGVzdCAxMjM=',
|
'data' => 'dGVzdCAxMjM=',
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -506,9 +506,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => 'ABC_INVALID_BASE64',
|
'data' => 'ABC_INVALID_BASE64',
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -528,9 +528,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => "LARGE_INVALID_BASE64_#{'#' * 20_000_000}",
|
'data' => "LARGE_INVALID_BASE64_#{'#' * 20_000_000}",
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -550,9 +550,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => Base64.encode64('a' * 1_000),
|
'data' => Base64.encode64('a' * 1_000),
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -576,9 +576,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => Base64.strict_encode64('a' * 1_000),
|
'data' => Base64.strict_encode64('a' * 1_000),
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -602,8 +602,8 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
subject: 'some test 123',
|
subject: 'some test 123',
|
||||||
body: 'some test 123',
|
body: 'some test 123',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => 'dGVzdCAxMjM=',
|
'data' => 'dGVzdCAxMjM=' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -665,9 +665,9 @@ RSpec.describe 'Ticket', type: :request do
|
||||||
body: 'some test 123 <img src=""
|
body: 'some test 123 <img src=""
|
||||||
>',
|
>',
|
||||||
attachments: [
|
attachments: [
|
||||||
'filename' => 'some_file.txt',
|
{ 'filename' => 'some_file.txt',
|
||||||
'data' => 'dGVzdCAxMjM=',
|
'data' => 'dGVzdCAxMjM=',
|
||||||
'mime-type' => 'text/plain',
|
'mime-type' => 'text/plain' },
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,7 +41,8 @@ class TestCase < ActiveSupport::TestCase
|
||||||
|
|
||||||
def profile
|
def profile
|
||||||
browser_profile = nil
|
browser_profile = nil
|
||||||
if browser == 'firefox'
|
case browser
|
||||||
|
when 'firefox'
|
||||||
browser_profile = Selenium::WebDriver::Firefox::Profile.new
|
browser_profile = Selenium::WebDriver::Firefox::Profile.new
|
||||||
|
|
||||||
browser_profile['intl.locale.matchOS'] = false
|
browser_profile['intl.locale.matchOS'] = false
|
||||||
|
@ -50,7 +51,7 @@ class TestCase < ActiveSupport::TestCase
|
||||||
# currently console log not working for firefox
|
# currently console log not working for firefox
|
||||||
# https://github.com/SeleniumHQ/selenium/issues/1161
|
# https://github.com/SeleniumHQ/selenium/issues/1161
|
||||||
#browser_profile['loggingPref'] = { browser: :all }
|
#browser_profile['loggingPref'] = { browser: :all }
|
||||||
elsif browser == 'chrome'
|
when 'chrome'
|
||||||
|
|
||||||
# profile are only working on remote selenium
|
# profile are only working on remote selenium
|
||||||
if ENV['REMOTE_URL']
|
if ENV['REMOTE_URL']
|
||||||
|
@ -89,10 +90,11 @@ class TestCase < ActiveSupport::TestCase
|
||||||
profile: profile,
|
profile: profile,
|
||||||
}
|
}
|
||||||
if ENV['BROWSER_HEADLESS'].present?
|
if ENV['BROWSER_HEADLESS'].present?
|
||||||
if browser == 'firefox'
|
case browser
|
||||||
|
when 'firefox'
|
||||||
params[:options] = Selenium::WebDriver::Firefox::Options.new
|
params[:options] = Selenium::WebDriver::Firefox::Options.new
|
||||||
params[:options].add_argument('-headless')
|
params[:options].add_argument('-headless')
|
||||||
elsif browser == 'chrome'
|
when 'chrome'
|
||||||
params[:options] = Selenium::WebDriver::Chrome::Options.new
|
params[:options] = Selenium::WebDriver::Chrome::Options.new
|
||||||
params[:options].add_argument('-headless')
|
params[:options].add_argument('-headless')
|
||||||
end
|
end
|
||||||
|
@ -3084,17 +3086,18 @@ wait untill text in selector disabppears
|
||||||
end
|
end
|
||||||
|
|
||||||
if data[:role]
|
if data[:role]
|
||||||
if data[:role] == 'Admin'
|
case data[:role]
|
||||||
|
when 'Admin'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=1]',
|
css: '.modal input[name=role_ids][value=1]',
|
||||||
)
|
)
|
||||||
elsif data[:role] == 'Customer'
|
when 'Customer'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=3]',
|
css: '.modal input[name=role_ids][value=3]',
|
||||||
)
|
)
|
||||||
elsif data[:role] == 'Agent'
|
when 'Agent'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=2]',
|
css: '.modal input[name=role_ids][value=2]',
|
||||||
|
@ -3251,17 +3254,18 @@ wait untill text in selector disabppears
|
||||||
end
|
end
|
||||||
|
|
||||||
if data[:role]
|
if data[:role]
|
||||||
if data[:role] == 'Admin'
|
case data[:role]
|
||||||
|
when 'Admin'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=1]',
|
css: '.modal input[name=role_ids][value=1]',
|
||||||
)
|
)
|
||||||
elsif data[:role] == 'Customer'
|
when 'Customer'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=3]',
|
css: '.modal input[name=role_ids][value=3]',
|
||||||
)
|
)
|
||||||
elsif data[:role] == 'Agent'
|
when 'Agent'
|
||||||
check(
|
check(
|
||||||
browser: instance,
|
browser: instance,
|
||||||
css: '.modal input[name=role_ids][value=2]',
|
css: '.modal input[name=role_ids][value=2]',
|
||||||
|
@ -4718,7 +4722,8 @@ wait untill text in selector disabppears
|
||||||
|
|
||||||
if data[:data_option]
|
if data[:data_option]
|
||||||
if data[:data_option][:options]
|
if data[:data_option][:options]
|
||||||
if data[:data_type] == 'Boolean'
|
case data[:data_type]
|
||||||
|
when 'Boolean'
|
||||||
# rubocop:disable Lint/BooleanSymbol
|
# rubocop:disable Lint/BooleanSymbol
|
||||||
element = instance.find_elements(css: '.modal .js-valueTrue').first
|
element = instance.find_elements(css: '.modal .js-valueTrue').first
|
||||||
element.clear
|
element.clear
|
||||||
|
@ -4727,7 +4732,7 @@ wait untill text in selector disabppears
|
||||||
element.clear
|
element.clear
|
||||||
element.send_keys(data[:data_option][:options][:false])
|
element.send_keys(data[:data_option][:options][:false])
|
||||||
# rubocop:enable Lint/BooleanSymbol
|
# rubocop:enable Lint/BooleanSymbol
|
||||||
elsif data[:data_type] == 'Tree Select'
|
when 'Tree Select'
|
||||||
add_tree_options(
|
add_tree_options(
|
||||||
instance: instance,
|
instance: instance,
|
||||||
options: data[:data_option][:options],
|
options: data[:data_option][:options],
|
||||||
|
|
|
@ -302,7 +302,8 @@ class PackageTest < ActiveSupport::TestCase
|
||||||
|
|
||||||
]
|
]
|
||||||
tests.each do |test|
|
tests.each do |test|
|
||||||
if test[:action] == 'install'
|
case test[:action]
|
||||||
|
when 'install'
|
||||||
begin
|
begin
|
||||||
package = Package.install(string: test[:zpm])
|
package = Package.install(string: test[:zpm])
|
||||||
rescue => e
|
rescue => e
|
||||||
|
@ -315,7 +316,7 @@ class PackageTest < ActiveSupport::TestCase
|
||||||
else
|
else
|
||||||
assert_not(package, 'install package successful but should not')
|
assert_not(package, 'install package successful but should not')
|
||||||
end
|
end
|
||||||
elsif test[:action] == 'reinstall'
|
when 'reinstall'
|
||||||
begin
|
begin
|
||||||
package = Package.reinstall(test[:name])
|
package = Package.reinstall(test[:name])
|
||||||
rescue
|
rescue
|
||||||
|
@ -328,7 +329,7 @@ class PackageTest < ActiveSupport::TestCase
|
||||||
else
|
else
|
||||||
assert_not(package, 'reinstall package successful but should not')
|
assert_not(package, 'reinstall package successful but should not')
|
||||||
end
|
end
|
||||||
elsif test[:action] == 'uninstall'
|
when 'uninstall'
|
||||||
if test[:zpm]
|
if test[:zpm]
|
||||||
begin
|
begin
|
||||||
package = Package.uninstall(string: test[:zpm])
|
package = Package.uninstall(string: test[:zpm])
|
||||||
|
@ -347,7 +348,7 @@ class PackageTest < ActiveSupport::TestCase
|
||||||
else
|
else
|
||||||
assert_not(package, 'uninstall package successful but should not')
|
assert_not(package, 'uninstall package successful but should not')
|
||||||
end
|
end
|
||||||
elsif test[:action] == 'auto_install'
|
when 'auto_install'
|
||||||
if test[:zpm]
|
if test[:zpm]
|
||||||
if !File.exist?(Rails.root.to_s + '/auto_install/')
|
if !File.exist?(Rails.root.to_s + '/auto_install/')
|
||||||
Dir.mkdir(Rails.root.to_s + '/auto_install/', 0o755)
|
Dir.mkdir(Rails.root.to_s + '/auto_install/', 0o755)
|
||||||
|
|
|
@ -89,12 +89,13 @@ class EmailBuildTest < ActiveSupport::TestCase
|
||||||
|
|
||||||
# check attachments
|
# check attachments
|
||||||
data[:attachments]&.each do |attachment|
|
data[:attachments]&.each do |attachment|
|
||||||
if attachment[:filename] == 'message.html'
|
case attachment[:filename]
|
||||||
|
when 'message.html'
|
||||||
assert_nil(attachment[:preferences]['Content-ID'])
|
assert_nil(attachment[:preferences]['Content-ID'])
|
||||||
assert_equal(true, attachment[:preferences]['content-alternative'])
|
assert_equal(true, attachment[:preferences]['content-alternative'])
|
||||||
assert_equal('text/html', attachment[:preferences]['Mime-Type'])
|
assert_equal('text/html', attachment[:preferences]['Mime-Type'])
|
||||||
assert_equal('UTF-8', attachment[:preferences]['Charset'])
|
assert_equal('UTF-8', attachment[:preferences]['Charset'])
|
||||||
elsif attachment[:filename] == 'somename.png'
|
when 'somename.png'
|
||||||
assert_nil(attachment[:preferences]['Content-ID'])
|
assert_nil(attachment[:preferences]['Content-ID'])
|
||||||
assert_nil(attachment[:preferences]['content-alternative'])
|
assert_nil(attachment[:preferences]['content-alternative'])
|
||||||
assert_equal('image/png', attachment[:preferences]['Mime-Type'])
|
assert_equal('image/png', attachment[:preferences]['Mime-Type'])
|
||||||
|
|
Loading…
Reference in a new issue