[JAVA-14174] Renamed paterns to paterns-module (#12718)

* [JAVA-14174] Renamed paterns to paterns-module

* [JAVA-14174] naming fixes

Co-authored-by: panagiotiskakos <panagiotis.kakos@libra-is.com>
This commit is contained in:
panos-kakos
2022-09-19 07:44:14 +01:00
committed by GitHub
parent 368dd6de19
commit b153cff200
518 changed files with 32 additions and 32 deletions

View File

@@ -0,0 +1,2 @@
### Relevant Articles:
- [Introduction to Intercepting Filter Pattern in Java](http://www.baeldung.com/intercepting-filter-pattern-in-java)

View File

@@ -0,0 +1,49 @@
<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<artifactId>intercepting-filter</artifactId>
<name>intercepting-filter</name>
<packaging>war</packaging>
<parent>
<groupId>com.baeldung</groupId>
<artifactId>patterns-modules</artifactId>
<version>1.0.0-SNAPSHOT</version>
</parent>
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${org.slf4j.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
<plugin>
<groupId>org.eclipse.jetty</groupId>
<artifactId>jetty-maven-plugin</artifactId>
<configuration>
<webApp>
<contextPath>/</contextPath>
</webApp>
</configuration>
</plugin>
</plugins>
</build>
</project>

View File

@@ -0,0 +1,66 @@
package com.baeldung.patterns.intercepting.filter;
import com.baeldung.patterns.intercepting.filter.commands.FrontCommand;
import com.baeldung.patterns.intercepting.filter.commands.UnknownCommand;
import com.baeldung.patterns.intercepting.filter.data.Bookshelf;
import com.baeldung.patterns.intercepting.filter.data.BookshelfImpl;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet(name = "intercepting-filter", urlPatterns = "/")
public class FrontControllerServlet extends HttpServlet {
@Override
public void init(ServletConfig config) throws ServletException {
super.init(config);
Bookshelf bookshelf = new BookshelfImpl();
bookshelf.init();
getServletContext().setAttribute("bookshelf", bookshelf);
}
@Override
protected void doGet(
HttpServletRequest request,
HttpServletResponse response
) throws ServletException, IOException {
doCommand(request, response);
}
@Override
protected void doPost(
HttpServletRequest request,
HttpServletResponse response
) throws ServletException, IOException {
doCommand(request, response);
}
private void doCommand(
HttpServletRequest request,
HttpServletResponse response
) throws ServletException, IOException {
FrontCommand command = getCommand(request);
command.init(request, response);
command.process();
}
private FrontCommand getCommand(HttpServletRequest request) {
try {
Class type = Class.forName(
String.format(
"com.baeldung.patterns.intercepting.filter.commands.%sCommand",
request.getParameter("command")
)
);
return (FrontCommand) type
.asSubclass(FrontCommand.class)
.newInstance();
} catch (Exception e) {
return new UnknownCommand();
}
}
}

View File

@@ -0,0 +1,27 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.data.Order;
import javax.servlet.ServletException;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class CheckoutCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
HttpSession session = request.getSession(false);
if (request.getMethod().equals("POST")) {
session.removeAttribute("order");
response.sendRedirect("/?command=Home&message=Thank you for buying!");
} else {
Order order = (Order) session.getAttribute("order");
Double total = order.getItems().entrySet().stream()
.map(entry -> entry.getKey().getPrice() * entry.getValue())
.reduce((p1, p2) -> p1 + p2)
.orElse(0.00);
request.setAttribute("total", total);
forward("shopping-cart");
}
}
}

View File

@@ -0,0 +1,43 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.filters.FilterManager;
import com.baeldung.patterns.intercepting.filter.filters.OnIntercept;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public abstract class FrontCommand implements OnIntercept {
protected HttpServletRequest request;
protected HttpServletResponse response;
private boolean intercept;
public FrontCommand() {
}
public void init(HttpServletRequest request, HttpServletResponse response) {
this.request = request;
this.response = response;
}
public void process() throws ServletException, IOException {
FilterManager.process(request, response, this);
}
public void forward(String target) throws ServletException, IOException {
if (intercept) {
return;
}
String path = String.format("/WEB-INF/jsp/%s.jsp", target);
RequestDispatcher dispatcher = request.getServletContext()
.getRequestDispatcher(path);
dispatcher.forward(request, response);
}
@Override
public void intercept() {
intercept = true;
}
}

View File

@@ -0,0 +1,17 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.data.Bookshelf;
import javax.servlet.ServletException;
import java.io.IOException;
public class HomeCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
Bookshelf bookshelf = (Bookshelf) request.getServletContext()
.getAttribute("bookshelf");
request.setAttribute("books", bookshelf);
forward("home");
}
}

View File

@@ -0,0 +1,23 @@
package com.baeldung.patterns.intercepting.filter.commands;
import javax.servlet.ServletException;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.Optional;
public class LoginCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
if (request.getMethod().equals("POST")) {
HttpSession session = request.getSession(true);
session.setAttribute("username", request.getParameter("username"));
response.sendRedirect(request.getParameter("redirect"));
} else {
String queryString = Optional.ofNullable(request.getQueryString())
.orElse("command=Home");
request.setAttribute("redirect", request.getRequestURL()
.append("?").append(queryString).toString());
forward("login");
}
}
}

View File

@@ -0,0 +1,19 @@
package com.baeldung.patterns.intercepting.filter.commands;
import javax.servlet.ServletException;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.Optional;
public class LogoutCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
Optional.ofNullable(request.getSession(false))
.ifPresent(session -> {
session.removeAttribute("username");
session.removeAttribute("order");
});
response.sendRedirect("/?command=Home");
}
}

View File

@@ -0,0 +1,33 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.data.Book;
import com.baeldung.patterns.intercepting.filter.data.Bookshelf;
import com.baeldung.patterns.intercepting.filter.data.Order;
import com.baeldung.patterns.intercepting.filter.data.OrderImpl;
import javax.servlet.ServletException;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.Optional;
public class OrderCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
if (request.getMethod().equals("POST")) {
HttpSession session = request.getSession(false);
Order order = Optional
.ofNullable(session.getAttribute("order"))
.map(Order.class::cast)
.orElseGet(() -> new OrderImpl((String) session.getAttribute("username")));
Bookshelf bookshelf = (Bookshelf) request.getServletContext()
.getAttribute("bookshelf");
String isbn = request.getParameter("isbn");
Integer quantity = Integer.parseInt(request.getParameter("quantity"));
Book book = bookshelf.get(isbn);
order.add(book, quantity);
session.setAttribute("order", order);
response.sendRedirect(String.format("/?command=Show&isbn=%s", isbn));
}
}
}

View File

@@ -0,0 +1,25 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.data.Book;
import com.baeldung.patterns.intercepting.filter.data.Bookshelf;
import javax.servlet.ServletException;
import java.io.IOException;
import java.util.List;
public class SearchCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
Bookshelf bookshelf = (Bookshelf) request.getServletContext()
.getAttribute("bookshelf");
String q = request.getParameter("q");
List<Book> books = bookshelf.find(q);
if (books.size() > 0) {
request.setAttribute("books", books);
forward("book-found");
} else {
forward("book-notfound");
}
}
}

View File

@@ -0,0 +1,21 @@
package com.baeldung.patterns.intercepting.filter.commands;
import com.baeldung.patterns.intercepting.filter.data.Book;
import com.baeldung.patterns.intercepting.filter.data.Bookshelf;
import javax.servlet.ServletException;
import java.io.IOException;
import java.util.Collections;
public class ShowCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
Bookshelf bookshelf = (Bookshelf) request.getServletContext()
.getAttribute("bookshelf");
String title = request.getParameter("isbn");
Book book = bookshelf.get(title);
request.setAttribute("books", Collections.singletonList(book));
forward("book-found");
}
}

View File

@@ -0,0 +1,12 @@
package com.baeldung.patterns.intercepting.filter.commands;
import javax.servlet.ServletException;
import java.io.IOException;
public class UnknownCommand extends FrontCommand {
@Override
public void process() throws ServletException, IOException {
super.process();
forward("unknown");
}
}

View File

@@ -0,0 +1,19 @@
package com.baeldung.patterns.intercepting.filter.data;
public interface Book {
String getIsbn();
void setIsbn(String isbn);
String getAuthor();
void setAuthor(String author);
String getTitle();
void setTitle(String title);
Double getPrice();
void setPrice(Double price);
}

View File

@@ -0,0 +1,58 @@
package com.baeldung.patterns.intercepting.filter.data;
public class BookImpl implements Book {
private String isbn;
private String author;
private String title;
private Double price;
public BookImpl() {
}
public BookImpl(String isbn, String author, String title, Double price) {
this.isbn = isbn;
this.author = author;
this.title = title;
this.price = price;
}
@Override
public String getIsbn() {
return isbn;
}
@Override
public void setIsbn(String isbn) {
this.isbn = isbn;
}
@Override
public String getAuthor() {
return author;
}
@Override
public void setAuthor(String author) {
this.author = author;
}
@Override
public String getTitle() {
return title;
}
@Override
public void setTitle(String title) {
this.title = title;
}
@Override
public Double getPrice() {
return price;
}
@Override
public void setPrice(Double price) {
this.price = price;
}
}

View File

@@ -0,0 +1,18 @@
package com.baeldung.patterns.intercepting.filter.data;
import java.util.List;
public interface Bookshelf {
default void init() {
add(new BookImpl("001", "Wilson, Robert Anton & Shea, Robert", "Illuminati", 9.99));
add(new BookImpl("002", "Fowler, Martin", "Patterns of Enterprise Application Architecture", 27.88));
add(new BookImpl("003", "Unknown", "Something about German Umlauts (äüö) and ß", 5.49));
}
<E extends Book> boolean add(E book);
Book get(String isbn);
List<Book> find(String q);
}

View File

@@ -0,0 +1,23 @@
package com.baeldung.patterns.intercepting.filter.data;
import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
public class BookshelfImpl extends ArrayList<Book> implements Bookshelf {
@Override
public Book get(String isbn) {
return this.stream()
.filter(book -> book.getIsbn().equals(isbn))
.findFirst()
.orElse(null);
}
@Override
public List<Book> find(String q) {
return this.stream()
.filter(book -> book.getTitle().toLowerCase().contains(q.toLowerCase())
|| book.getAuthor().toLowerCase().contains(q.toLowerCase()))
.collect(Collectors.toList());
}
}

View File

@@ -0,0 +1,11 @@
package com.baeldung.patterns.intercepting.filter.data;
import java.util.Map;
public interface Order {
String getUsername();
Map<Book, Integer> getItems();
void add(Book item, Integer quantity);
}

View File

@@ -0,0 +1,40 @@
package com.baeldung.patterns.intercepting.filter.data;
import java.util.HashMap;
import java.util.Map;
public class OrderImpl implements Order {
private String username;
private Map<Book, Integer> items = new HashMap<>();
public OrderImpl(String username) {
this.username = username;
}
@Override
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
@Override
public Map<Book, Integer> getItems() {
return items;
}
public void setItems(Map<Book, Integer> items) {
this.items = items;
}
@Override
public void add(Book item, Integer quantity) {
Integer q = 0;
if (this.items.containsKey(item)) {
q = this.items.get(item);
}
this.items.put(item, quantity + q);
}
}

View File

@@ -0,0 +1,45 @@
package com.baeldung.patterns.intercepting.filter.filters;
import com.baeldung.patterns.intercepting.filter.commands.FrontCommand;
import com.baeldung.patterns.intercepting.filter.commands.LoginCommand;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
public class AuthenticationFilter implements Filter {
private OnIntercept callback;
public AuthenticationFilter(OnIntercept callback) {
this.callback = callback;
}
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain
) throws IOException, ServletException {
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
HttpServletResponse httpServletResponse = (HttpServletResponse) response;
HttpSession session = httpServletRequest.getSession(false);
if (session == null || session.getAttribute("username") == null) {
callback.intercept();
FrontCommand command = new LoginCommand();
command.init(httpServletRequest, httpServletResponse);
command.process();
} else {
chain.doFilter(request, response);
}
}
@Override
public void destroy() {
}
}

View File

@@ -0,0 +1,25 @@
package com.baeldung.patterns.intercepting.filter.filters;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.Filter;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
public abstract class BaseFilter implements Filter {
private static final Logger log = LoggerFactory.getLogger(BaseFilter.class);
protected FilterConfig filterConfig;
@Override
public void init(FilterConfig filterConfig) throws ServletException {
log.info("Initialize filter: {}", getClass().getSimpleName());
this.filterConfig = filterConfig;
}
@Override
public void destroy() {
log.info("Destroy filter: {}", getClass().getSimpleName());
}
}

View File

@@ -0,0 +1,34 @@
package com.baeldung.patterns.intercepting.filter.filters;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.annotation.WebInitParam;
import java.io.IOException;
import java.util.Optional;
@WebFilter(
servletNames = {"intercepting-filter"},
initParams = {@WebInitParam(name = "encoding", value = "UTF-8")}
)
public class EncodingFilter extends BaseFilter {
private String encoding;
@Override
public void init(FilterConfig filterConfig) throws ServletException {
super.init(filterConfig);
this.encoding = filterConfig.getInitParameter("encoding");
}
@Override
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain
) throws IOException, ServletException {
String encoding = Optional
.ofNullable(request.getParameter("encoding"))
.orElse(this.encoding);
response.setCharacterEncoding(encoding);
chain.doFilter(request, response);
}
}

View File

@@ -0,0 +1,25 @@
package com.baeldung.patterns.intercepting.filter.filters;
import javax.servlet.*;
import java.io.IOException;
import java.util.Arrays;
import java.util.Iterator;
public class FilterChainImpl implements FilterChain {
private Iterator<Filter> filters;
public FilterChainImpl(Filter... filters) {
this.filters = Arrays.asList(filters).iterator();
}
@Override
public void doFilter(
ServletRequest request,
ServletResponse response
) throws IOException, ServletException {
if (filters.hasNext()) {
Filter filter = filters.next();
filter.doFilter(request, response, this);
}
}
}

View File

@@ -0,0 +1,21 @@
package com.baeldung.patterns.intercepting.filter.filters;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class FilterManager {
public static void process(
HttpServletRequest request,
HttpServletResponse response,
OnIntercept callback
) throws ServletException, IOException {
FilterChain filterChain = new FilterChainImpl(
new AuthenticationFilter(callback),
new VisitorCounterFilter()
);
filterChain.doFilter(request, response);
}
}

View File

@@ -0,0 +1,34 @@
package com.baeldung.patterns.intercepting.filter.filters;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.util.Optional;
@WebFilter(servletNames = "intercepting-filter")
public class LoggingFilter extends BaseFilter {
private static final Logger log = LoggerFactory.getLogger(LoggingFilter.class);
@Override
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain
) throws IOException, ServletException {
chain.doFilter(request, response);
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
String username = Optional
.ofNullable(httpServletRequest.getAttribute("username"))
.map(Object::toString)
.orElse("guest");
log.info("Request from '{}@{}': {}?{}", username, request.getRemoteAddr(),
httpServletRequest.getRequestURI(), request.getParameterMap());
}
}

View File

@@ -0,0 +1,5 @@
package com.baeldung.patterns.intercepting.filter.filters;
public interface OnIntercept {
void intercept();
}

View File

@@ -0,0 +1,34 @@
package com.baeldung.patterns.intercepting.filter.filters;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public abstract class TemplateFilter extends BaseFilter {
protected abstract void preFilter(
HttpServletRequest request,
HttpServletResponse response
) throws IOException, ServletException;
protected abstract void postFilter(
HttpServletRequest request,
HttpServletResponse response
) throws IOException, ServletException;
@Override
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain
) throws IOException, ServletException {
HttpServletRequest httpServletRequest = (HttpServletRequest) request;
HttpServletResponse httpServletResponse = (HttpServletResponse) response;
preFilter(httpServletRequest, httpServletResponse);
chain.doFilter(request, response);
postFilter(httpServletRequest, httpServletResponse);
}
}

View File

@@ -0,0 +1,35 @@
package com.baeldung.patterns.intercepting.filter.filters;
import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import java.io.IOException;
import java.util.HashSet;
import java.util.Optional;
import java.util.Set;
public class VisitorCounterFilter implements Filter {
private static Set<String> users = new HashSet<>();
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(
ServletRequest request,
ServletResponse response,
FilterChain chain
) throws IOException, ServletException {
HttpSession session = ((HttpServletRequest) request).getSession(false);
Optional.ofNullable(session.getAttribute("username"))
.map(Object::toString)
.ifPresent(users::add);
request.setAttribute("counter", users.size());
chain.doFilter(request, response);
}
@Override
public void destroy() {
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.2 KiB

View File

@@ -0,0 +1,22 @@
@startuml
scale 1.5
class Handler {
doGet
doPost
}
abstract class AbstractCommand {
process
}
class ConcreteCommand1 {
process
}
class ConcreteCommand2 {
process
}
Handler .right.> AbstractCommand
AbstractCommand <|-- ConcreteCommand1
AbstractCommand <|-- ConcreteCommand2
@enduml

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

View File

@@ -0,0 +1,29 @@
@startuml
scale 1.5
class FrontControllerServlet {
void doGet()
void doPost()
}
class FilterManager {
{static} void process()
}
class FilterChainImpl {
void doFilter()
}
class AuthenticationFilter {
void doFilter()
}
class VisitorCounterFilter {
void doFilter()
}
class FrontCommand {
void process()
}
FrontControllerServlet -- FrontCommand
FrontCommand .right.-- FilterManager
FilterManager -- FilterChainImpl
FilterChainImpl .right.-- AuthenticationFilter
AuthenticationFilter .right.-- VisitorCounterFilter
@enduml

Binary file not shown.

After

Width:  |  Height:  |  Size: 25 KiB

View File

@@ -0,0 +1,26 @@
@startuml
scale 1.5
class FrontControllerServlet {
void doGet()
void doPost()
}
abstract class BaseFilter {
void init()
void destroy()
}
class LoggingFilter {
void doFilter()
}
class EncodingFilter {
void doFilter()
}
class FrontCommand {
void process()
}
FrontControllerServlet .right.-- FrontCommand
FrontControllerServlet -- BaseFilter
BaseFilter <|-- LoggingFilter
BaseFilter <|-- EncodingFilter
@enduml

Binary file not shown.

After

Width:  |  Height:  |  Size: 25 KiB

View File

@@ -0,0 +1,25 @@
@startuml
scale 1.5
class FrontControllerServlet {
void doGet()
void doPost()
}
abstract class BaseFilter {
void init()
void destroy()
}
abstract class TemplateFilter {
{abstract} void preFilter()
{abstract} void postFilter()
--
void doFilter()
}
class FrontCommand {
void process()
}
FrontControllerServlet .right.-- FrontCommand
FrontControllerServlet -- BaseFilter
BaseFilter <|-- TemplateFilter
@enduml

Binary file not shown.

After

Width:  |  Height:  |  Size: 17 KiB

View File

@@ -0,0 +1,17 @@
@startuml
scale 1.5
class Client
class FilterManager
interface FilterChain
interface "Filter 1"
interface "Filter 2"
interface "Filter 3"
Client .right.-- FilterManager
FilterManager .right.-- Target
FilterManager -- FilterChain
FilterChain .right.-- "Filter 3"
FilterChain .right.-- "Filter 2"
FilterChain .right.-- "Filter 1"
@enduml

View File

@@ -0,0 +1,13 @@
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
</pattern>
</encoder>
</appender>
<root level="INFO">
<appender-ref ref="STDOUT" />
</root>
</configuration>

View File

@@ -0,0 +1,24 @@
<%@ page import="com.baeldung.patterns.intercepting.filter.data.Book" %>
<%@ page import="java.util.List" %>
<!DOCTYPE html>
<html>
<head>
<title>Bookshelf: Title found</title>
</head>
<body>
<p>Our Bookshelf contains following titles:</p>
<% for (Book book : (List<Book>) request.getAttribute("books")) { %>
<h2><%= book.getTitle() %></h2>
<p>Author: <%= book.getAuthor() %></p>
<form action="/?command=Order" method="POST">
<label for="quantity">Quantity:</label>
<input type="text" id="quantity" name="quantity" value="1" required>
<input type="hidden" name="isbn" value="<%= book.getIsbn() %>">
<input type="submit" value="Buy it: <%= book.getPrice() %>$">
<a href="/?command=Home">Go back...</a>
</form>
<% } %>
<%@ include file="shopping-cart-hint.jsp"%>
<%@ include file="visitor-counter.jsp"%>
</body>
</html>

View File

@@ -0,0 +1,11 @@
<!DOCTYPE html>
<html>
<head>
<title>Bookshelf: Title not found</title>
</head>
<body>
<p>Our Bookshelf doesn't contains this title:</p>
<h2><%= request.getParameter("q") %></h2>
<%@ include file="visitor-counter.jsp"%>
</body>
</html>

View File

@@ -0,0 +1,27 @@
<%@ page import="com.baeldung.patterns.intercepting.filter.data.Book" %>
<%@ page import="java.util.List" %>
<!DOCTYPE>
<html>
<head>
<title>Bookshelf: Home</title>
</head>
<body>
<form action="/?command=Search" method="POST">
<input type="text" id="search" name="q">
<input type="submit" value="Go!">
</form>
<% if (request.getParameter("message") != null) { %>
<h2><%= request.getParameter("message") %></h2>
<% } else { %>
<h2>Welcome to the Bookshelf!</h2>
<% } %>
<% for (Book book : (List<Book>) request.getAttribute("books")) { %>
<hr/>
<p><b><%= book.getAuthor() %>:</b></p>
<h3><%= book.getTitle() %></h3>
<a href="/?command=Show&isbn=<%= book.getIsbn() %>">More...</a>
<% } %>
<%@ include file="shopping-cart-hint.jsp"%>
<%@ include file="visitor-counter.jsp"%>
</body>
</html>

View File

@@ -0,0 +1,16 @@
<!DOCTYPE html>
<html>
<head>
<title>Bookshelf: Login</title>
</head>
<body>
<p>Please input a username:</p>
<h2>Login</h2>
<form action="/?command=Login" method="POST">
<input type="text" name="username" placeholder="Username">
<input type="hidden" name="redirect" value="<%= (String) request.getAttribute("redirect") %>">
<input type="submit" value="Proceed">
</form>
<%@ include file="visitor-counter.jsp" %>
</body>
</html>

View File

@@ -0,0 +1,16 @@
<%@ page import="com.baeldung.patterns.intercepting.filter.data.Order" %>
<% if (session != null && session.getAttribute("order") != null) { %>
<% Order order = ((Order) session.getAttribute("order")); %>
<% if (order != null && order.getItems().size() > 0) { %>
<hr/>
<p>
Your shopping cart is holding
<% if (order.getItems().size() == 1) { %>
1 item.
<% } else { %>
<%= (order.getItems().size()) %> items.
<% } %>
<a href="/?command=Checkout">Checkout</a>
</p>
<% } %>
<% } %>

View File

@@ -0,0 +1,29 @@
<%@ page import="com.baeldung.patterns.intercepting.filter.data.Book" %>
<%@ page import="com.baeldung.patterns.intercepting.filter.data.Order" %>
<%@ page import="java.util.Map" %>
<!DOCTYPE html>
<html>
<head>
<title>Bookshelf: Checkout</title>
</head>
<body>
<p>You are about to buy the following books:</p>
<h2>Shopping Cart</h2>
<% Order order = (Order) session.getAttribute("order"); %>
<ul>
<% for (Map.Entry<Book, Integer> entry : order.getItems().entrySet()) { %>
<li>
<b><%= entry.getValue() %> x <%= entry.getKey().getPrice() %></b>
<h3><%= entry.getKey().getTitle() %></h3>
<i> by <%= entry.getKey().getAuthor()%></i>
</li>
<% } %>
</ul>
<p>
<b>Total: <%= request.getAttribute("total") %></b>
</p>
<form action="/?command=Checkout" method="POST">
<input type="submit" value="Donate :)">
</form>
</body>
</html>

View File

@@ -0,0 +1,9 @@
<!DOCTYPE html>
<html>
<head>
<title>Bookshelf: Command unknown</title>
</head>
<body>
<p>Sorry, this command is not known!</p>
</body>
</html>

View File

@@ -0,0 +1,5 @@
<% Integer counter = (Integer) request.getAttribute("counter"); %>
<% if (counter != null && counter > 0) { %>
<hr/>
<p>You are visitor #<%= counter %>. <a href="/?command=Logout">Logout</a></p>
<% } %>