- Introduced user registration
- Now using Spring Boot for classloading, this way local development does not need to restart the complete server - Fixed all kinds of dependencies on the names of the lessons necessary to keep in mind during the creation of a lesson. - Simplied loading of resources, by adding resource mappings in MvcConfig. - Refactored plugin loading, now only one class is left for loading the lessons.
This commit is contained in:
		
							
								
								
									
										176
									
								
								webgoat-server/pom.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								webgoat-server/pom.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,176 @@ | ||||
| <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" | ||||
|          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> | ||||
|     <modelVersion>4.0.0</modelVersion> | ||||
|     <artifactId>webgoat-server</artifactId> | ||||
|     <packaging>jar</packaging> | ||||
|     <parent> | ||||
|         <groupId>org.owasp.webgoat</groupId> | ||||
|         <artifactId>webgoat-parent</artifactId> | ||||
|         <version>8.0-SNAPSHOT</version> | ||||
|     </parent> | ||||
|  | ||||
|     <properties> | ||||
|         <start-class>org.owasp.webgoat.StartWebGoat</start-class> | ||||
|     </properties> | ||||
|  | ||||
|     <profiles> | ||||
|         <profile> | ||||
|             <id>raspberry-pi-3</id> | ||||
|             <activation> | ||||
|                 <property> | ||||
|                     <name>rpi</name> | ||||
|                 </property> | ||||
|             </activation> | ||||
|             <build> | ||||
|                 <plugins> | ||||
|                     <plugin> | ||||
|                         <groupId>com.spotify</groupId> | ||||
|                         <artifactId>docker-maven-plugin</artifactId> | ||||
|                         <version>0.4.10</version> | ||||
|                         <configuration> | ||||
|                             <imageName>webgoat/webgoat-8.0</imageName> | ||||
|                             <dockerDirectory>src/main/docker_rpi3</dockerDirectory> | ||||
|                             <resources> | ||||
|                                 <resource> | ||||
|                                     <targetPath>/</targetPath> | ||||
|                                     <directory>${project.build.directory}</directory> | ||||
|                                     <include>${project.build.finalName}.war</include> | ||||
|                                 </resource> | ||||
|                             </resources> | ||||
|                         </configuration> | ||||
|                     </plugin> | ||||
|                 </plugins> | ||||
|             </build> | ||||
|         </profile> | ||||
|         <profile> | ||||
|             <id>default</id> | ||||
|             <activation> | ||||
|                 <property> | ||||
|                     <name>!rpi</name> | ||||
|                 </property> | ||||
|             </activation> | ||||
|             <build> | ||||
|                 <plugins> | ||||
|                     <plugin> | ||||
|                         <groupId>com.spotify</groupId> | ||||
|                         <artifactId>docker-maven-plugin</artifactId> | ||||
|                         <version>0.4.10</version> | ||||
|                         <configuration> | ||||
|                             <imageName>webgoat/webgoat-8.0</imageName> | ||||
|                             <dockerDirectory>src/main/docker</dockerDirectory> | ||||
|                             <resources> | ||||
|                                 <resource> | ||||
|                                     <targetPath>/</targetPath> | ||||
|                                     <directory>${project.build.directory}</directory> | ||||
|                                     <include>${project.build.finalName}.war</include> | ||||
|                                 </resource> | ||||
|                             </resources> | ||||
|                         </configuration> | ||||
|                     </plugin> | ||||
|                 </plugins> | ||||
|             </build> | ||||
|         </profile> | ||||
|     </profiles> | ||||
|  | ||||
|  | ||||
|  | ||||
|     <dependencies> | ||||
|         <dependency> | ||||
|             <groupId>com.spotify</groupId> | ||||
|             <artifactId>docker-maven-plugin</artifactId> | ||||
|             <version>0.4.10</version> | ||||
|             <scope>compile</scope> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat</groupId> | ||||
|             <artifactId>webgoat-container</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>challenge</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>client-side-filtering</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>cross-site-scripting</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>http-basics</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>http-proxies</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>idor</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>jwt</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>sql-injection</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>vulnerable-components</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.owasp.webgoat.lesson</groupId> | ||||
|             <artifactId>xxe</artifactId> | ||||
|             <version>${project.version}</version> | ||||
|         </dependency> | ||||
|         <dependency> | ||||
|             <groupId>org.springframework.boot</groupId> | ||||
|             <artifactId>spring-boot-devtools</artifactId> | ||||
|             <optional>true</optional> | ||||
|         </dependency> | ||||
|     </dependencies> | ||||
|  | ||||
|     <build> | ||||
|         <plugins> | ||||
|             <plugin> | ||||
|                 <groupId>org.springframework.boot</groupId> | ||||
|                 <artifactId>spring-boot-maven-plugin</artifactId> | ||||
|                 <configuration> | ||||
|                     <!-- See http://docs.spring.io/spring-boot/docs/current/reference/html/howto-build.html#howto-extract-specific-libraries-when-an-executable-jar-runs --> | ||||
|                     <requiresUnpack> | ||||
|                         <dependency> | ||||
|                             <groupId>org.thymeleaf.extra</groupId> | ||||
|                             <artifactId>thymeleaf-extras-springsecurity4</artifactId> | ||||
|                         </dependency> | ||||
|                         <dependency> | ||||
|                             <groupId>org.asciidoctor</groupId> | ||||
|                             <artifactId>asciidoctorj</artifactId> | ||||
|                         </dependency> | ||||
|                         <dependency> | ||||
|                             <groupId>org.jruby</groupId> | ||||
|                             <artifactId>jruby-complete</artifactId> | ||||
|                         </dependency> | ||||
|                     </requiresUnpack> | ||||
|                     <jvmArguments> | ||||
|                         <!-- -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000--> | ||||
|                     </jvmArguments> | ||||
|                     <fork>true</fork> | ||||
|                 </configuration> | ||||
|             </plugin> | ||||
|         </plugins> | ||||
|     </build> | ||||
|  | ||||
| </project> | ||||
							
								
								
									
										6
									
								
								webgoat-server/src/main/docker/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								webgoat-server/src/main/docker/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| FROM openjdk:8-jre | ||||
| VOLUME /tmp | ||||
| RUN cd /root; mkdir -p .webgoat | ||||
| ADD webgoat-container-8.0-SNAPSHOT.war webgoat.jar | ||||
| RUN sh -c 'touch /webgoat.jar' | ||||
| ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/webgoat.jar"] | ||||
							
								
								
									
										10
									
								
								webgoat-server/src/main/docker_rpi3/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								webgoat-server/src/main/docker_rpi3/Dockerfile
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | ||||
| # Baseimage specially for raspberry pi usage | ||||
| FROM resin/rpi-raspbian:jessie | ||||
| VOLUME /tmp | ||||
| # Installing openjdk-8-headless like in the standard Webgoat Docker container | ||||
| RUN apt-get update && apt-get install -y \ | ||||
|       openjdk-8-jre-headless | ||||
| RUN cd /root; mkdir -p .webgoat | ||||
| ADD webgoat-container-8.0-SNAPSHOT.war webgoat.jar | ||||
| RUN sh -c 'touch /webgoat.jar' | ||||
| ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/webgoat.jar"] | ||||
| @ -0,0 +1,40 @@ | ||||
| /* | ||||
|  * This file is part of WebGoat, an Open Web Application Security Project utility. For details, | ||||
|  * please see http://www.owasp.org/ | ||||
|  * <p> | ||||
|  * Copyright (c) 2002 - 2017 Bruce Mayhew | ||||
|  * <p> | ||||
|  * 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. | ||||
|  * <p> | ||||
|  * 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. | ||||
|  * <p> | ||||
|  * 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. | ||||
|  * <p> | ||||
|  * Getting Source ============== | ||||
|  * <p> | ||||
|  * Source for this application is maintained at https://github.com/WebGoat/WebGoat, a repository for free software | ||||
|  * projects. | ||||
|  * <p> | ||||
|  */ | ||||
| package org.owasp.webgoat;import org.springframework.boot.SpringApplication; | ||||
| import org.springframework.boot.autoconfigure.SpringBootApplication; | ||||
|  | ||||
| /** | ||||
|  * @author nbaars | ||||
|  * @date 2/21/17 | ||||
|  */ | ||||
| @SpringBootApplication | ||||
| public class StartWebGoat  { | ||||
|  | ||||
|     public static void main(String[] args) { | ||||
|         SpringApplication.run(WebGoat.class, args); | ||||
|     } | ||||
|  | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user