This site is the archived OWASP Foundation Wiki and is no longer accepting Account Requests.
To view the new OWASP Foundation website, please visit https://owasp.org

Difference between revisions of "CSRF Guard 2.2 Roadmap"

From OWASP
Jump to: navigation, search
 
(4 intermediate revisions by the same user not shown)
Line 7: Line 7:
 
The following is a list of changes that have been implemented for the development version of J2EE CSRFGuard 2.2:
 
The following is a list of changes that have been implemented for the development version of J2EE CSRFGuard 2.2:
  
TBD
+
:# JavaScriptHandler now iterates over all DOM elements and puts the token in if the element is a form or has a 'src' or 'href' attribute.
 +
:# Allow the user to define "entry point pages" whose token is never validated but a token always gets inserted
 +
:# Allow the user to define "unprotected pages" that we will simply ignore. By default, all pages are "protected"
 +
:# Update the response handlers to support the various locations that an "href" and "src" attribute can be placed in the HTML 5 spec
 +
:# Visiting the page and clicking "refresh" is caught as a CSRF attack. Only verify the token if parameters exist in the request (optional).
 +
:# Allow the developer to specify where to send the user on the initial request (i.e. when the token is being created). Prevents initial CSRF attacks against unauthenticated users.
 +
:# Add a "CSRF Token" JSP Tag library that developers can call in their JSP to dynamically add the token.
  
 
== Planned Changes ==
 
== Planned Changes ==
Line 13: Line 19:
 
The following is a list of changes that are tentatively scheduled for the J2EE CSRFGuard 2.2 release:
 
The following is a list of changes that are tentatively scheduled for the J2EE CSRFGuard 2.2 release:
  
:# Allow the user to define "entry point pages" whose token is never validated but a token always gets inserted
 
:# Allow the user to define "unprotected pages" that we will simply ignore. By default, all pages are "protected"
 
 
:# Modify the response handlers to only place the token in links/forms that point to our origin
 
:# Modify the response handlers to only place the token in links/forms that point to our origin
:# Update the response handlers to support the various locations that an "href" and "src" attribute can be placed in the HTML 5 spec
 
:# Update the JavaScriptHandler to support the "embed" tag. Is there a better way to update the attributes where we don't need to know the tag name, like the HTMLParserHandler?
 
:# Visiting the page and clicking "refresh" is caught as a CSRF attack. Only verify the token if parameters exist in the request (optional).
 
 
:# Add basic JavaScript support for invocations such as "document.location" or "window.location"
 
:# Add basic JavaScript support for invocations such as "document.location" or "window.location"
 
:# Optionally randomize the CSRF token parameter name.
 
:# Optionally randomize the CSRF token parameter name.
:# Add a "CSRF Token" JSP Tag library that developers can call in their JSP to dynamically add the token.
 
  
 
== Deferred Changes ==
 
== Deferred Changes ==

Latest revision as of 18:01, 5 April 2008

Overview

The purpose of this article is to maintain the desired change requests for the upcoming CSRFGuard releases. If there is a particular feature that you would like to see implemented, please feel free to add it to the appropriate sections below.

Completed Changes

The following is a list of changes that have been implemented for the development version of J2EE CSRFGuard 2.2:

  1. JavaScriptHandler now iterates over all DOM elements and puts the token in if the element is a form or has a 'src' or 'href' attribute.
  2. Allow the user to define "entry point pages" whose token is never validated but a token always gets inserted
  3. Allow the user to define "unprotected pages" that we will simply ignore. By default, all pages are "protected"
  4. Update the response handlers to support the various locations that an "href" and "src" attribute can be placed in the HTML 5 spec
  5. Visiting the page and clicking "refresh" is caught as a CSRF attack. Only verify the token if parameters exist in the request (optional).
  6. Allow the developer to specify where to send the user on the initial request (i.e. when the token is being created). Prevents initial CSRF attacks against unauthenticated users.
  7. Add a "CSRF Token" JSP Tag library that developers can call in their JSP to dynamically add the token.

Planned Changes

The following is a list of changes that are tentatively scheduled for the J2EE CSRFGuard 2.2 release:

  1. Modify the response handlers to only place the token in links/forms that point to our origin
  2. Add basic JavaScript support for invocations such as "document.location" or "window.location"
  3. Optionally randomize the CSRF token parameter name.

Deferred Changes

The following is a list of changes that were suggested but not implemented:

  1. Port the existing configuration file to an XML based config file
  2. Allow the user to define a list of "known safe extensions" that do not require CSRF checks

Changes Under Consideration

The following is a list of change requests that are still under consideration:

TBD