This project has retired. For details please refer to its Attic page.
Source code
001package org.apache.archiva.scheduler.repository;
002
003/*
004 * Licensed to the Apache Software Foundation (ASF) under one
005 * or more contributor license agreements.  See the NOTICE file
006 * distributed with this work for additional information
007 * regarding copyright ownership.  The ASF licenses this file
008 * to you under the Apache License, Version 2.0 (the
009 * "License"); you may not use this file except in compliance
010 * with the License.  You may obtain a copy of the License at
011 *
012 *   http://www.apache.org/licenses/LICENSE-2.0
013 *
014 * Unless required by applicable law or agreed to in writing,
015 * software distributed under the License is distributed on an
016 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
017 * KIND, either express or implied.  See the License for the
018 * specific language governing permissions and limitations
019 * under the License.
020 */
021
022import org.apache.archiva.redback.components.scheduler.AbstractJob;
023import org.apache.archiva.redback.components.taskqueue.TaskQueue;
024import org.apache.archiva.redback.components.taskqueue.TaskQueueException;
025import org.apache.archiva.scheduler.repository.model.RepositoryTask;
026import org.quartz.JobDataMap;
027import org.quartz.JobExecutionContext;
028import org.quartz.JobExecutionException;
029
030/**
031 * This class is the repository job that is executed by the scheduler.
032 */
033public class RepositoryTaskJob
034    extends AbstractJob
035{
036    /**
037     * Execute the discoverer and the indexer.
038     * 
039     * @param context
040     * @throws org.quartz.JobExecutionException
041     */
042    @Override
043    public void execute( JobExecutionContext context )
044        throws JobExecutionException
045    {
046        JobDataMap dataMap = context.getJobDetail().getJobDataMap();
047        setJobDataMap( dataMap );
048
049        TaskQueue taskQueue = (TaskQueue) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_QUEUE );
050
051        String repositoryId = (String) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_REPOSITORY );
052        RepositoryTask task = new RepositoryTask();
053        task.setRepositoryId( repositoryId );
054
055        try
056        {
057            taskQueue.put( task );
058        }
059        catch ( TaskQueueException e )
060        {
061            throw new JobExecutionException( e );
062        }
063    }
064}