--- /dev/null
+/*****************************************************************************
+ * Copyright Igor Barma, Eric Brun, Alexandre Desoubeaux, Christian Martel,
+ * (2 décembre 2008)
+ *
+ * Ce logiciel est un programme informatique servant à l'évaluation des
+ * compétences.
+ *
+ * Ce logiciel est régi par la licence CeCILL soumise au droit français et
+ * respectant les principes de diffusion des logiciels libres. Vous pouvez
+ * utiliser, modifier et/ou redistribuer ce programme sous les conditions
+ * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
+ * sur le site "http://www.cecill.info".
+ *
+ * En contrepartie de l'accessibilité au code source et des droits de copie,
+ * de modification et de redistribution accordés par cette licence, il n'est
+ * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
+ * seule une responsabilité restreinte pèse sur l'auteur du programme, le
+ * titulaire des droits patrimoniaux et les concédants successifs.
+ *
+ * A cet égard l'attention de l'utilisateur est attirée sur les risques
+ * associés au chargement, à l'utilisation, à la modification et/ou au
+ * développement et à la reproduction du logiciel par l'utilisateur étant
+ * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
+ * manipuler et qui le réserve donc à des développeurs et des professionnels
+ * avertis possédant des connaissances informatiques approfondies. Les
+ * utilisateurs sont donc invités à charger et tester l'adéquation du
+ * logiciel à leurs besoins dans des conditions permettant d'assurer la
+ * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
+ * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
+ *
+ * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
+ * pris connaissance de la licence CeCILL, et que vous en avez accepté les
+ * termes.
+ *******************************************************************************/
+package com.pentila.evalcomp.utilities;
+
+import javax.servlet.http.HttpServletRequest;
+
+import org.aopalliance.intercept.MethodInterceptor;
+import org.aopalliance.intercept.MethodInvocation;
+import org.springframework.aop.ProxyMethodInvocation;
+import org.springframework.web.context.request.RequestContextHolder;
+import org.springframework.web.context.request.ServletRequestAttributes;
+
+// TODO: Auto-generated Javadoc
+/**
+ * The Class JustInTimeInterceptor.
+ */
+public class JustInTimeInterceptor implements MethodInterceptor {
+
+ /** The logger. */
+ org.slf4j.Logger logger = org.slf4j.LoggerFactory.getLogger(JustInTimeInterceptor.class);
+
+ /** The schema loader. */
+ private SchemaLoader schemaLoader;
+
+ /* (non-Javadoc)
+ * @see org.aopalliance.intercept.MethodInterceptor#invoke(org.aopalliance.intercept.MethodInvocation)
+ */
+ public Object invoke(MethodInvocation methodInvocation) throws Throwable {
+
+ String code = null;
+ try{
+ ServletRequestAttributes attrs = (ServletRequestAttributes) RequestContextHolder
+ .getRequestAttributes();
+
+ HttpServletRequest hsr = attrs.getRequest();
+
+ code = hsr.getHeader("code");
+ if (code == null){
+ code = (String)hsr.getAttribute("code");
+ }
+
+ if (logger.isDebugEnabled()){
+ logger.debug("invoke code is : " + code);
+ }
+
+ String isFirst = (String) hsr.getAttribute("codeIsFirst");
+
+ if (isFirst != null){
+ code = null;
+ }else{
+ hsr.setAttribute("codeIsFirst", "no");
+ }
+
+ }catch(Exception e){
+ //e.printStackTrace();
+ }
+
+
+ ProxyMethodInvocation pmi = (ProxyMethodInvocation) methodInvocation;
+
+ //long startTime = System.currentTimeMillis();
+
+ Object result = pmi.proceed();
+
+ //long duration = System.currentTimeMillis() - startTime;
+ //Method method = pmi.getMethod();
+
+ //String methodName = method.getDeclaringClass().getName() + "."
+ // + method.getName();
+
+ /*System.out.println("Args : ");
+ for (Object o : pmi.getArguments()) {
+ System.out.println("=> " + o);
+ }*/
+
+ if (result != null) {
+ //System.out.println("Type of returned object " + result.getClass());
+ if (code != null) {
+ schemaLoader.loadObject(code, result);
+ }
+
+ }
+ //System.out.println("Method '" + methodName + "' took " + duration
+ // + " milliseconds to run");
+ return result;
+ }
+
+ /**
+ * Gets the schema loader.
+ *
+ * @return the schema loader
+ */
+ public SchemaLoader getSchemaLoader() {
+ return schemaLoader;
+ }
+
+ /**
+ * Sets the schema loader.
+ *
+ * @param schemaLoader the new schema loader
+ */
+ public void setSchemaLoader(SchemaLoader schemaLoader) {
+ this.schemaLoader = schemaLoader;
+ }
+
+}