/**
 * Version 2.1
 * CeCILL Copyright (c) 2006-2009, AtolCD, ADULLACT-projet
 * Initiated by AtolCD S.A. & ADULLACT-projet S.A.
 * Developped by AtolCD S.A. & ADULLACT-projet S.A.
 * 
 * contact@atolcd.com
 * contact@adullact-projet.coop
 * 
 * Ce logiciel est un programme informatique servant à faire circuler des 
 * documents au travers d'un circuit de validation, où chaque acteur vise 
 * le dossier, jusqu'à l'étape finale de signature.
 * 
 * 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.atolcd.parapheur.repo;

import java.io.IOException;

import org.alfresco.repo.security.authentication.AuthenticationComponent;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.Job;
import org.quartz.JobDataMap;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

/**
 * @author svast
 * 
 */
public class S2lowHeliosQuartzJob implements Job
{
    /** Used for running the initialization code or not; if true, initialization is complete */
    private static boolean initialized = false;
    /** Used for logging */
    private static Log logger = LogFactory.getLog(S2lowHeliosQuartzJob.class);
    /** Alfresco Service Registry - used for finding necessary Alfresco services */
    /** Alfresco AuthenticationComponent object - used for being able to run as the system admin */
    private static AuthenticationComponent authenticationComponent;
    /** iParapheur S2lowService */
    private static S2lowService s2lowService;

    /**
     * The main method. Runs at intervals defined in scheduled-jobs-context.xml (repeatInterval)
     * 
     * @see org.quartz.Job#execute(org.quartz.JobExecutionContext)
     */
    @Override
    public void execute(JobExecutionContext context) throws JobExecutionException
    {
	initialize(context);
	// After this, Alfresco services will think that the system admin is running this code
	// logger.debug("setSystemUserAsCurrentUser");
	authenticationComponent.setSystemUserAsCurrentUser();
	// Now do the job
	try
	{
	    logger.debug("Call getS2lowHeliosListePES_Retour");
	    s2lowService.getS2lowHeliosListePES_Retour();
	} catch (IOException e)
	{
	    // TODO Auto-generated catch block
	    e.printStackTrace();
	}
    }

    /**
     * Finds necessary services and the company home node
     * 
     * @param context
     *                The JobExecutionContext, used for getting the necessary beans from the config file
     *                (scheduled-jobs-context.xml)
     */
    private void initialize(JobExecutionContext context)
    {
	if (!initialized)
	{
	    logger.debug("initialize");
	    JobDataMap jobData = context.getJobDetail().getJobDataMap();

	    Object authenticationComponentObj = jobData.get("authenticationComponent");
	    authenticationComponent = (AuthenticationComponent) authenticationComponentObj;

	    s2lowService = (S2lowService) jobData.get("s2lowService");
	    authenticationComponent.setSystemUserAsCurrentUser();
	    
	    initialized = true;
	}
    }
}
