diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..efdbd2c
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,9 @@
+target
+*.class
+*.iml
+*.ipr
+.idea
+.classpath
+.settings
+.project
+.DS_Store
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..a6bf8df
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,38 @@
+
+
+ 4.0.0
+ com.develogical
+ 1.0-SNAPSHOT
+ SimpleWebApp
+
+
+ org.eclipse.jetty
+ jetty-servlet
+ 9.2.14.v20151106
+
+
+ javax.servlet
+ servlet-api
+ 2.5
+
+
+ junit
+ junit
+ 4.12
+
+
+
+
+
+ maven-compiler-plugin
+ 3.3
+
+
+ 1.7
+
+
+
+
+
\ No newline at end of file
diff --git a/src/main/java/com/develogical/WebServer.java b/src/main/java/com/develogical/WebServer.java
new file mode 100644
index 0000000..89c5a7e
--- /dev/null
+++ b/src/main/java/com/develogical/WebServer.java
@@ -0,0 +1,54 @@
+package com.develogical;
+
+import com.develogical.app.QueryProcessor;
+import com.develogical.web.ApiResponse;
+import com.develogical.web.IndexPage;
+import com.develogical.web.ResultsPage;
+import org.eclipse.jetty.server.Server;
+import org.eclipse.jetty.servlet.ServletHandler;
+import org.eclipse.jetty.servlet.ServletHolder;
+
+import javax.servlet.ServletException;
+import javax.servlet.http.HttpServlet;
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+
+public class WebServer {
+
+ public WebServer() throws Exception {
+ Server server = new Server(8080);
+
+ ServletHandler handler = new ServletHandler();
+ handler.addServletWithMapping(new ServletHolder(new Website()), "/*");
+ handler.addServletWithMapping(new ServletHolder(new Api()), "/api/*");
+ server.setHandler(handler);
+
+ server.start();
+ }
+
+ static class Website extends HttpServlet {
+ @Override
+ protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
+ String query = req.getParameter("q");
+ if (query == null) {
+ new IndexPage().writeTo(resp);
+ } else {
+ new ResultsPage(query, new QueryProcessor().process(query)).writeTo(resp);
+ }
+ }
+ }
+
+ static class Api extends HttpServlet {
+ @Override
+ protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
+ String query = req.getParameter("q");
+ new ApiResponse(new QueryProcessor().process(query)).writeTo(resp);
+ }
+ }
+
+ public static void main(String[] args) throws Exception {
+ new WebServer();
+ }
+}
+
diff --git a/src/main/java/com/develogical/app/QueryProcessor.java b/src/main/java/com/develogical/app/QueryProcessor.java
new file mode 100644
index 0000000..5027093
--- /dev/null
+++ b/src/main/java/com/develogical/app/QueryProcessor.java
@@ -0,0 +1,13 @@
+package com.develogical.app;
+
+public class QueryProcessor {
+
+ public String process(String query) {
+ if (query.toLowerCase().contains("shakespeare")) {
+ return "William Shakespeare (26 April 1564 - 23 April 1616) was an " +
+ "English poet, playwright, and actor, widely regarded as the greatest " +
+ "writer in the English language and the world's pre-eminent dramatist.";
+ }
+ return "";
+ }
+}
diff --git a/src/main/java/com/develogical/web/ApiResponse.java b/src/main/java/com/develogical/web/ApiResponse.java
new file mode 100644
index 0000000..832819f
--- /dev/null
+++ b/src/main/java/com/develogical/web/ApiResponse.java
@@ -0,0 +1,20 @@
+package com.develogical.web;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.io.PrintWriter;
+
+public class ApiResponse {
+
+ private final String answer;
+
+ public ApiResponse(String answer) {
+ this.answer = answer;
+ }
+
+ public void writeTo(HttpServletResponse resp) throws IOException {
+ resp.setContentType("text/plain");
+ PrintWriter writer = resp.getWriter();
+ writer.println(answer);
+ }
+}
diff --git a/src/main/java/com/develogical/web/HtmlPage.java b/src/main/java/com/develogical/web/HtmlPage.java
new file mode 100644
index 0000000..19bceee
--- /dev/null
+++ b/src/main/java/com/develogical/web/HtmlPage.java
@@ -0,0 +1,30 @@
+package com.develogical.web;
+
+import javax.servlet.http.HttpServletResponse;
+import java.io.IOException;
+import java.io.PrintWriter;
+
+public abstract class HtmlPage {
+
+ public void writeTo(HttpServletResponse resp) throws IOException {
+ resp.setContentType("text/html");
+ PrintWriter writer = resp.getWriter();
+ writeHeaderTo(writer);
+ writeContentTo(writer);
+ writeFooterTo(writer);
+ }
+
+ private void writeHeaderTo(PrintWriter writer) {
+ writer.println("");
+ writer.println("
");
+ writer.println("");
+ }
+
+ private void writeFooterTo(PrintWriter writer) {
+ writer.println("");
+ writer.println("");
+ }
+
+ protected abstract void writeContentTo(PrintWriter writer);
+
+}
diff --git a/src/main/java/com/develogical/web/IndexPage.java b/src/main/java/com/develogical/web/IndexPage.java
new file mode 100644
index 0000000..7de3044
--- /dev/null
+++ b/src/main/java/com/develogical/web/IndexPage.java
@@ -0,0 +1,18 @@
+package com.develogical.web;
+
+import java.io.PrintWriter;
+
+public class IndexPage extends HtmlPage {
+
+ @Override
+ protected void writeContentTo(PrintWriter writer) {
+ writer.println(
+ "Welcome!
" +
+ "Enter your query in the box below: " +
+ "
" +
+ "");
+ }
+
+}
diff --git a/src/main/java/com/develogical/web/ResultsPage.java b/src/main/java/com/develogical/web/ResultsPage.java
new file mode 100644
index 0000000..d9b3236
--- /dev/null
+++ b/src/main/java/com/develogical/web/ResultsPage.java
@@ -0,0 +1,28 @@
+package com.develogical.web;
+
+import java.io.PrintWriter;
+
+public class ResultsPage extends HtmlPage {
+
+ private final String query;
+ private final String answer;
+
+ public ResultsPage(String query, String answer) {
+ this.query = query;
+ this.answer = answer;
+ }
+
+ @Override
+ protected void writeContentTo(PrintWriter writer) {
+
+ if (answer == null || answer.isEmpty()) {
+ writer.println("Sorry
");
+ writer.print("Sorry, we didn't understand " + query + "
");
+ } else {
+ writer.println("" + query + "
");
+ writer.println("" + answer + "
");
+ }
+
+ writer.println("Back to Search Page
");
+ }
+}
diff --git a/src/test/java/com/develogical/app/QueryProcessorTest.java b/src/test/java/com/develogical/app/QueryProcessorTest.java
new file mode 100644
index 0000000..744dc0b
--- /dev/null
+++ b/src/test/java/com/develogical/app/QueryProcessorTest.java
@@ -0,0 +1,27 @@
+package com.develogical.app;
+
+import org.junit.Test;
+
+import static org.hamcrest.CoreMatchers.containsString;
+import static org.hamcrest.CoreMatchers.is;
+import static org.junit.Assert.assertThat;
+
+public class QueryProcessorTest {
+
+ QueryProcessor queryProcessor = new QueryProcessor();
+
+ @Test
+ public void returnsEmptyStringIfCannotProcessQuery() throws Exception {
+ assertThat(queryProcessor.process("test"), is(""));
+ }
+
+ @Test
+ public void knowsAboutShakespeare() throws Exception {
+ assertThat(queryProcessor.process("Shakespeare"), containsString("playwright"));
+ }
+
+ @Test
+ public void isNotCaseSensitive() throws Exception {
+ assertThat(queryProcessor.process("shakespeare"), containsString("playwright"));
+ }
+}