You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
First of all, thank you for the great work on the CSRF protection functionality in the csrf_protection_controller.js script. It’s a fantastic addition, and it works really well for handling traditional form submissions.
However, I’ve encountered an issue when using this CSRF protection in the context of fetch requests (without Turbo). Specifically, I found that the CSRF token is not always applied correctly when sending fetch requests, as the event listener for the form submission may be executed before the CSRF logic in csrf_protection_controller.js is applied.
In the current implementation, the CSRF token is injected into the form submission when the submit event is captured :
This works fine when the form is submitted in the traditional way. However, when using fetch (with custom AJAX logic), I encountered an issue where the CSRF protection logic is executed after the fetch request is sent, which results in the CSRF token not being updated in time.
Here’s an example that illustrates the problem :
document.addEventListener('submit',function(event){if(event.target.matches('form[data-toggle="ajax-form"]')){event.preventDefault()// Send request with fetch}})
Depending on the order of event listener registration, the event that triggers the fetch request can be executed before the csrf_protection_controller.js event listener. This is exactly what happens in my case, as my event listener is registered during the DOMContentLoaded event, which causes it to run before the CSRF protection logic is applied.
To fix this issue, I used the capture phase (true as the third argument in addEventListener) to ensure that the CSRF protection logic is executed before the fetch request is sent.
// csrf_protection_controller.jsdocument.addEventListener('submit',function(event){// CSRF protection logic},true);// Using the capture phase to ensure this runs first
Why is the capture phase not used by default in the script? I believe this would help ensure the CSRF token is updated before the form is submitted, especially in cases where fetch is used.
Additionally, I noticed that the CSRF logic in csrf_protection_controller.js is tightly coupled with form submissions with Turbo. However, when using fetch (without Turbo), the same functionality is required — updating the CSRF token — but the existing solution works specifically for Turbo requests. This creates the need for duplication of code to handle CSRF protection in the same way for fetch requests.
It would be more efficient to refactor the CSRF protection logic in csrf_protection_controller.js into reusable JavaScript functions that could be invoked depending on the environment (e.g., when handling fetch requests). This way, the CSRF protection logic for Turbo can be reused without duplicating code, allowing developers to call the relevant functions as needed based on their specific use case.
I’d love to hear your thoughts on whether this approach makes sense and if there are any suggestions for improving this workflow, particularly for fetch requests.
Happy Holidays !
The text was updated successfully, but these errors were encountered:
First of all, thank you for the great work on the CSRF protection functionality in the
csrf_protection_controller.js
script. It’s a fantastic addition, and it works really well for handling traditional form submissions.However, I’ve encountered an issue when using this CSRF protection in the context of fetch requests (without Turbo). Specifically, I found that the CSRF token is not always applied correctly when sending fetch requests, as the event listener for the form submission may be executed before the CSRF logic in
csrf_protection_controller.js
is applied.In the current implementation, the CSRF token is injected into the form submission when the submit event is captured :
This works fine when the form is submitted in the traditional way. However, when using fetch (with custom AJAX logic), I encountered an issue where the CSRF protection logic is executed after the fetch request is sent, which results in the CSRF token not being updated in time.
Here’s an example that illustrates the problem :
Depending on the order of event listener registration, the event that triggers the fetch request can be executed before the csrf_protection_controller.js event listener. This is exactly what happens in my case, as my event listener is registered during the DOMContentLoaded event, which causes it to run before the CSRF protection logic is applied.
To fix this issue, I used the capture phase (true as the third argument in addEventListener) to ensure that the CSRF protection logic is executed before the fetch request is sent.
Why is the capture phase not used by default in the script? I believe this would help ensure the CSRF token is updated before the form is submitted, especially in cases where fetch is used.
Additionally, I noticed that the CSRF logic in csrf_protection_controller.js is tightly coupled with form submissions with Turbo. However, when using fetch (without Turbo), the same functionality is required — updating the CSRF token — but the existing solution works specifically for Turbo requests. This creates the need for duplication of code to handle CSRF protection in the same way for fetch requests.
It would be more efficient to refactor the CSRF protection logic in csrf_protection_controller.js into reusable JavaScript functions that could be invoked depending on the environment (e.g., when handling fetch requests). This way, the CSRF protection logic for Turbo can be reused without duplicating code, allowing developers to call the relevant functions as needed based on their specific use case.
I’d love to hear your thoughts on whether this approach makes sense and if there are any suggestions for improving this workflow, particularly for fetch requests.
Happy Holidays !
The text was updated successfully, but these errors were encountered: