platformos-check 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.dockerignore +2 -0
- data/.gitignore +22 -0
- data/.rubocop.yml +555 -0
- data/CHANGELOG.md +5 -0
- data/CODE_OF_CONDUCT.md +74 -0
- data/CONTRIBUTING.md +209 -0
- data/Gemfile +33 -0
- data/Guardfile +7 -0
- data/LICENSE.md +10 -0
- data/Makefile +18 -0
- data/README.md +189 -0
- data/RELEASING.md +35 -0
- data/Rakefile +83 -0
- data/TROUBLESHOOTING.md +35 -0
- data/bin/platformos-check +29 -0
- data/bin/platformos-check-language-server +29 -0
- data/config/default.yml +98 -0
- data/config/nothing.yml +11 -0
- data/data/platformos_liquid/built_in_liquid_objects.json +66 -0
- data/data/platformos_liquid/deprecated_filters.json +22 -0
- data/data/platformos_liquid/documentation/filters.json +6 -0
- data/data/platformos_liquid/documentation/latest.json +2 -0
- data/data/platformos_liquid/documentation/objects.json +6 -0
- data/data/platformos_liquid/documentation/tags.json +6 -0
- data/docker/check.Dockerfile +3 -0
- data/docker/lsp.Dockerfile +21 -0
- data/docs/api/check.md +15 -0
- data/docs/api/html_check.md +46 -0
- data/docs/api/liquid_check.md +115 -0
- data/docs/api/yaml_check.md +19 -0
- data/docs/checks/TEMPLATE.md.erb +52 -0
- data/docs/checks/convert_include_to_render.md +48 -0
- data/docs/checks/deprecated_filter.md +30 -0
- data/docs/checks/html_parsing_error.md +50 -0
- data/docs/checks/img_lazy_loading.md +63 -0
- data/docs/checks/img_width_and_height.md +79 -0
- data/docs/checks/invalid_args.md +56 -0
- data/docs/checks/liquid_tag.md +65 -0
- data/docs/checks/missing_enable_comment.md +50 -0
- data/docs/checks/missing_template.md +65 -0
- data/docs/checks/parse_json_format.md +76 -0
- data/docs/checks/parser_blocking_javascript.md +97 -0
- data/docs/checks/required_layout_object.md +28 -0
- data/docs/checks/space_inside_braces.md +89 -0
- data/docs/checks/syntax_error.md +49 -0
- data/docs/checks/template_length.md +45 -0
- data/docs/checks/undefined_object.md +71 -0
- data/docs/checks/unknown_filter.md +46 -0
- data/docs/checks/unused_assign.md +63 -0
- data/docs/checks/unused_partial.md +32 -0
- data/docs/checks/valid_yaml.md +48 -0
- data/docs/flamegraph.svg +18488 -0
- data/docs/language_server/code-action-command-palette.png +0 -0
- data/docs/language_server/code-action-flow.png +0 -0
- data/docs/language_server/code-action-keyboard.png +0 -0
- data/docs/language_server/code-action-light-bulb.png +0 -0
- data/docs/language_server/code-action-problem.png +0 -0
- data/docs/language_server/code-action-quickfix.png +0 -0
- data/docs/language_server/how_to_correct_code_with_code_actions_and_execute_command.md +197 -0
- data/docs/preview.png +0 -0
- data/exe/platformos-check +6 -0
- data/exe/platformos-check-language-server +7 -0
- data/lib/platformos_check/analyzer.rb +178 -0
- data/lib/platformos_check/api_call_file.rb +9 -0
- data/lib/platformos_check/app.rb +138 -0
- data/lib/platformos_check/app_file.rb +89 -0
- data/lib/platformos_check/app_file_rewriter.rb +79 -0
- data/lib/platformos_check/asset_file.rb +34 -0
- data/lib/platformos_check/bug.rb +23 -0
- data/lib/platformos_check/check.rb +163 -0
- data/lib/platformos_check/checks/TEMPLATE.rb.erb +11 -0
- data/lib/platformos_check/checks/convert_include_to_render.rb +17 -0
- data/lib/platformos_check/checks/deprecated_filter.rb +123 -0
- data/lib/platformos_check/checks/html_parsing_error.rb +13 -0
- data/lib/platformos_check/checks/img_lazy_loading.rb +18 -0
- data/lib/platformos_check/checks/img_width_and_height.rb +46 -0
- data/lib/platformos_check/checks/invalid_args.rb +81 -0
- data/lib/platformos_check/checks/liquid_tag.rb +47 -0
- data/lib/platformos_check/checks/missing_enable_comment.rb +37 -0
- data/lib/platformos_check/checks/missing_template.rb +107 -0
- data/lib/platformos_check/checks/parse_json_format.rb +31 -0
- data/lib/platformos_check/checks/parser_blocking_javascript.rb +17 -0
- data/lib/platformos_check/checks/required_layout_object.rb +41 -0
- data/lib/platformos_check/checks/space_inside_braces.rb +150 -0
- data/lib/platformos_check/checks/syntax_error.rb +31 -0
- data/lib/platformos_check/checks/template_length.rb +20 -0
- data/lib/platformos_check/checks/undefined_object.rb +206 -0
- data/lib/platformos_check/checks/unknown_filter.rb +27 -0
- data/lib/platformos_check/checks/unused_assign.rb +101 -0
- data/lib/platformos_check/checks/unused_partial.rb +93 -0
- data/lib/platformos_check/checks/valid_yaml.rb +16 -0
- data/lib/platformos_check/checks.rb +73 -0
- data/lib/platformos_check/checks_tracking.rb +9 -0
- data/lib/platformos_check/cli.rb +239 -0
- data/lib/platformos_check/config.rb +219 -0
- data/lib/platformos_check/config_file.rb +6 -0
- data/lib/platformos_check/corrector.rb +68 -0
- data/lib/platformos_check/disabled_check.rb +44 -0
- data/lib/platformos_check/disabled_checks.rb +96 -0
- data/lib/platformos_check/email_file.rb +9 -0
- data/lib/platformos_check/exceptions.rb +36 -0
- data/lib/platformos_check/file_system_storage.rb +93 -0
- data/lib/platformos_check/graphql_file.rb +68 -0
- data/lib/platformos_check/html_check.rb +8 -0
- data/lib/platformos_check/html_node.rb +210 -0
- data/lib/platformos_check/html_visitor.rb +36 -0
- data/lib/platformos_check/in_memory_storage.rb +68 -0
- data/lib/platformos_check/json_file.rb +57 -0
- data/lib/platformos_check/json_helper.rb +73 -0
- data/lib/platformos_check/json_helpers.rb +24 -0
- data/lib/platformos_check/json_printer.rb +32 -0
- data/lib/platformos_check/language_server/bridge.rb +167 -0
- data/lib/platformos_check/language_server/channel.rb +69 -0
- data/lib/platformos_check/language_server/client_capabilities.rb +27 -0
- data/lib/platformos_check/language_server/code_action_engine.rb +32 -0
- data/lib/platformos_check/language_server/code_action_provider.rb +41 -0
- data/lib/platformos_check/language_server/code_action_providers/quickfix_code_action_provider.rb +85 -0
- data/lib/platformos_check/language_server/code_action_providers/source_fix_all_code_action_provider.rb +41 -0
- data/lib/platformos_check/language_server/completion_context.rb +52 -0
- data/lib/platformos_check/language_server/completion_engine.rb +32 -0
- data/lib/platformos_check/language_server/completion_helper.rb +26 -0
- data/lib/platformos_check/language_server/completion_provider.rb +53 -0
- data/lib/platformos_check/language_server/completion_providers/assignments_completion_provider.rb +40 -0
- data/lib/platformos_check/language_server/completion_providers/filter_completion_provider.rb +102 -0
- data/lib/platformos_check/language_server/completion_providers/object_attribute_completion_provider.rb +48 -0
- data/lib/platformos_check/language_server/completion_providers/object_completion_provider.rb +38 -0
- data/lib/platformos_check/language_server/completion_providers/render_snippet_completion_provider.rb +50 -0
- data/lib/platformos_check/language_server/completion_providers/tag_completion_provider.rb +41 -0
- data/lib/platformos_check/language_server/configuration.rb +89 -0
- data/lib/platformos_check/language_server/constants.rb +29 -0
- data/lib/platformos_check/language_server/diagnostic.rb +129 -0
- data/lib/platformos_check/language_server/diagnostics_engine.rb +131 -0
- data/lib/platformos_check/language_server/diagnostics_manager.rb +184 -0
- data/lib/platformos_check/language_server/document_change_corrector.rb +271 -0
- data/lib/platformos_check/language_server/document_link_engine.rb +21 -0
- data/lib/platformos_check/language_server/document_link_provider.rb +71 -0
- data/lib/platformos_check/language_server/document_link_providers/asset_document_link_provider.rb +11 -0
- data/lib/platformos_check/language_server/document_link_providers/include_document_link_provider.rb +11 -0
- data/lib/platformos_check/language_server/document_link_providers/render_document_link_provider.rb +11 -0
- data/lib/platformos_check/language_server/document_link_providers/section_document_link_provider.rb +11 -0
- data/lib/platformos_check/language_server/execute_command_engine.rb +19 -0
- data/lib/platformos_check/language_server/execute_command_provider.rb +30 -0
- data/lib/platformos_check/language_server/execute_command_providers/correction_execute_command_provider.rb +48 -0
- data/lib/platformos_check/language_server/execute_command_providers/run_checks_execute_command_provider.rb +28 -0
- data/lib/platformos_check/language_server/handler.rb +310 -0
- data/lib/platformos_check/language_server/hover_engine.rb +32 -0
- data/lib/platformos_check/language_server/hover_provider.rb +53 -0
- data/lib/platformos_check/language_server/hover_providers/filter_hover_provider.rb +113 -0
- data/lib/platformos_check/language_server/io_messenger.rb +109 -0
- data/lib/platformos_check/language_server/messenger.rb +27 -0
- data/lib/platformos_check/language_server/protocol.rb +55 -0
- data/lib/platformos_check/language_server/server.rb +188 -0
- data/lib/platformos_check/language_server/tokens.rb +55 -0
- data/lib/platformos_check/language_server/type_helper.rb +22 -0
- data/lib/platformos_check/language_server/uri_helper.rb +39 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/assignments_finder/node_handler.rb +87 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/assignments_finder/scope.rb +60 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/assignments_finder/scope_visitor.rb +44 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/assignments_finder.rb +76 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/constants.rb +44 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/liquid_fixer.rb +103 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/potential_lookup.rb +10 -0
- data/lib/platformos_check/language_server/variable_lookup_finder/tolerant_parser.rb +94 -0
- data/lib/platformos_check/language_server/variable_lookup_finder.rb +262 -0
- data/lib/platformos_check/language_server/variable_lookup_traverser.rb +70 -0
- data/lib/platformos_check/language_server/versioned_in_memory_storage.rb +84 -0
- data/lib/platformos_check/language_server.rb +71 -0
- data/lib/platformos_check/layout_file.rb +15 -0
- data/lib/platformos_check/liquid_check.rb +10 -0
- data/lib/platformos_check/liquid_file.rb +102 -0
- data/lib/platformos_check/liquid_node.rb +570 -0
- data/lib/platformos_check/liquid_visitor.rb +39 -0
- data/lib/platformos_check/migration_file.rb +9 -0
- data/lib/platformos_check/node.rb +53 -0
- data/lib/platformos_check/offense.rb +228 -0
- data/lib/platformos_check/page_file.rb +9 -0
- data/lib/platformos_check/parsing_helpers.rb +21 -0
- data/lib/platformos_check/partial_file.rb +15 -0
- data/lib/platformos_check/platformos_liquid/deprecated_filter.rb +31 -0
- data/lib/platformos_check/platformos_liquid/documentation/markdown_template.rb +51 -0
- data/lib/platformos_check/platformos_liquid/documentation.rb +45 -0
- data/lib/platformos_check/platformos_liquid/filter.rb +19 -0
- data/lib/platformos_check/platformos_liquid/object.rb +15 -0
- data/lib/platformos_check/platformos_liquid/source_index/base_entry.rb +66 -0
- data/lib/platformos_check/platformos_liquid/source_index/base_state.rb +23 -0
- data/lib/platformos_check/platformos_liquid/source_index/filter_entry.rb +26 -0
- data/lib/platformos_check/platformos_liquid/source_index/filter_state.rb +11 -0
- data/lib/platformos_check/platformos_liquid/source_index/object_entry.rb +20 -0
- data/lib/platformos_check/platformos_liquid/source_index/object_state.rb +11 -0
- data/lib/platformos_check/platformos_liquid/source_index/parameter_entry.rb +25 -0
- data/lib/platformos_check/platformos_liquid/source_index/property_entry.rb +21 -0
- data/lib/platformos_check/platformos_liquid/source_index/return_type_entry.rb +41 -0
- data/lib/platformos_check/platformos_liquid/source_index/tag_entry.rb +24 -0
- data/lib/platformos_check/platformos_liquid/source_index/tag_state.rb +11 -0
- data/lib/platformos_check/platformos_liquid/source_index.rb +79 -0
- data/lib/platformos_check/platformos_liquid/source_manager.rb +116 -0
- data/lib/platformos_check/platformos_liquid/tag.rb +59 -0
- data/lib/platformos_check/platformos_liquid.rb +21 -0
- data/lib/platformos_check/position.rb +180 -0
- data/lib/platformos_check/position_helper.rb +57 -0
- data/lib/platformos_check/printer.rb +87 -0
- data/lib/platformos_check/regex_helpers.rb +21 -0
- data/lib/platformos_check/releaser.rb +43 -0
- data/lib/platformos_check/schema_file.rb +6 -0
- data/lib/platformos_check/sms_file.rb +9 -0
- data/lib/platformos_check/storage.rb +29 -0
- data/lib/platformos_check/string_helpers.rb +48 -0
- data/lib/platformos_check/tags/background.rb +67 -0
- data/lib/platformos_check/tags/base.rb +14 -0
- data/lib/platformos_check/tags/base_block.rb +14 -0
- data/lib/platformos_check/tags/base_tag_methods.rb +59 -0
- data/lib/platformos_check/tags/cache.rb +13 -0
- data/lib/platformos_check/tags/export.rb +30 -0
- data/lib/platformos_check/tags/form.rb +19 -0
- data/lib/platformos_check/tags/function.rb +58 -0
- data/lib/platformos_check/tags/graphql.rb +70 -0
- data/lib/platformos_check/tags/hash_assign.rb +75 -0
- data/lib/platformos_check/tags/log.rb +15 -0
- data/lib/platformos_check/tags/parse_json.rb +24 -0
- data/lib/platformos_check/tags/print.rb +20 -0
- data/lib/platformos_check/tags/redirect_to.rb +15 -0
- data/lib/platformos_check/tags/render.rb +60 -0
- data/lib/platformos_check/tags/response_headers.rb +20 -0
- data/lib/platformos_check/tags/response_status.rb +20 -0
- data/lib/platformos_check/tags/return.rb +20 -0
- data/lib/platformos_check/tags/session.rb +27 -0
- data/lib/platformos_check/tags/sign_in.rb +27 -0
- data/lib/platformos_check/tags/spam_protection.rb +15 -0
- data/lib/platformos_check/tags/theme_render.rb +58 -0
- data/lib/platformos_check/tags/try.rb +59 -0
- data/lib/platformos_check/tags.rb +65 -0
- data/lib/platformos_check/translation_file.rb +6 -0
- data/lib/platformos_check/user_schema_file.rb +6 -0
- data/lib/platformos_check/version.rb +5 -0
- data/lib/platformos_check/yaml_check.rb +11 -0
- data/lib/platformos_check/yaml_file.rb +57 -0
- data/lib/platformos_check.rb +106 -0
- data/platformos-check.gemspec +34 -0
- metadata +329 -0
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Log < Base
|
6
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
7
|
+
def children
|
8
|
+
[
|
9
|
+
@node.value_expr
|
10
|
+
].compact + @node.attributes_expr.values
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class ParseJson < Liquid::Block
|
6
|
+
SYNTAX = /(#{Liquid::VariableSignature}+)/o
|
7
|
+
|
8
|
+
attr_reader :to
|
9
|
+
|
10
|
+
def initialize(tag_name, markup, options)
|
11
|
+
super
|
12
|
+
raise Liquid::SyntaxError, "Syntax Error in 'parse_json' - Valid syntax: parse_json [var]" unless markup =~ SYNTAX
|
13
|
+
|
14
|
+
@to = Regexp.last_match(1)
|
15
|
+
end
|
16
|
+
|
17
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
18
|
+
def children
|
19
|
+
super + [@node.to]
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Print < Liquid::Tag
|
6
|
+
attr_reader :var
|
7
|
+
|
8
|
+
def initialize(tag_name, markup, options)
|
9
|
+
super
|
10
|
+
@var = Liquid::Variable.new(markup, options)
|
11
|
+
end
|
12
|
+
|
13
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
14
|
+
def children
|
15
|
+
[@node.var]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class RedirectTo < Base
|
6
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
7
|
+
def children
|
8
|
+
[
|
9
|
+
@node.value_expr
|
10
|
+
].compact + @node.attributes_expr.values
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,60 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Render < Liquid::Tag
|
6
|
+
SYNTAX = /
|
7
|
+
(
|
8
|
+
## for {% render "snippet" %}
|
9
|
+
#{Liquid::QuotedString}+ |
|
10
|
+
## for {% render block %}
|
11
|
+
## We require the variable # segment to be at the beginning of the
|
12
|
+
## string (with \A). This is to prevent code like {% render !foo! %}
|
13
|
+
## from parsing
|
14
|
+
\A#{Liquid::VariableSegment}+
|
15
|
+
)
|
16
|
+
## for {% render "snippet" with product as p %}
|
17
|
+
## or {% render "snippet" for products p %}
|
18
|
+
(\s+(with|#{Liquid::Render::FOR})\s+(#{Liquid::QuotedFragment}+))?
|
19
|
+
(\s+(?:as)\s+(#{Liquid::VariableSegment}+))?
|
20
|
+
## variables passed into the tag (e.g. {% render "snippet", var1: value1, var2: value2 %}
|
21
|
+
## are not matched by this regex and are handled by Liquid::Render.initialize
|
22
|
+
/xo
|
23
|
+
|
24
|
+
disable_tags "include"
|
25
|
+
|
26
|
+
attr_reader :template_name_expr, :variable_name_expr, :attributes, :duplicated_attrs
|
27
|
+
|
28
|
+
def initialize(tag_name, markup, options)
|
29
|
+
super
|
30
|
+
|
31
|
+
raise Liquid::SyntaxError, options[:locale].t("errors.syntax.render") unless markup =~ SYNTAX
|
32
|
+
|
33
|
+
template_name = Regexp.last_match(1)
|
34
|
+
with_or_for = Regexp.last_match(3)
|
35
|
+
variable_name = Regexp.last_match(4)
|
36
|
+
|
37
|
+
@alias_name = Regexp.last_match(6)
|
38
|
+
@variable_name_expr = variable_name ? parse_expression(variable_name) : nil
|
39
|
+
@template_name_expr = parse_expression(template_name)
|
40
|
+
@for = (with_or_for == Liquid::Render::FOR)
|
41
|
+
|
42
|
+
@attributes = {}
|
43
|
+
@duplicated_attrs = []
|
44
|
+
markup.scan(Liquid::TagAttributes) do |key, value|
|
45
|
+
@duplicated_attrs << key if @attributes.key?(key)
|
46
|
+
@attributes[key] = parse_expression(value)
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
51
|
+
def children
|
52
|
+
[
|
53
|
+
@node.template_name_expr,
|
54
|
+
@node.variable_name_expr
|
55
|
+
] + @node.attributes.values
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
60
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class ResponseHeaders < Liquid::Tag
|
6
|
+
attr_reader :var
|
7
|
+
|
8
|
+
def initialize(tag_name, markup, options)
|
9
|
+
super
|
10
|
+
@var = Liquid::Variable.new(markup, options)
|
11
|
+
end
|
12
|
+
|
13
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
14
|
+
def children
|
15
|
+
[@node.var]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class ResponseStatus < Liquid::Tag
|
6
|
+
attr_reader :var
|
7
|
+
|
8
|
+
def initialize(tag_name, markup, options)
|
9
|
+
super
|
10
|
+
@var = Liquid::Variable.new(markup, options)
|
11
|
+
end
|
12
|
+
|
13
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
14
|
+
def children
|
15
|
+
[@node.var]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Return < Liquid::Tag
|
6
|
+
attr_reader :var
|
7
|
+
|
8
|
+
def initialize(tag_name, markup, options)
|
9
|
+
super
|
10
|
+
@var = Liquid::Variable.new(markup, options)
|
11
|
+
end
|
12
|
+
|
13
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
14
|
+
def children
|
15
|
+
[@node.var]
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Session < Liquid::Tag
|
6
|
+
SYNTAX = /(#{Liquid::VariableSignature}+)\s*=\s*(.*)\s*/om
|
7
|
+
|
8
|
+
attr_reader :from
|
9
|
+
|
10
|
+
def initialize(tag_name, markup, options)
|
11
|
+
super
|
12
|
+
raise Liquid::SyntaxError, "Syntax Error in 'session' - Valid syntax: session [var1] = [var2]" unless markup =~ SYNTAX
|
13
|
+
|
14
|
+
@to = Regexp.last_match(1)
|
15
|
+
@from = Liquid::Variable.new(Regexp.last_match(2), options)
|
16
|
+
end
|
17
|
+
|
18
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
19
|
+
def children
|
20
|
+
[
|
21
|
+
@node.from
|
22
|
+
]
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class SignIn < Base
|
6
|
+
SYNTAX = /\A([\w-]+[\s,]*[\w\s,]*)\s*(user_id:\s*(.+))?\z/
|
7
|
+
VALID_ATTRUBTES = %w[user_id timeout_in_minutes].freeze
|
8
|
+
|
9
|
+
def initialize(tag_name, markup, options)
|
10
|
+
super
|
11
|
+
|
12
|
+
raise Liquid::SyntaxError, "Syntax Error in 'sign_in' - Valid syntax: sign_in user_id: [user_id], timeout_in_minutes: [timeout_in_minutes]" if attributes_expr['user_id'].nil?
|
13
|
+
|
14
|
+
wrong_attributes = attributes_expr.keys - VALID_ATTRUBTES
|
15
|
+
raise Liquid::SyntaxError, "Syntax Error in 'sign_in' - Unknown argument(s): #{wrong_attributes.join(', ')}. Valid arguments: #{VALID_ATTRUBTES}" unless wrong_attributes.empty?
|
16
|
+
end
|
17
|
+
|
18
|
+
def parse_main_value(_tag_name, _markup); end
|
19
|
+
|
20
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
21
|
+
def children
|
22
|
+
@node.attributes_expr.values
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
@@ -0,0 +1,15 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class SpamProtection < Base
|
6
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
7
|
+
def children
|
8
|
+
[
|
9
|
+
@node.value_expr
|
10
|
+
].compact + @node.attributes_expr.values
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class ThemeRender < Liquid::Tag
|
6
|
+
SYNTAX = /
|
7
|
+
(
|
8
|
+
## for {% render "snippet" %}
|
9
|
+
#{Liquid::QuotedString}+ |
|
10
|
+
## for {% render block %}
|
11
|
+
## We require the variable # segment to be at the beginning of the
|
12
|
+
## string (with \A). This is to prevent code like {% render !foo! %}
|
13
|
+
## from parsing
|
14
|
+
\A#{Liquid::VariableSegment}+
|
15
|
+
)
|
16
|
+
## for {% render "snippet" with product as p %}
|
17
|
+
## or {% render "snippet" for products p %}
|
18
|
+
(\s+(with|#{Liquid::Render::FOR})\s+(#{Liquid::QuotedFragment}+))?
|
19
|
+
(\s+(?:as)\s+(#{Liquid::VariableSegment}+))?
|
20
|
+
## variables passed into the tag (e.g. {% render "snippet", var1: value1, var2: value2 %}
|
21
|
+
## are not matched by this regex and are handled by Liquid::Render.initialize
|
22
|
+
/xo
|
23
|
+
|
24
|
+
disable_tags "include"
|
25
|
+
|
26
|
+
attr_reader :template_name_expr, :variable_name_expr, :attributes
|
27
|
+
|
28
|
+
def initialize(tag_name, markup, options)
|
29
|
+
super
|
30
|
+
|
31
|
+
raise Liquid::SyntaxError, options[:locale].t("errors.syntax.render") unless markup =~ SYNTAX
|
32
|
+
|
33
|
+
template_name = Regexp.last_match(1)
|
34
|
+
with_or_for = Regexp.last_match(3)
|
35
|
+
variable_name = Regexp.last_match(4)
|
36
|
+
|
37
|
+
@alias_name = Regexp.last_match(6)
|
38
|
+
@variable_name_expr = variable_name ? parse_expression(variable_name) : nil
|
39
|
+
@template_name_expr = parse_expression(template_name)
|
40
|
+
@for = (with_or_for == Liquid::Render::FOR)
|
41
|
+
|
42
|
+
@attributes = {}
|
43
|
+
markup.scan(Liquid::TagAttributes) do |key, value|
|
44
|
+
@attributes[key] = parse_expression(value)
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
49
|
+
def children
|
50
|
+
[
|
51
|
+
@node.template_name_expr,
|
52
|
+
@node.variable_name_expr
|
53
|
+
] + @node.attributes.values
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
class Try < BaseBlock
|
6
|
+
SYNTAX = /(#{::Liquid::VariableSignature}+)/o
|
7
|
+
|
8
|
+
attr_reader :error_var
|
9
|
+
|
10
|
+
def initialize(tag_name, markup, options)
|
11
|
+
super
|
12
|
+
@try_block = new_body
|
13
|
+
@catch_block = nil
|
14
|
+
@ensure_block = nil
|
15
|
+
end
|
16
|
+
|
17
|
+
def parse(tokens)
|
18
|
+
if parse_body(@try_block, tokens)
|
19
|
+
parse_body(@catch_block, tokens) if @catch_block
|
20
|
+
parse_body(@ensure_block, tokens) if @ensure_block
|
21
|
+
end
|
22
|
+
if blank?
|
23
|
+
@try_block.remove_blank_strings
|
24
|
+
@catch_block&.remove_blank_strings
|
25
|
+
@ensure_block&.remove_blank_strings
|
26
|
+
end
|
27
|
+
@try_block.freeze
|
28
|
+
@catch_block&.freeze
|
29
|
+
@ensure_block&.freeze
|
30
|
+
end
|
31
|
+
|
32
|
+
def nodelist
|
33
|
+
[@try_block, @catch_block, @ensure_block].compact
|
34
|
+
end
|
35
|
+
|
36
|
+
def unknown_tag(tag, markup, tokens)
|
37
|
+
if tag == 'catch'
|
38
|
+
raise Liquid::SyntaxError, "Syntax Error in 'try' - Valid syntax: try ... catch [var] ... endtry" unless markup =~ SYNTAX
|
39
|
+
|
40
|
+
@error_var = Regexp.last_match(1)
|
41
|
+
|
42
|
+
@catch_block = new_body
|
43
|
+
elsif tag == 'ensure'
|
44
|
+
@ensure_block = new_body
|
45
|
+
else
|
46
|
+
super
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
def parse_main_value(tag_name, markup); end
|
51
|
+
|
52
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
53
|
+
def children
|
54
|
+
@node.nodelist
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,65 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
module Tags
|
5
|
+
# Copied tags parsing code from storefront-renderer
|
6
|
+
|
7
|
+
class ContentFor < BaseBlock; end
|
8
|
+
|
9
|
+
class Yield < Base; end
|
10
|
+
|
11
|
+
class IncludeForm < Base
|
12
|
+
class ParseTreeVisitor < Liquid::ParseTreeVisitor
|
13
|
+
def children
|
14
|
+
[
|
15
|
+
@node.main_value
|
16
|
+
] + @node.attributes_expr.values
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
|
21
|
+
class << self
|
22
|
+
attr_writer :register_tags
|
23
|
+
|
24
|
+
def register_tags?
|
25
|
+
@register_tags
|
26
|
+
end
|
27
|
+
|
28
|
+
def register_tag(name, klass)
|
29
|
+
Liquid::Template.register_tag(name, klass)
|
30
|
+
end
|
31
|
+
|
32
|
+
def register_tags!
|
33
|
+
return if !register_tags? || (defined?(@registered_tags) && @registered_tags)
|
34
|
+
|
35
|
+
@registered_tags = true
|
36
|
+
register_tag('form', Form)
|
37
|
+
register_tag('include_form', IncludeForm)
|
38
|
+
register_tag('render', Render)
|
39
|
+
register_tag('theme_render', ThemeRender)
|
40
|
+
register_tag('theme_render_rc', ThemeRender)
|
41
|
+
register_tag('log', Log)
|
42
|
+
register_tag('cache', Cache)
|
43
|
+
register_tag('print', Print)
|
44
|
+
register_tag('parse_json', ParseJson)
|
45
|
+
register_tag('try_rc', Try)
|
46
|
+
register_tag('try', Try)
|
47
|
+
register_tag('export', Export)
|
48
|
+
register_tag('return', Return)
|
49
|
+
register_tag('redirect_to', RedirectTo)
|
50
|
+
register_tag('response_headers', ResponseHeaders)
|
51
|
+
register_tag('response_status', ResponseStatus)
|
52
|
+
register_tag('hash_assign', HashAssign)
|
53
|
+
register_tag('background', Background)
|
54
|
+
register_tag('content_for', ContentFor)
|
55
|
+
register_tag('session', Session)
|
56
|
+
register_tag('sign_in', SignIn)
|
57
|
+
register_tag('yield', Yield)
|
58
|
+
register_tag('graphql', Graphql)
|
59
|
+
register_tag('function', Function)
|
60
|
+
register_tag('spam_protection', SpamProtection)
|
61
|
+
end
|
62
|
+
end
|
63
|
+
self.register_tags = true
|
64
|
+
end
|
65
|
+
end
|
@@ -0,0 +1,11 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module PlatformosCheck
|
4
|
+
class YamlCheck < Check
|
5
|
+
extend ChecksTracking
|
6
|
+
|
7
|
+
def add_offense(message, markup: nil, line_number: nil, app_file: nil, &block)
|
8
|
+
offenses << Offense.new(check: self, message:, markup:, line_number:, app_file:, correction: block)
|
9
|
+
end
|
10
|
+
end
|
11
|
+
end
|
@@ -0,0 +1,57 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "yaml"
|
4
|
+
|
5
|
+
module PlatformosCheck
|
6
|
+
class YamlFile < AppFile
|
7
|
+
def initialize(relative_path, storage)
|
8
|
+
super
|
9
|
+
@loaded = false
|
10
|
+
@content = nil
|
11
|
+
@parser_error = nil
|
12
|
+
end
|
13
|
+
|
14
|
+
def content
|
15
|
+
load!
|
16
|
+
@content
|
17
|
+
end
|
18
|
+
|
19
|
+
def parse_error
|
20
|
+
load!
|
21
|
+
@parser_error
|
22
|
+
end
|
23
|
+
|
24
|
+
def update_contents(new_content = {})
|
25
|
+
raise ArgumentError if new_content.is_a?(String)
|
26
|
+
|
27
|
+
@content = new_content
|
28
|
+
end
|
29
|
+
|
30
|
+
def write
|
31
|
+
pretty = YAML.dump(@content)
|
32
|
+
return unless source.rstrip != pretty.rstrip
|
33
|
+
|
34
|
+
# Most editors add a trailing \n at the end of files. Here we
|
35
|
+
# try to maintain the convention.
|
36
|
+
eof = source.end_with?("\n") ? "\n" : ""
|
37
|
+
@storage.write(@relative_path, pretty.gsub("\n", @eol) + eof)
|
38
|
+
@source = pretty
|
39
|
+
end
|
40
|
+
|
41
|
+
def yaml?
|
42
|
+
true
|
43
|
+
end
|
44
|
+
|
45
|
+
private
|
46
|
+
|
47
|
+
def load!
|
48
|
+
return if @loaded
|
49
|
+
|
50
|
+
@content = YAML.load(source, aliases: true) || {}
|
51
|
+
rescue Psych::SyntaxError => e
|
52
|
+
@parser_error = e
|
53
|
+
ensure
|
54
|
+
@loaded = true
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
@@ -0,0 +1,106 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "liquid"
|
4
|
+
|
5
|
+
require_relative "platformos_check/version"
|
6
|
+
require_relative "platformos_check/bug"
|
7
|
+
require_relative "platformos_check/exceptions"
|
8
|
+
require_relative "platformos_check/json_helper"
|
9
|
+
require_relative "platformos_check/app_file_rewriter"
|
10
|
+
require_relative "platformos_check/app_file"
|
11
|
+
require_relative "platformos_check/yaml_file"
|
12
|
+
require_relative "platformos_check/translation_file"
|
13
|
+
require_relative "platformos_check/schema_file"
|
14
|
+
require_relative "platformos_check/config_file"
|
15
|
+
require_relative "platformos_check/user_schema_file"
|
16
|
+
require_relative "platformos_check/graphql_file"
|
17
|
+
require_relative "platformos_check/liquid_file"
|
18
|
+
require_relative "platformos_check/page_file"
|
19
|
+
require_relative "platformos_check/partial_file"
|
20
|
+
require_relative "platformos_check/layout_file"
|
21
|
+
require_relative "platformos_check/migration_file"
|
22
|
+
require_relative "platformos_check/sms_file"
|
23
|
+
require_relative "platformos_check/email_file"
|
24
|
+
require_relative "platformos_check/api_call_file"
|
25
|
+
require_relative "platformos_check/asset_file"
|
26
|
+
require_relative "platformos_check/json_file"
|
27
|
+
require_relative "platformos_check/analyzer"
|
28
|
+
require_relative "platformos_check/check"
|
29
|
+
require_relative "platformos_check/checks_tracking"
|
30
|
+
require_relative "platformos_check/liquid_check"
|
31
|
+
require_relative "platformos_check/html_check"
|
32
|
+
require_relative "platformos_check/yaml_check"
|
33
|
+
require_relative "platformos_check/cli"
|
34
|
+
require_relative "platformos_check/disabled_check"
|
35
|
+
require_relative "platformos_check/disabled_checks"
|
36
|
+
require_relative "platformos_check/regex_helpers"
|
37
|
+
require_relative "platformos_check/json_helpers"
|
38
|
+
require_relative "platformos_check/position_helper"
|
39
|
+
require_relative "platformos_check/position"
|
40
|
+
require_relative "platformos_check/checks"
|
41
|
+
require_relative "platformos_check/config"
|
42
|
+
require_relative "platformos_check/node"
|
43
|
+
require_relative "platformos_check/tags/base_tag_methods"
|
44
|
+
require_relative "platformos_check/tags/base"
|
45
|
+
require_relative "platformos_check/tags/base_block"
|
46
|
+
require_relative "platformos_check/tags/background"
|
47
|
+
require_relative "platformos_check/tags/cache"
|
48
|
+
require_relative "platformos_check/tags/export"
|
49
|
+
require_relative "platformos_check/tags/form"
|
50
|
+
require_relative "platformos_check/tags/function"
|
51
|
+
require_relative "platformos_check/tags/graphql"
|
52
|
+
require_relative "platformos_check/tags/hash_assign"
|
53
|
+
require_relative "platformos_check/tags/log"
|
54
|
+
require_relative "platformos_check/tags/parse_json"
|
55
|
+
require_relative "platformos_check/tags/print"
|
56
|
+
require_relative "platformos_check/tags/redirect_to"
|
57
|
+
require_relative "platformos_check/tags/render"
|
58
|
+
require_relative "platformos_check/tags/response_headers"
|
59
|
+
require_relative "platformos_check/tags/response_status"
|
60
|
+
require_relative "platformos_check/tags/return"
|
61
|
+
require_relative "platformos_check/tags/session"
|
62
|
+
require_relative "platformos_check/tags/sign_in"
|
63
|
+
require_relative "platformos_check/tags/spam_protection"
|
64
|
+
require_relative "platformos_check/tags/theme_render"
|
65
|
+
require_relative "platformos_check/tags/try"
|
66
|
+
require_relative "platformos_check/tags"
|
67
|
+
require_relative "platformos_check/liquid_node"
|
68
|
+
require_relative "platformos_check/html_node"
|
69
|
+
require_relative "platformos_check/offense"
|
70
|
+
require_relative "platformos_check/printer"
|
71
|
+
require_relative "platformos_check/json_printer"
|
72
|
+
require_relative "platformos_check/platformos_liquid"
|
73
|
+
require_relative "platformos_check/string_helpers"
|
74
|
+
require_relative "platformos_check/storage"
|
75
|
+
require_relative "platformos_check/file_system_storage"
|
76
|
+
require_relative "platformos_check/in_memory_storage"
|
77
|
+
require_relative "platformos_check/app"
|
78
|
+
require_relative "platformos_check/corrector"
|
79
|
+
require_relative "platformos_check/liquid_visitor"
|
80
|
+
require_relative "platformos_check/html_visitor"
|
81
|
+
require_relative "platformos_check/language_server"
|
82
|
+
|
83
|
+
Dir[__dir__ + "/platformos_check/checks/*.rb"].each { |file| require file }
|
84
|
+
|
85
|
+
Encoding.default_external = Encoding::UTF_8
|
86
|
+
Encoding.default_internal = Encoding::UTF_8
|
87
|
+
|
88
|
+
module PlatformosCheck
|
89
|
+
def self.debug?
|
90
|
+
ENV["PLATFORMOS_CHECK_DEBUG"] == "true"
|
91
|
+
end
|
92
|
+
|
93
|
+
def self.debug_log_file
|
94
|
+
ENV.fetch("PLATFORMOS_CHECK_DEBUG_LOG_FILE", nil)
|
95
|
+
end
|
96
|
+
|
97
|
+
def self.with_liquid_c_disabled
|
98
|
+
if defined?(Liquid::C)
|
99
|
+
was_enabled = Liquid::C.enabled
|
100
|
+
Liquid::C.enabled = false if was_enabled
|
101
|
+
end
|
102
|
+
yield
|
103
|
+
ensure
|
104
|
+
Liquid::C.enabled = true if defined?(Liquid::C) && was_enabled
|
105
|
+
end
|
106
|
+
end
|