avo 0.5.0.beta8 → 0.5.0.beta13
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of avo might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Gemfile +46 -50
- data/Gemfile.lock +3 -8
- data/Rakefile +14 -14
- data/app/components/avo/common/multiple_file_viewer_component.rb +1 -1
- data/app/components/avo/common/single_file_viewer_component.rb +1 -1
- data/app/components/avo/edit/field_wrapper_component.rb +3 -3
- data/app/components/avo/edit/fields/trix_field_component.html.erb +1 -1
- data/app/components/avo/index/field_wrapper_component.rb +1 -1
- data/app/components/avo/index/grid_item_component.rb +10 -9
- data/app/components/avo/index/resource_controls_component.rb +2 -2
- data/app/components/avo/panel_component.rb +7 -6
- data/app/components/avo/resource_component.rb +4 -3
- data/app/components/avo/show/field_wrapper_component.rb +3 -3
- data/app/components/avo/views/resource_edit_component.rb +4 -3
- data/app/components/avo/views/resource_index_component.rb +8 -7
- data/app/components/avo/views/resource_new_component.rb +4 -3
- data/app/components/avo/views/resource_show_component.rb +21 -21
- data/app/controllers/avo/actions_controller.rb +30 -29
- data/app/controllers/avo/application_controller.rb +113 -126
- data/app/controllers/avo/attachments_controller.rb +3 -3
- data/app/controllers/avo/base_controller.rb +81 -80
- data/app/controllers/avo/home_controller.rb +2 -2
- data/app/controllers/avo/relations_controller.rb +29 -28
- data/app/controllers/avo/resources_controller.rb +1 -1
- data/app/controllers/avo/search_controller.rb +20 -19
- data/app/helpers/avo/application_helper.rb +48 -42
- data/app/helpers/avo/resources_helper.rb +11 -11
- data/app/mailers/avo/application_mailer.rb +2 -2
- data/app/packs/entrypoints/application.js +9 -4
- data/app/packs/images/logo.png +0 -0
- data/app/packs/js/controllers/fields/code_field_controller.js +14 -14
- data/app/packs/js/controllers/filter_controller.js +9 -8
- data/app/packs/js/toastr.js +1 -0
- data/app/packs/stylesheets/components/code.css +0 -16
- data/avo.gemspec +30 -31
- data/bin/webpack +1 -0
- data/config/initializers/pagy.rb +1 -1
- data/config/routes.rb +12 -12
- data/config/spring.rb +5 -5
- data/config/webpack/base.js +3 -3
- data/config/webpacker.yml +32 -0
- data/db/factories.rb +3 -5
- data/lib/avo.rb +6 -6
- data/lib/avo/app.rb +18 -18
- data/lib/avo/base_action.rb +20 -20
- data/lib/avo/base_resource.rb +41 -45
- data/lib/avo/configuration.rb +16 -18
- data/lib/avo/engine.rb +18 -18
- data/lib/avo/fields/badge_field.rb +2 -2
- data/lib/avo/fields/base_field.rb +25 -26
- data/lib/avo/fields/belongs_to_field.rb +13 -12
- data/lib/avo/fields/boolean_field.rb +4 -4
- data/lib/avo/fields/boolean_group_field.rb +3 -3
- data/lib/avo/fields/code_field.rb +4 -4
- data/lib/avo/fields/country_field.rb +2 -2
- data/lib/avo/fields/currency_field.rb +3 -3
- data/lib/avo/fields/date_field.rb +3 -3
- data/lib/avo/fields/date_time_field.rb +2 -2
- data/lib/avo/fields/external_image_field.rb +2 -2
- data/lib/avo/fields/field_extensions/has_field_name.rb +2 -2
- data/lib/avo/fields/field_extensions/visible_in_different_views.rb +34 -33
- data/lib/avo/fields/file_field.rb +1 -1
- data/lib/avo/fields/files_field.rb +2 -2
- data/lib/avo/fields/gravatar_field.rb +9 -9
- data/lib/avo/fields/has_and_belongs_to_many_field.rb +1 -1
- data/lib/avo/fields/has_many_field.rb +1 -1
- data/lib/avo/fields/has_one_field.rb +2 -2
- data/lib/avo/fields/heading_field.rb +2 -2
- data/lib/avo/fields/hidden_field.rb +1 -1
- data/lib/avo/fields/id_field.rb +3 -3
- data/lib/avo/fields/key_value_field.rb +12 -12
- data/lib/avo/fields/markdown_field.rb +2 -2
- data/lib/avo/fields/number_field.rb +3 -3
- data/lib/avo/fields/password_field.rb +1 -1
- data/lib/avo/fields/select_field.rb +8 -12
- data/lib/avo/fields/status_field.rb +4 -4
- data/lib/avo/fields/text_field.rb +2 -2
- data/lib/avo/fields/textarea_field.rb +2 -2
- data/lib/avo/fields/trix_field.rb +1 -1
- data/lib/avo/fields_collector.rb +4 -5
- data/lib/avo/filters/base_filter.rb +6 -6
- data/lib/avo/filters/boolean_filter.rb +1 -1
- data/lib/avo/filters/select_filter.rb +1 -1
- data/lib/avo/licensing/h_q.rb +56 -55
- data/lib/avo/licensing/license.rb +5 -5
- data/lib/avo/licensing/license_manager.rb +4 -4
- data/lib/avo/licensing/null_license.rb +2 -2
- data/lib/avo/licensing/pro_license.rb +1 -1
- data/lib/avo/loaders/fields_loader.rb +4 -4
- data/lib/avo/services/authorization_service.rb +2 -2
- data/lib/avo/services/panel_service.rb +4 -4
- data/lib/avo/version.rb +1 -1
- data/lib/generators/avo/action_generator.rb +4 -4
- data/lib/generators/avo/controller_generator.rb +4 -4
- data/lib/generators/avo/filter_generator.rb +5 -5
- data/lib/generators/avo/install_generator.rb +8 -8
- data/lib/generators/avo/locales_generator.rb +5 -5
- data/lib/generators/avo/partials_generator.rb +4 -4
- data/lib/generators/avo/resource_generator.rb +5 -5
- data/lib/generators/avo/templates/action.tt +0 -4
- data/lib/generators/avo/templates/resource/resource.tt +3 -13
- data/lib/tasks/avo_tasks.rake +0 -60
- data/public/avo-packs/css/{application-5bb09ba4.css → application-9d115b7e.css} +124 -276
- data/public/avo-packs/css/application-9d115b7e.css.br +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.gz +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.map +1 -0
- data/public/avo-packs/css/application-9d115b7e.css.map.br +0 -0
- data/public/avo-packs/css/application-9d115b7e.css.map.gz +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js +26 -0
- data/public/avo-packs/js/{application-86a3ea5a835b0c758203.js.LICENSE.txt → application-4751feac1bb0404b9c47.js.LICENSE.txt} +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.br +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.gz +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map +1 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map.br +0 -0
- data/public/avo-packs/js/application-4751feac1bb0404b9c47.js.map.gz +0 -0
- data/public/avo-packs/manifest.json +16 -16
- data/public/avo-packs/media/images/dadf2db36589607d107d.png +0 -0
- metadata +16 -31
- data/config/initializers/inline_svg.rb +0 -33
- data/public/avo-packs/css/application-5bb09ba4.css.br +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.gz +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.map +0 -1
- data/public/avo-packs/css/application-5bb09ba4.css.map.br +0 -0
- data/public/avo-packs/css/application-5bb09ba4.css.map.gz +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js +0 -26
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.br +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.gz +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map +0 -1
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map.br +0 -0
- data/public/avo-packs/js/application-86a3ea5a835b0c758203.js.map.gz +0 -0
- data/public/avo-packs/media/images/f1b4befac91a3336db9a.png +0 -0
@@ -5,7 +5,7 @@ module Avo
|
|
5
5
|
|
6
6
|
def initialize(name, **args, &block)
|
7
7
|
@defaults = {
|
8
|
-
partial_name:
|
8
|
+
partial_name: "files-field"
|
9
9
|
}.merge(@defaults || {})
|
10
10
|
|
11
11
|
super(name, **args, &block)
|
@@ -16,7 +16,7 @@ module Avo
|
|
16
16
|
end
|
17
17
|
|
18
18
|
def to_permitted_param
|
19
|
-
{
|
19
|
+
{"#{id}": []}
|
20
20
|
end
|
21
21
|
|
22
22
|
def fill_field(model, key, value)
|
@@ -1,5 +1,5 @@
|
|
1
|
-
require
|
2
|
-
require
|
1
|
+
require "digest"
|
2
|
+
require "erb"
|
3
3
|
|
4
4
|
module Avo
|
5
5
|
module Fields
|
@@ -10,9 +10,9 @@ module Avo
|
|
10
10
|
|
11
11
|
def initialize(name, **args, &block)
|
12
12
|
@defaults = {
|
13
|
-
partial_name:
|
14
|
-
name:
|
15
|
-
id: args[:id].present? ? args[:id] :
|
13
|
+
partial_name: "gravatar-field",
|
14
|
+
name: "Avatar",
|
15
|
+
id: args[:id].present? ? args[:id] : "email"
|
16
16
|
}
|
17
17
|
|
18
18
|
super(name, **args, &block)
|
@@ -21,7 +21,7 @@ module Avo
|
|
21
21
|
|
22
22
|
@rounded = args[:rounded].present? ? args[:rounded] : true
|
23
23
|
@size = args[:size].present? ? args[:size].to_i : 40
|
24
|
-
@default = args[:default].present? ? ERB::Util.url_encode(args[:default]).to_s :
|
24
|
+
@default = args[:default].present? ? ERB::Util.url_encode(args[:default]).to_s : ""
|
25
25
|
@link_to_resource = args[:link_to_resource].present? ? args[:link_to_resource] : false
|
26
26
|
end
|
27
27
|
|
@@ -33,11 +33,11 @@ module Avo
|
|
33
33
|
|
34
34
|
def to_image
|
35
35
|
options = {
|
36
|
-
default:
|
37
|
-
size: 340
|
36
|
+
default: "",
|
37
|
+
size: 340
|
38
38
|
}
|
39
39
|
|
40
|
-
query = options.map { |key, value| "#{key}=#{value}" }.join(
|
40
|
+
query = options.map { |key, value| "#{key}=#{value}" }.join("&")
|
41
41
|
|
42
42
|
URI::HTTPS.build(host: "www.gravatar.com", path: "/avatar/#{md5}", query: query).to_s
|
43
43
|
end
|
@@ -7,14 +7,14 @@ module Avo
|
|
7
7
|
def initialize(name, **args, &block)
|
8
8
|
@defaults = {
|
9
9
|
updatable: true,
|
10
|
-
partial_name:
|
10
|
+
partial_name: "has-one-field"
|
11
11
|
}
|
12
12
|
|
13
13
|
super(name, **args, &block)
|
14
14
|
|
15
15
|
hide_on :new, :edit
|
16
16
|
|
17
|
-
@placeholder = I18n.t
|
17
|
+
@placeholder = I18n.t "avo.choose_an_option"
|
18
18
|
|
19
19
|
@relation_method = name.to_s.parameterize.underscore
|
20
20
|
@display = args[:display].present? ? args[:display] : :show
|
@@ -4,8 +4,8 @@ module Avo
|
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
6
|
updatable: false,
|
7
|
-
partial_name:
|
8
|
-
id:
|
7
|
+
partial_name: "heading-field",
|
8
|
+
id: "heading_" + name.to_s.parameterize.underscore
|
9
9
|
}
|
10
10
|
|
11
11
|
super(name, **args, &block)
|
data/lib/avo/fields/id_field.rb
CHANGED
@@ -2,11 +2,11 @@ module Avo
|
|
2
2
|
module Fields
|
3
3
|
class IdField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
|
-
default_value =
|
5
|
+
default_value = "id"
|
6
6
|
|
7
7
|
if name.nil?
|
8
8
|
@name = name = default_value
|
9
|
-
elsif !name.is_a?
|
9
|
+
elsif !name.is_a?(String) && !name.is_a?(Symbol)
|
10
10
|
args_copy = name
|
11
11
|
@name = name = default_value
|
12
12
|
args = args_copy
|
@@ -16,7 +16,7 @@ module Avo
|
|
16
16
|
id: name.to_sym,
|
17
17
|
readonly: true,
|
18
18
|
sortable: true,
|
19
|
-
partial_name:
|
19
|
+
partial_name: "id-field"
|
20
20
|
}
|
21
21
|
|
22
22
|
hide_on [:edit, :new]
|
@@ -1,36 +1,36 @@
|
|
1
|
-
require
|
1
|
+
require "json"
|
2
2
|
|
3
3
|
module Avo
|
4
4
|
module Fields
|
5
5
|
class KeyValueField < BaseField
|
6
6
|
def initialize(name, **args, &block)
|
7
7
|
@defaults = {
|
8
|
-
partial_name:
|
8
|
+
partial_name: "key-value-field"
|
9
9
|
}
|
10
10
|
|
11
11
|
super(name, **args, &block)
|
12
12
|
|
13
13
|
hide_on :index
|
14
14
|
|
15
|
-
@key_label = args[:key_label].present? ? args[:key_label].to_s :
|
16
|
-
@value_label = args[:value_label].present? ? args[:value_label].to_s :
|
17
|
-
@action_text = args[:action_text].present? ? args[:action_text].to_s :
|
18
|
-
@delete_text = args[:delete_text].present? ? args[:delete_text].to_s :
|
15
|
+
@key_label = args[:key_label].present? ? args[:key_label].to_s : "Key"
|
16
|
+
@value_label = args[:value_label].present? ? args[:value_label].to_s : "Value"
|
17
|
+
@action_text = args[:action_text].present? ? args[:action_text].to_s : "Add row"
|
18
|
+
@delete_text = args[:delete_text].present? ? args[:delete_text].to_s : "Delete row"
|
19
19
|
|
20
20
|
@disable_editing_keys = args[:disable_editing_keys].present? ? args[:disable_editing_keys] : false
|
21
21
|
# disabling editing keys also disables adding rows (doesn't take into account the value of disable_adding_rows)
|
22
|
-
if args[:disable_editing_keys].present? && args[:disable_editing_keys] == true
|
23
|
-
|
22
|
+
@disable_adding_rows = if args[:disable_editing_keys].present? && args[:disable_editing_keys] == true
|
23
|
+
true
|
24
24
|
elsif args[:disable_adding_rows].present?
|
25
|
-
|
25
|
+
args[:disable_adding_rows]
|
26
26
|
else
|
27
|
-
|
27
|
+
false
|
28
28
|
end
|
29
29
|
@disable_deleting_rows = args[:disable_deleting_rows].present? ? args[:disable_deleting_rows] : false
|
30
30
|
end
|
31
31
|
|
32
32
|
def to_permitted_param
|
33
|
-
[:"#{id}", "#{id}": {}
|
33
|
+
[:"#{id}", "#{id}": {}]
|
34
34
|
end
|
35
35
|
|
36
36
|
def hydrate_field(fields, model, resource, view)
|
@@ -41,7 +41,7 @@ module Avo
|
|
41
41
|
delete_text: @delete_text,
|
42
42
|
disable_editing_keys: @disable_editing_keys,
|
43
43
|
disable_adding_rows: @disable_adding_rows,
|
44
|
-
disable_deleting_rows: @disable_deleting_rows
|
44
|
+
disable_deleting_rows: @disable_deleting_rows
|
45
45
|
}
|
46
46
|
end
|
47
47
|
end
|
@@ -3,7 +3,7 @@ module Avo
|
|
3
3
|
class MarkdownField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
6
|
+
partial_name: "markdown-field"
|
7
7
|
}
|
8
8
|
|
9
9
|
super(name, **args, &block)
|
@@ -11,7 +11,7 @@ module Avo
|
|
11
11
|
hide_on :index
|
12
12
|
|
13
13
|
@always_show = args[:always_show].present? ? args[:always_show] : false
|
14
|
-
@height = args[:height].present? ? args[:height].to_s :
|
14
|
+
@height = args[:height].present? ? args[:height].to_s : "auto"
|
15
15
|
end
|
16
16
|
|
17
17
|
def hydrate_field(fields, model, resource, view)
|
@@ -3,8 +3,8 @@ module Avo
|
|
3
3
|
class NumberField < TextField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
7
|
-
computable: true
|
6
|
+
partial_name: "number-field",
|
7
|
+
computable: true
|
8
8
|
}
|
9
9
|
|
10
10
|
super(name, **args, &block)
|
@@ -12,7 +12,7 @@ module Avo
|
|
12
12
|
@meta = {
|
13
13
|
min: args[:min].present? ? args[:min].to_f : nil,
|
14
14
|
max: args[:max].present? ? args[:max].to_f : nil,
|
15
|
-
step: args[:step].present? ? args[:step].to_f : nil
|
15
|
+
step: args[:step].present? ? args[:step].to_f : nil
|
16
16
|
}
|
17
17
|
end
|
18
18
|
end
|
@@ -7,7 +7,7 @@ module Avo
|
|
7
7
|
|
8
8
|
def initialize(name, **args, &block)
|
9
9
|
@defaults = {
|
10
|
-
partial_name:
|
10
|
+
partial_name: "select-field"
|
11
11
|
}
|
12
12
|
|
13
13
|
super(name, **args, &block)
|
@@ -16,7 +16,7 @@ module Avo
|
|
16
16
|
@options = ActiveSupport::HashWithIndifferentAccess.new @options
|
17
17
|
@enum = args[:enum].present? ? args[:enum] : nil
|
18
18
|
@display_value = args[:display_value].present? ? args[:display_value] : false
|
19
|
-
@placeholder = args[:placeholder].present? ? args[:placeholder].to_s : I18n.t(
|
19
|
+
@placeholder = args[:placeholder].present? ? args[:placeholder].to_s : I18n.t("avo.choose_an_option")
|
20
20
|
end
|
21
21
|
|
22
22
|
def options_for_select
|
@@ -26,24 +26,20 @@ module Avo
|
|
26
26
|
else
|
27
27
|
options.map { |label, value| [label, label] }.to_h
|
28
28
|
end
|
29
|
+
elsif display_value
|
30
|
+
options.map { |label, value| [value, value] }.to_h
|
29
31
|
else
|
30
|
-
|
31
|
-
options.map { |label, value| [value, value] }.to_h
|
32
|
-
else
|
33
|
-
options
|
34
|
-
end
|
32
|
+
options
|
35
33
|
end
|
36
34
|
end
|
37
35
|
|
38
36
|
def label
|
39
37
|
if display_value
|
40
38
|
value
|
39
|
+
elsif enum.present?
|
40
|
+
options[value]
|
41
41
|
else
|
42
|
-
|
43
|
-
options[value]
|
44
|
-
else
|
45
|
-
options.invert[value]
|
46
|
-
end
|
42
|
+
options.invert[value]
|
47
43
|
end
|
48
44
|
end
|
49
45
|
end
|
@@ -3,7 +3,7 @@ module Avo
|
|
3
3
|
class StatusField < BaseField
|
4
4
|
def initialize(name, **args, &block)
|
5
5
|
@defaults = {
|
6
|
-
partial_name:
|
6
|
+
partial_name: "status-field"
|
7
7
|
}
|
8
8
|
|
9
9
|
super(name, **args, &block)
|
@@ -13,10 +13,10 @@ module Avo
|
|
13
13
|
end
|
14
14
|
|
15
15
|
def status
|
16
|
-
status =
|
16
|
+
status = "success"
|
17
17
|
if value.present?
|
18
|
-
status =
|
19
|
-
status =
|
18
|
+
status = "failed" if @failed_when.include? value.to_sym
|
19
|
+
status = "loading" if @loading_when.include? value.to_sym
|
20
20
|
end
|
21
21
|
|
22
22
|
status
|
data/lib/avo/fields_collector.rb
CHANGED
@@ -11,16 +11,15 @@ module Avo
|
|
11
11
|
field[:name].to_s == as.to_s
|
12
12
|
end
|
13
13
|
|
14
|
-
if matched_field.present?
|
14
|
+
if matched_field.present? && matched_field[:class].present?
|
15
15
|
klass = matched_field[:class]
|
16
16
|
|
17
|
-
if
|
18
|
-
|
17
|
+
if block
|
18
|
+
klass.new(field_name, **args || {}, &block)
|
19
19
|
else
|
20
|
-
|
20
|
+
klass.new(field_name, **args || {})
|
21
21
|
end
|
22
22
|
|
23
|
-
field
|
24
23
|
end
|
25
24
|
end
|
26
25
|
|
@@ -1,19 +1,19 @@
|
|
1
1
|
module Avo
|
2
2
|
module Filters
|
3
3
|
class BaseFilter
|
4
|
-
class_attribute :name, default:
|
5
|
-
class_attribute :component, default:
|
6
|
-
class_attribute :default, default:
|
7
|
-
class_attribute :template, default:
|
4
|
+
class_attribute :name, default: "Filter"
|
5
|
+
class_attribute :component, default: "boolean-filter"
|
6
|
+
class_attribute :default, default: ""
|
7
|
+
class_attribute :template, default: "avo/base/select_filter"
|
8
8
|
|
9
9
|
def apply_query(request, query, value)
|
10
10
|
value.symbolize_keys! if value.is_a? Hash
|
11
11
|
|
12
|
-
|
12
|
+
apply(request, query, value)
|
13
13
|
end
|
14
14
|
|
15
15
|
def id
|
16
|
-
self.class.name.underscore.
|
16
|
+
self.class.name.underscore.tr("/", "_")
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
data/lib/avo/licensing/h_q.rb
CHANGED
@@ -3,8 +3,8 @@ module Avo
|
|
3
3
|
class HQ
|
4
4
|
attr_accessor :current_request
|
5
5
|
|
6
|
-
ENDPOINT =
|
7
|
-
CACHE_KEY =
|
6
|
+
ENDPOINT = "https://avohq.io/api/v1/licenses/check" unless const_defined?(:ENDPOINT)
|
7
|
+
CACHE_KEY = "avo.hq.response" unless const_defined?(:CACHE_KEY)
|
8
8
|
REQUEST_TIMEOUT = 5 unless const_defined?(:REQUEST_TIMEOUT) # seconds
|
9
9
|
|
10
10
|
def initialize(current_request)
|
@@ -13,76 +13,77 @@ module Avo
|
|
13
13
|
end
|
14
14
|
|
15
15
|
def response
|
16
|
-
@hq_response
|
16
|
+
@hq_response || request
|
17
17
|
end
|
18
18
|
|
19
19
|
private
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
20
|
+
|
21
|
+
def request
|
22
|
+
return cached_response if has_cached_response
|
23
|
+
|
24
|
+
begin
|
25
|
+
perform_and_cache_request
|
26
|
+
rescue HTTParty::Error => exception
|
27
|
+
cache_and_return_error "HTTP client error.", exception.message
|
28
|
+
rescue Net::OpenTimeout => exception
|
29
|
+
cache_and_return_error "Request timeout.", exception.message
|
30
|
+
rescue SocketError => exception
|
31
|
+
cache_and_return_error "Connection error.", exception.message
|
32
32
|
end
|
33
|
+
end
|
33
34
|
|
34
|
-
|
35
|
-
|
35
|
+
def perform_and_cache_request
|
36
|
+
hq_response = perform_request
|
36
37
|
|
37
|
-
|
38
|
+
return cache_and_return_error "Avo HQ Internal server error.", hq_response.body if hq_response.code == 500
|
38
39
|
|
39
|
-
|
40
|
-
|
40
|
+
cache_response 1.hour.to_i, hq_response.parsed_response if hq_response.code == 200
|
41
|
+
end
|
41
42
|
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
43
|
+
def cache_response(time, response)
|
44
|
+
response.merge!(
|
45
|
+
expiry: time,
|
46
|
+
**payload
|
47
|
+
).stringify_keys!
|
47
48
|
|
48
|
-
|
49
|
+
@cache_store.write(CACHE_KEY, response, expires_in: time)
|
49
50
|
|
50
|
-
|
51
|
+
@hq_response = response
|
51
52
|
|
52
|
-
|
53
|
-
|
53
|
+
response
|
54
|
+
end
|
54
55
|
|
55
|
-
|
56
|
-
|
56
|
+
def perform_request
|
57
|
+
puts "Performing request to avohq.io API to check license availability.".inspect if Rails.env.development?
|
57
58
|
|
58
|
-
|
59
|
-
|
59
|
+
HTTParty.post ENDPOINT, body: payload.to_json, headers: {'Content-type': "application/json"}, timeout: REQUEST_TIMEOUT
|
60
|
+
end
|
60
61
|
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
62
|
+
def payload
|
63
|
+
{
|
64
|
+
license: Avo.configuration.license,
|
65
|
+
license_key: Avo.configuration.license_key,
|
66
|
+
avo_version: Avo::VERSION,
|
67
|
+
rails_version: Rails::VERSION::STRING,
|
68
|
+
ruby_version: RUBY_VERSION,
|
69
|
+
environment: Rails.env,
|
70
|
+
ip: current_request.ip,
|
71
|
+
host: current_request.host,
|
72
|
+
port: current_request.port
|
73
|
+
}
|
74
|
+
end
|
74
75
|
|
75
|
-
|
76
|
-
|
77
|
-
|
76
|
+
def cache_and_return_error(error, exception_message = "")
|
77
|
+
cache_response 5.minutes.to_i, {error: error, exception_message: exception_message}.stringify_keys
|
78
|
+
end
|
78
79
|
|
79
|
-
|
80
|
-
|
81
|
-
|
80
|
+
def has_cached_response
|
81
|
+
@cache_store.exist? CACHE_KEY
|
82
|
+
end
|
82
83
|
|
83
|
-
|
84
|
-
|
85
|
-
|
84
|
+
def cached_response
|
85
|
+
@cache_store.read CACHE_KEY
|
86
|
+
end
|
86
87
|
end
|
87
88
|
end
|
88
89
|
end
|