-
-
Notifications
You must be signed in to change notification settings - Fork 5.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Invalid CSRF token issues - unable to recover submitted data #17850
Comments
And possible this one: My proposal (#17282 (comment)) is saving a draft in local storage. |
After reading the EasyMDE source code, the autosave of EasyMDE seems not ideal, it doesn't clear expired drafts, it may lead to problems: https://stackoverflow.com/questions/13567509/what-happens-when-localstorage-is-full . |
I second this Request. I just lost a good hour or two of code review commentary. Edit: I have to revise: Fortunately, all inline comments were already saved (just not visible), so I only lost the actual review comment. Still annoying, but only two minutes of work ;-) |
I think save it in the frontend is a choice. So the form content will not be lost when special things happen. |
This is a very annoying issue. I had it multiple times and last time i lost 2 hours of work! @lunny have you considered using a more modern architecture with AJAX (is that still a thing?) or Websockets to change the page content in real time, like displaying an error or adding new comments in real-time? As always, GitHubs design is great! |
We should do that AJAX thing, but there is no plan currently. But we are working toward that direction. And currently I think it should be a bug. At least, it should redirect to login page but not display the CSRF token issue. |
The issue is that you can still be logged in, but the CSRF token be expired. At least this is the scenario for me. Another solution would be to present a confirmation page that asks the user if they still want to perform the action with the new token. |
So the CSRF expired time have to be set longer than session expired time to avoid that. |
The issue is that you could for example login again in the meantime - the CSRF token is expired, but you have a valid session. The login page wouldn't help in this case. It should be gracefully handled, and in case you don't have a valid session, you'll be redirected to the login page from there. |
I think I find the bug in CSRF module. If I understand correctly, the CSRF token is generated every 24h, and the valid period is also 24h. So, if a user get a CSRF token at time If it is the case, there could be a simple fix to generate the CSRF token every minute (or every 10 minutes). |
Where could you find it's |
About: "Where could you find it's Two timeout durations in csrf.go and xsrf.go, one is for cookie timeout, one is for token validation timeout, they are both 24h |
The PR to fix the bug: |
Feature Description
If you have an issue / pull comment open for a long time, submitting it will yield
Bad Request: Invalid CSRF token
, which is fine from a security perspective, but very annoying to users.It seems there is currently no way to restore the submitted data. I encountered this two times very recently with pull review comments, the content is gone if you go back in your history, and you can't re-send (and maybe get via the browser console, although this is already very unintuitive, because Gitea uses a redirect to the dashboard to display this warning, instead of directly showing it on the next page).
This is very annoying to me, and I think it might be annoying to all users ever encountering this.
I can think of some "naive solutions", but I doubt all work or are secure:
Screenshots
No response
The text was updated successfully, but these errors were encountered: