2006/unicorn/src/org/w3c/unicorn Test.java,1.1.2.2,1.1.2.3 Init.java,1.1.2.3,1.1.2.4 Controller.java,1.1.2.3,1.1.2.4

Update of /sources/public/2006/unicorn/src/org/w3c/unicorn
In directory hutz:/tmp/cvs-serv2800/src/org/w3c/unicorn

Added Files:
      Tag: dev2
	Test.java Init.java Controller.java 
Log Message:
w3 => w3c 

--- NEW FILE: Controller.java ---
package org.w3c.unicorn;

import java.io.IOException;
import javax.servlet.*;
import javax.servlet.http.*;

import org.apache.log4j.Logger;
import org.w3.unicorn.route.Route;
import org.w3c.unicorn.route.RouteParser;

public class Controller extends HttpServlet {
	private static final long serialVersionUID = 1L;
	
	private static Logger logger;
	private static boolean isInitialized = false;
	
	@Override
	public final void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		if (isInitialized)
			processRequest(request, response);
		else
			response.sendError(500, "Unicorn is not initialized properly. Check logs.");
	}

	@Override
	public final void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

	@Override
	protected void doPut(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		doGet(request, response);
	}

	protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		logger.info("Processing request: " + request.getRequestURL());
		Route route = RouteParser.getRoute(request);
		
		if (route.isSetUrl()) {
			response.sendRedirect(route.getUrl());
			logger.info("Request redirected to: " + route.getUrl());
		}
		else if (route.isSetAction()) {
			RequestDispatcher dispatcher = getServletContext().getNamedDispatcher(route.getAction());
			if (dispatcher == null) {
				String error = "ERROR: " + route.getAction() + " does not corespond to any servlet-name in web.xml";
				logger.error(error);
				response.sendError(501, error);
			} else {
				try {
					dispatcher.forward(request, response);
					logger.info("Request dispatched to: " + route.getAction());
				} catch (Exception e) {
					logger.error("ERROR: " + e.getMessage(), e);
					response.sendError(501, "ERROR: " + e.getMessage());
				}
			}
		} else {
			String error = "ERROR: No action associated with this route. Check route.xml.";
			logger.error(error);
			response.sendError(501, error);
		}
	}
	
	static {
		try {
			Init.init();
			logger = Logger.getLogger("Controller");
			isInitialized = true;
			logger.info("Unicorn initialized properly");
		} catch (Exception e) {
			try {
				logger.error("Unicorn was not initialized properly. No request will be processed!");
			} catch (Exception e1) {
				e1.printStackTrace();
			}
			e.printStackTrace();
		}
	}
}
--- NEW FILE: Test.java ---
package org.w3c.unicorn;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		String s = "${TEST} sdf zer ${TEST2}";
		System.out.println(s.matches("\\$\\{[a-zA-Z_0-9]*\\}"));
		
		Matcher matcher = Pattern.compile("\\$\\{[a-zA-Z_0-9]*\\}").matcher(s);
		
		while (matcher.find()) {
			System.out.println(matcher.group());
		}
		
		System.out.println(matcher.lookingAt());
		System.out.println(matcher.group());
		System.out.println(matcher.group(0));
		System.out.println(matcher.group(1));
		System.out.println(matcher.lookingAt());
		System.out.println(matcher.group());
	     //replaceAll(repl)
	}

}

--- NEW FILE: Init.java ---
package org.w3c.unicorn;

import java.io.File;
import java.net.URI;
import java.util.List;

import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
import org.w3.unicorn.route.Route;
import org.w3c.unicorn.route.RouteParser;
import org.w3.unicorn.route.RoutesDocument;
import org.w3c.unicorn.util.Property;
import org.w3c.unicorn.util.UCNProperties;

public class Init {
	
	private static Logger logger;
	
	private static URI unicornHome;
	
	public static void init() throws Exception {
		
		// Checks that unicorn.home (JVM parameter) is set to an existing directory
		String ucnHome = System.getProperty("unicorn.home");
		if (ucnHome == null) {
			String error = "ERROR: \"unicorn.home\" is not set in the JVM parameters. Please read the README file before trying to install Unicorn";
			System.err.println(error);
			throw new Exception(error);
		} else if (!(new File(ucnHome)).exists() && (new File(ucnHome).isDirectory())){
			String error = "ERROR: \"unicorn.home\" is not an existing directory: " + System.getProperty("unicorn.home");
			System.err.println(error);
			throw new Exception(error);
		} else {
			unicornHome = (new File(ucnHome)).toURI();
			System.out.println("OK - \"unicorn.home\" was found: " + unicornHome.getPath());
		}
		
		// Log4j initialisation attempt
		String log4jPath = unicornHome.getPath() + "/WEB-INF/conf/log4j.properties";
		File log4jPropFile = new File(log4jPath);
		if (!log4jPropFile.exists()) {
			String error = "WARN: \"log4j.properties\" could not be found: " + log4jPath;
			System.err.println(error);
			System.err.println("WARN: Log4j will not be initialized.");
		} else {
			System.out.println("OK - Log4j initialized with file: " + log4jPath);
			PropertyConfigurator.configure(log4jPropFile.toURI().toURL());
			logger = Logger.getLogger("Init");
			logger.info("Unicorn home directory was found");
			logger.debug("Unicorn home path = " + unicornHome.getPath());
			logger.info("Log4j has been successfully initialized");
			logger.debug("Log4j properties file = " + log4jPropFile.toURI().toURL().getPath());
		}
		
		// Loading unicorn.properties
		logger.debug("Loading unicorn.properties");		
		String unicornPath = unicornHome.getPath() + "/WEB-INF/conf/unicorn.properties";
		logger.debug("Unicorn properties file = " + unicornPath);
		File unicornPropFile = new File(unicornPath);
		if (!unicornPropFile.exists()) {
			String error = "ERROR: \"unicorn.properties\" could not be found: " + unicornPath;
			System.err.println(error);
			logger.error("Unicorn properties file does not exists! Path is: " + unicornPath);
			throw new Exception(error);
		} else {
			UCNProperties ucnProperties = new UCNProperties();
			ucnProperties.put("UNICORN_HOME", unicornHome.getPath());
			ucnProperties.load(unicornPropFile.toURI().toURL().openStream());
			Property.setUnicornProperties(ucnProperties);
			logger.info("Unicorn properties file successfully loaded");
			logger.debug("Loaded properties: " + Property.getUnicornProperties());
		}
		
		// Checking Unicorn properties
		String[] mandatoryProperties = {"PATH_TO_CONF_FILES","ROUTE_XML","PATH_TO_CACHE"};
		for (String property: mandatoryProperties) {
			if (Property.get(property) == null) {
				String error = "\""+ property +"\" is not defined in unicorn.properties. This property is mandatory.";
				logger.error(error);
				throw new Exception(error);
			}
		}
		
		// Initialising RouteParser
		logger.debug("Initialising RouteParser");
		File routesFile = new File(Property.get("PATH_TO_CONF_FILES", "ROUTE_XML"));
		if (!routesFile.exists()) {
			String error = "Route xml file could not be found: " + routesFile;
			logger.error(error);
			throw new Exception(error);
		}
		RoutesDocument routesXML = RoutesDocument.Factory.parse(routesFile);
		List<Route> tempRouteList = routesXML.getRoutes().getRouteList();
		for(Route route : tempRouteList) {
			logger.debug("Route found: " + route.xmlText());
			if (route.isSetType() && route.getType().equals("index")) {
				logger.debug("> This route is the Index route");
				RouteParser.setIndex(route);
				RouteParser.getRouteList().add(route);
			} else if (route.isSetType() && route.getType().equals("404")) {
				logger.debug("> This route is the 404 route");
				RouteParser.setError404(route);
			} else {
				RouteParser.getRouteList().add(route);
			}
		}
		if (RouteParser.getIndex() == null) {
			String error = "There is non Index route. RouteParser is not initialized properly.";
			logger.error(error);
			throw new Exception(error);
		} else if (RouteParser.getError404() == null) {
			String error = "There is non 404 route. RouteParser is not initialized properly.";
			logger.error(error);
			throw new Exception(error);
		} else {
			logger.info("Unicorn routes successfully loaded");
		}
		
	}
	
	public static void main(String argv[]) {
        
		try {
			init();
		} catch (Exception e1) {
			// TODO Auto-generated catch block
			e1.printStackTrace();
		}
		//Property.init();
		
		
		 /*URL url;

		 HttpURLConnection connection;
		try {
			
			url = new URL("http://www.masdelafontanelle.fr");
			 connection = (HttpURLConnection) url.openConnection();
			
			 System.out.println(connection.getResponseCode());
			 System.out.println(connection.getContentType());
			
	         Map responseMap = connection.getHeaderFields();
	         System.out.println("");

	         for (Iterator iterator = responseMap.keySet().iterator(); iterator.hasNext(); ) {
	        	 String key = (String) iterator.next();
	             System.out.print(key + " = ");

	             List values = (List) responseMap.get(key);
	             for (int i = 0; i < values.size(); i++) {
	                 Object o = values.get(i);
	                 System.out.print(o + ", ");
	             }
	             System.out.println("");
	         }
	         
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}



		 logger.error("toooooooooooooooooo");
		 logger.debug("Hello, my name is Homer Simpson.");
	        logger.debug("Hello, my name is Lisa Simpson.");
	        logger.debug("Hello, my name is Marge Simpson.");
	        logger.debug("Hello, my name is Bart Simpson.");
	        logger.debug("Hello, my name is Maggie Simpson.");

	        logger.info("We are the Simpsons!");
	        logger.info("Mmmmmm .... Chocolate.");
	        logger.info("Homer likes chocolate");
	        logger.info("Doh!");
	        logger.info("We are the Simpsons!");

	        logger.warn("Bart: I am through with working! Working is for chumps!" +
	                "Homer: Son, I'm proud of you. I was twice your age before " +
	                "I figured that out.");
	        logger.warn("Mmm...forbidden donut.");
	        logger.warn("D'oh! A deer! A female deer!");
	        logger.warn("Truly, yours is a butt that won't quit." +
	                "- Bart, writing as Woodrow to Ms. Krabappel.");
	        NDC.push("#23856");
	        logger.error("Dear Baby, Welcome to Dumpsville. Population: you.");
	        logger.error("Dear Baby, Welcome to Dumpsville. Population: you.",
	                new IOException("Dumpsville, USA"));
	        logger.error("Mr. Hutz, are you aware you're not wearing pants?");
	        logger.error("Mr. Hutz, are you aware you're not wearing pants?",
	                new IllegalStateException("Error !!"));

	        NDC.pop();
	        NDC.remove();

	        NDC.push("Another NDC");
	        // Log some information.
	        logger.fatal("Hello, my name is Bart Simpson.");
	        logger.error("Hi diddly ho good neighbour.");
	        // Clean up NDC
	        NDC.pop();
	        NDC.remove();
	        logger.fatal("Eep.");
	        logger.fatal("Mmm...forbidden donut.",
	                new SecurityException("Fatal Exception"));
	        logger.fatal("D'oh! A deer! A female deer!");
	        logger.fatal("Mmmmmm .... Chocolate.",
	                new SecurityException("Fatal Exception"));
		*/
        
	}
}

Received on Thursday, 6 August 2009 12:47:10 UTC