001/*
002 *  Copyright 2016 Anyware Services
003 *
004 *  Licensed under the Apache License, Version 2.0 (the "License");
005 *  you may not use this file except in compliance with the License.
006 *  You may obtain a copy of the License at
007 *
008 *      http://www.apache.org/licenses/LICENSE-2.0
009 *
010 *  Unless required by applicable law or agreed to in writing, software
011 *  distributed under the License is distributed on an "AS IS" BASIS,
012 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 *  See the License for the specific language governing permissions and
014 *  limitations under the License.
015 */
016package org.ametys.plugins.contentio.synchronize;
017
018import org.apache.avalon.framework.service.ServiceException;
019import org.apache.avalon.framework.service.ServiceManager;
020import org.quartz.JobExecutionContext;
021
022import org.ametys.core.schedule.Schedulable;
023import org.ametys.plugins.core.impl.schedule.AbstractStaticSchedulable;
024
025/**
026 * A {@link Schedulable} job which synchronizes all collections of contents from a datasource.
027 */
028public class SynchronizeAllCollectionsSchedulable extends AbstractStaticSchedulable
029{
030    private SynchronizableContentsCollectionDAO _synchronizableContentsCollectionDAO;
031    
032    @Override
033    public void service(ServiceManager manager) throws ServiceException
034    {
035        super.service(manager);
036        _synchronizableContentsCollectionDAO = (SynchronizableContentsCollectionDAO) manager.lookup(SynchronizableContentsCollectionDAO.ROLE);
037    }
038    
039    @Override
040    public void execute(JobExecutionContext context) throws Exception
041    {
042        for (SynchronizableContentsCollection collection : _synchronizableContentsCollectionDAO.getSynchronizableContentsCollections())
043        {
044            collection.populate(getLogger());
045        }
046    }
047}