GSoC 2021: Patch Security Vulnerabilities Identified by NCSU



Primary mentor

@Isaac Sears

Backup mentor

@Sharif Magembe

Assigned to

NA

Abstract

Late last year, OpenMRS began collaborating with researchers from North Carolina State University (NCSU) to better secure the OpenMRS Reference Application. NCSU researchers, using cutting-edge security assessment techniques, have identified almost 300 distinct security issues. Many of those issues are relatively low-complexity, requiring one-line patches. This is a great opportunity for students who are interested in software security to get first-hand experience in the field.

Project Champions

  • @Isaac Sears

Objectives

  1. (First priority) Patch up to 50 XSS vulnerabilities

  2. (Second priority) Implement up to 25 authorization checks where they are lacking

  3. (Third priority) Implement safe exception handling for up to 10 HTTP 500 errors

Extra Credits

  1. Take on responsibility for patching more complex security issues

Skills Required

  1. Javascript, HTML

  2. Java

Skills Recommended

  1. Experience with .jsp and/or .gsp frontend templating languages

  2. Basic knowledge of common web application security vulnerabilities

Examples to Look Through While Preparing Your Proposal

1) Understand XSS vulnerabilities

2) Review some recent fix examples

For security reasons we can't publicly release the full NCSU report; however, you can check out these PRs for recent examples of the kinds of bugs that are being patched (and the kind of work the patches in this GSOC project entail):

Once you are accepted into the project, you will be added to the security team and a more detailed backlog of issues will be shared with you.

A successful proposal

A successful proposal could include a general approach to patching XSS vulnerabilities based on the examples above.