All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.owasp.webgoat.LessonSource Maven / Gradle / Ivy

There is a newer version: 7.1
Show newest version
package org.owasp.webgoat;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.owasp.webgoat.lessons.AbstractLesson;
import org.owasp.webgoat.session.Course;
import org.owasp.webgoat.session.WebSession;

/**
 * *************************************************************************************************
 *
 *
 * This file is part of WebGoat, an Open Web Application Security Project
 * utility. For details, please see http://www.owasp.org/
 *
 * Copyright (c) 2002 - 20014 Bruce Mayhew
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation; either version 2 of the License, or (at your option) any later
 * version.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program; if not, write to the Free Software Foundation, Inc., 59 Temple
 * Place - Suite 330, Boston, MA 02111-1307, USA.
 *
 * Getting Source ==============
 *
 * Source for this application is maintained at https://github.com/WebGoat/WebGoat, a repository
 * for free software projects.
 *
 * @author Bruce Mayhew WebGoat
 * @since October 28, 2003
 * @version $Id: $Id
 */
public class LessonSource extends HammerHead {

    /**
     *
     */
    private static final long serialVersionUID = 2588430536196446145L;

    /**
     * Description of the Field
     */
    public final static String START_SOURCE_SKIP = "START_OMIT_SOURCE";

    /** Constant END_SOURCE_SKIP="END_OMIT_SOURCE" */
    public final static String END_SOURCE_SKIP = "END_OMIT_SOURCE";

    /**
     * {@inheritDoc}
     *
     * Description of the Method
     * @exception IOException Description of the Exception
     * @exception ServletException Description of the Exception
     */
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
        String source = null;

        try {
			// System.out.println( "Entering doPost: " );
            // System.out.println( " - request " + request);
            // System.out.println( " - principle: " + request.getUserPrincipal()
            // );
            // setCacheHeaders(response, 0);
            WebSession session = (WebSession) request.getSession(true).getAttribute(WebSession.SESSION);
            // FIXME: Too much in this call.
            session.update(request, response, this.getServletName());

            boolean showSolution = session.getParser().getBooleanParameter("solution", false);
            boolean showSource = session.getParser().getBooleanParameter("source", false);
            if (showSolution) {

                // Get the Java solution of the lesson.
                source = getSolution(session);

                int scr = session.getCurrentScreen();
                Course course = session.getCourse();
                AbstractLesson lesson = course.getLesson(session, scr, AbstractLesson.USER_ROLE);
                lesson.getLessonTracker(session).setViewedSolution(true);

            } else if (showSource) {

                // Get the Java source of the lesson. FIXME: Not needed
                source = getSource(session);

                int scr = session.getCurrentScreen();
                Course course = session.getCourse();
                AbstractLesson lesson = course.getLesson(session, scr, AbstractLesson.USER_ROLE);
                lesson.getLessonTracker(session).setViewedSource(true);
            }
        } catch (Throwable t) {
            t.printStackTrace();
            log("ERROR: " + t);
        } finally {
            try {
                this.writeSource(source, response);
            } catch (Throwable thr) {
                thr.printStackTrace();
                log(request, "Could not write error screen: " + thr.getMessage());
            }
            // System.out.println( "Leaving doPost: " );

        }
    }

    /**
     * Description of the Method
     *
     * @param s Description of the Parameter
     * @return Description of the Return Value
     */
    protected String getSource(WebSession s) {

        String source = null;
        int scr = s.getCurrentScreen();
        Course course = s.getCourse();

        if (s.isUser() || s.isChallenge()) {

            AbstractLesson lesson = course.getLesson(s, scr, AbstractLesson.USER_ROLE);

            if (lesson != null) {
                source = lesson.getSource(s);
            }
        }
        if (source == null) {
            return "Source code is not available. Contact "
                    + s.getWebgoatContext().getFeedbackAddressHTML();
        }
        return (source.replaceAll("(?s)" + START_SOURCE_SKIP + ".*" + END_SOURCE_SKIP,
                "Code Section Deliberately Omitted"));
    }

    /**
     * 

getSolution.

* * @param s a {@link org.owasp.webgoat.session.WebSession} object. * @return a {@link java.lang.String} object. */ protected String getSolution(WebSession s) { String source = null; int scr = s.getCurrentScreen(); Course course = s.getCourse(); if (s.isUser() || s.isChallenge()) { AbstractLesson lesson = course.getLesson(s, scr, AbstractLesson.USER_ROLE); if (lesson != null) { source = lesson.getSolution(s); } } if (source == null) { return "Solution is not available. Contact " + s.getWebgoatContext().getFeedbackAddressHTML(); } return (source); } /** * Description of the Method * * @param s Description of the Parameter * @param response Description of the Parameter * @exception IOException Description of the Exception * @throws java.io.IOException if any. */ protected void writeSource(String s, HttpServletResponse response) throws IOException { response.setContentType("text/html"); PrintWriter out = response.getWriter(); if (s == null) { s = new String(); } out.print(s); out.close(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy