Skip to content

Commit

Permalink
#3 get rid of ozark dependencies in the sources
Browse files Browse the repository at this point in the history
  • Loading branch information
dasniko committed Apr 17, 2016
1 parent 6a1c427 commit a7edc4e
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 12 deletions.
4 changes: 1 addition & 3 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -12,15 +12,13 @@ repositories {
mavenLocal()
// for glassfish/mvc/ozark dependencies
maven { url 'https://maven.java.net/content/groups/public/' }
// for ozark-react dependency
maven { url 'https://jitpack.io' }
}

dependencies {
// servlet-api
providedCompile 'javax:javaee-web-api:7.0'
// mvc api and ri
compile 'javax.mvc:javax.mvc-api:1.0-SNAPSHOT'
compile 'javax.mvc:javax.mvc-api:1.0-edr2'
compile 'org.glassfish.ozark:ozark:1.0.0-m03-SNAPSHOT'
// required dependencies to be able to deploy to a plain servlet container like tomcat
compile 'org.glassfish.jersey.containers:jersey-container-servlet:2.22.2'
Expand Down
60 changes: 51 additions & 9 deletions src/main/java/dasniko/ozark/react/ReactViewEngine.java
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,19 @@

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.glassfish.ozark.engine.ServletViewEngine;
import org.glassfish.ozark.engine.ViewEngineContextImpl;

import javax.annotation.Priority;
import javax.inject.Inject;
import javax.mvc.Models;
import javax.mvc.engine.Priorities;
import javax.mvc.engine.ViewEngine;
import javax.mvc.engine.ViewEngineContext;
import javax.mvc.engine.ViewEngineException;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import java.io.IOException;
import java.util.Arrays;
import java.util.Map;
Expand All @@ -21,12 +24,14 @@
* @author Niko Köbler, http://www.n-k.de, @dasniko
*/
@Priority(Priorities.FRAMEWORK)
public class ReactViewEngine extends ServletViewEngine {
public class ReactViewEngine implements ViewEngine {

private static final String viewPrefix = "react:";

@Inject
React react;
@Inject
ServletContext servletContext;

private ObjectMapper mapper = new ObjectMapper();

Expand Down Expand Up @@ -67,13 +72,8 @@ public void processView(ViewEngineContext context) throws ViewEngineException {
throw new ViewEngineException(e);
}

// create a new context with the actual view and forward to ServletViewEngine
ViewEngineContext ctx = new ViewEngineContextImpl(template, models,
context.getRequest(), context.getResponse(), context.getUriInfo(),
context.getResourceInfo(), context.getConfiguration());

try {
forwardRequest(ctx, "*.jsp", "*.jspx");
processRequest(context, models, template);
} catch (ServletException | IOException e) {
throw new ViewEngineException(e);
}
Expand All @@ -82,4 +82,46 @@ public void processView(ViewEngineContext context) throws ViewEngineException {
private Map<String, String> parseQueryString(final String query) {
return Arrays.asList(query.split("&")).stream().map(p -> p.split("=")).collect(Collectors.toMap(s -> s[0], s -> s[1]));
}

private void processRequest(final ViewEngineContext context, final Models models, final String view) throws ServletException, IOException {
RequestDispatcher requestDispatcher = servletContext.getNamedDispatcher("jsp");
// Need new request with updated URI and extension matching semantics
final HttpServletRequest request = new HttpServletRequestWrapper(context.getRequest()) {
@Override
public String getRequestURI() {
return resolveView(context, view);
}

@Override
public String getServletPath() {
return resolveView(context, view);
}

@Override
public String getPathInfo() {
return null;
}

@Override
public StringBuffer getRequestURL() {
return new StringBuffer(getRequestURI());
}
};

for (String name : models) {
request.setAttribute(name, models.get(name));
}

requestDispatcher.forward(request, context.getResponse());
}

private String resolveView(final ViewEngineContext context, final String view) {
if (!view.startsWith("/")) {
String viewFolder = (String) context.getConfiguration().getProperty(VIEW_FOLDER);
viewFolder = viewFolder == null ? DEFAULT_VIEW_FOLDER : viewFolder;
viewFolder += !viewFolder.endsWith("/") ? "/" : "";
return viewFolder + view;
}
return view;
}
}

0 comments on commit a7edc4e

Please sign in to comment.