platformos-check 0.4.4 → 0.4.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2232ebaad35fcbe180ef2bf7430a1f1b14a8a292e9e83162cab6f4daa2627e77
4
- data.tar.gz: 664d5f186a9a9af5db288b287d05cacc1134b7533c63c11255e635481d7315e7
3
+ metadata.gz: 737ae774f598b10b46e556298d68e7eafe711c00ef6463c30ba8f8736c6cf42a
4
+ data.tar.gz: 443998e3955d4032ab41b2d5189ff42f5a736781b05cf0bdfa2a8dfe1b4fe629
5
5
  SHA512:
6
- metadata.gz: 8dc44ad6b4b964108030b675ee46d883c75c4d3e8ef7262617dc2897eb7a53bf858d64b0e3ffb2ddc50a1f762bf9fbe6371c630d9a64c5358a5152e0a52e7901
7
- data.tar.gz: 6c86d9c6e458117f9f25c0563fbe33d7f3792f5b9129671f8e30fe539b0d02cd9faedd77491c091e5c608d1e296a0bb9bc86c236b10f2cc10aa7711ac22f2f1f
6
+ metadata.gz: 5049fd3616a7721b1d23920c87436ed19a525d96454ef18a93cb22ba210e733a5984c154f3a79778f047769fa059052fc65b3ca56cc02d70e4ee5e108c568b29
7
+ data.tar.gz: c7dcafbce9b30fc5fd2b954a080e4f167f24c7fcfbc8ea48b6131b54eb33eb71657f45068075c1ea2f9f6520682a33f94eb207e0a68341e10f9abcda4939b8db
data/CHANGELOG.md CHANGED
@@ -1,3 +1,13 @@
1
+ v0.4.6 / 2023-12-19
2
+ ==================
3
+
4
+ * Add FormAuthenticityToken check
5
+
6
+ v0.4.5 / 2023-12-19
7
+ ==================
8
+
9
+ * Add FormAction check
10
+
1
11
  v0.4.4 / 2023-12-04
2
12
  ==================
3
13
 
data/config/default.yml CHANGED
@@ -87,6 +87,14 @@ ImgLazyLoading:
87
87
  enabled: true
88
88
  ignore: []
89
89
 
90
+ FormAction:
91
+ enabled: true
92
+ ignore: []
93
+
94
+ FormAuthenticityToken:
95
+ enabled: true
96
+ ignore: []
97
+
90
98
  HtmlParsingError:
91
99
  enabled: true
92
100
  ignore: []
@@ -1,2 +1,2 @@
1
1
 
2
- {"revision":"008ef526d0cf8a5c42eb2c05938d91543996edf8"}
2
+ {"revision":"131bcc176b04bbd3cd19a57ac57395a74b949760"}
@@ -0,0 +1,56 @@
1
+ # Form action (`FormAction`)
2
+
3
+ Form action defines the endpoint to which browser will make a request after submitting it.
4
+
5
+ As a general rule you should use relative path like `action="/my/path"` instead of for example `action="my/path"` to avoid errors.
6
+
7
+ ## Check Details
8
+
9
+ This check is aimed at ensuring you have not forgotten to start the path with /.
10
+
11
+ :-1: Examples of **incorrect** code for this check:
12
+
13
+ ```liquid
14
+ <form action="dummy/create">
15
+ ...
16
+ </form>
17
+ ```
18
+
19
+ :+1: Examples of **correct** code for this check:
20
+
21
+ ```liquid
22
+ <form action="/dummy/create">
23
+ ...
24
+ </form>
25
+ ```
26
+
27
+ ```liquid
28
+ <form action="{{ var }}">
29
+ ...
30
+ </form>
31
+ ```
32
+
33
+ ## Check Options
34
+
35
+ The default configuration for this check is the following:
36
+
37
+ ```yaml
38
+ FormAction:
39
+ enabled: true
40
+ ```
41
+
42
+ ## When Not To Use It
43
+
44
+ There should be no cases where disabling this rule is needed.
45
+
46
+ ## Version
47
+
48
+ This check has been introduced in PlatformOS Check 0.45.0.
49
+
50
+ ## Resources
51
+
52
+ - [Rule Source][codesource]
53
+ - [Documentation Source][docsource]
54
+
55
+ [codesource]: /lib/platformos_check/checks/form_action.rb
56
+ [docsource]: /docs/checks/form_action.md
@@ -0,0 +1,55 @@
1
+ # Form authenticity token (`FormAuthenticityToken`)
2
+
3
+ In platformOS all POST/PATCH/PUT/DELETE requests are protected from [CSRF Attacks][csrf-attack] through [authenticity_token][page-csrf]
4
+ Form action defines the endpoint to which browser will make a request after submitting it.
5
+
6
+ As a general rule you should include hidden input `<input type="hidden" name="authenticity_token" value="{{ context.authenticity_token }}">` in every form. Missing it will result in session invalidation and any logged in user will be automatically logged out.
7
+
8
+ ## Check Details
9
+
10
+ This check is aimed at ensuring you have not forgotten to include authenticity_token in a form.
11
+
12
+ :-1: Examples of **incorrect** code for this check:
13
+
14
+ ```liquid
15
+ <form action="dummy/create">
16
+ </form>
17
+ ```
18
+
19
+ :+1: Examples of **correct** code for this check:
20
+
21
+ ```liquid
22
+ <form action="/dummy/create">
23
+ <input type="hidden" name="authenticity_token" value="{{ context.authenticity_token }}">
24
+ </form>
25
+ ```
26
+
27
+ ## Check Options
28
+
29
+ The default configuration for this check is the following:
30
+
31
+ ```yaml
32
+ FormAuthenticityToken:
33
+ enabled: true
34
+ ```
35
+
36
+ ## When Not To Use It
37
+
38
+ There should be no cases where disabling this rule is needed.
39
+
40
+ ## Version
41
+
42
+ This check has been introduced in PlatformOS Check 0.46.0.
43
+
44
+ ## Resources
45
+
46
+ - [Rule Source][codesource]
47
+ - [Documentation Source][docsource]
48
+ - [platformOS Page documentation][page-csrf]
49
+ - [OWASP Cross Site Request Forgery][csrf-attack]
50
+
51
+ [codesource]: /lib/platformos_check/checks/form_authenticity_token.rb
52
+ [docsource]: /docs/checks/form_authenticity_token.md
53
+ [page-csrf]: https://documentation.platformos.com/developer-guide/pages/pages#post-put-patch-delete-methods-and-cross-site-request-forgery-attacks
54
+ [csrf-attack]: https://owasp.org/www-community/attacks/csrf
55
+
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module PlatformosCheck
4
+ class FormAction < HtmlCheck
5
+ severity :error
6
+ categories :html
7
+ doc docs_url(__FILE__)
8
+
9
+ def on_form(node)
10
+ action = node.attributes["action"]&.strip
11
+ return if action.nil?
12
+ return if action.empty?
13
+ return if action.start_with?('/', '{{')
14
+
15
+ add_offense("Use action=\"/#{action}\" (start with /) to ensure the form can be submitted multiple times in case of validation errors", node:)
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,21 @@
1
+ # frozen_string_literal: true
2
+
3
+ module PlatformosCheck
4
+ class FormAuthenticityToken < HtmlCheck
5
+ severity :error
6
+ categories :html
7
+ doc docs_url(__FILE__)
8
+
9
+ AUTHENTICITY_TOKEN_VALUE = /\A\s*{{\s*context\.authenticity_token\s*}}\s*\z/
10
+
11
+ def on_form(node)
12
+ authenticity_toke_inputs = node.children.select { |c| c.name == 'input' && c.attributes['name'] == 'authenticity_token' && c.attributes['value']&.match?(AUTHENTICITY_TOKEN_VALUE) }
13
+ return if authenticity_toke_inputs.size == 1
14
+ return add_offense('Duplicated authenticity_token inputs', node:) if authenticity_toke_inputs.size > 1
15
+
16
+ add_offense('Missing authenticity_token input <input type="hidden" name="authenticity_token" value="{{ context.authenticity_token }}">', node:) do |corrector|
17
+ corrector.insert_after(node, "\n<input type=\"hidden\" name=\"authenticity_token\" value=\"{{ context.authenticity_token }}\">")
18
+ end
19
+ end
20
+ end
21
+ end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module PlatformosCheck
4
- VERSION = "0.4.4"
4
+ VERSION = "0.4.6"
5
5
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: platformos-check
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.4
4
+ version: 0.4.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Piotr Bliszczyk
@@ -10,7 +10,7 @@ authors:
10
10
  autorequire:
11
11
  bindir: exe
12
12
  cert_chain: []
13
- date: 2023-12-04 00:00:00.000000000 Z
13
+ date: 2023-12-19 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: graphql
@@ -117,6 +117,8 @@ files:
117
117
  - docs/checks/TEMPLATE.md.erb
118
118
  - docs/checks/convert_include_to_render.md
119
119
  - docs/checks/deprecated_filter.md
120
+ - docs/checks/form_action.md
121
+ - docs/checks/form_authenticity_token.md
120
122
  - docs/checks/html_parsing_error.md
121
123
  - docs/checks/img_lazy_loading.md
122
124
  - docs/checks/img_width_and_height.md
@@ -159,6 +161,8 @@ files:
159
161
  - lib/platformos_check/checks/TEMPLATE.rb.erb
160
162
  - lib/platformos_check/checks/convert_include_to_render.rb
161
163
  - lib/platformos_check/checks/deprecated_filter.rb
164
+ - lib/platformos_check/checks/form_action.rb
165
+ - lib/platformos_check/checks/form_authenticity_token.rb
162
166
  - lib/platformos_check/checks/html_parsing_error.rb
163
167
  - lib/platformos_check/checks/img_lazy_loading.rb
164
168
  - lib/platformos_check/checks/img_width_and_height.rb