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.components.scheduler.AbstractJob;
023import org.apache.archiva.components.taskqueue.TaskQueue;
024import org.apache.archiva.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    @SuppressWarnings( "unchecked" )
043    @Override
044    public void execute( JobExecutionContext context )
045        throws JobExecutionException
046    {
047        JobDataMap dataMap = context.getJobDetail().getJobDataMap();
048        setJobDataMap( dataMap );
049
050        TaskQueue taskQueue = (TaskQueue) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_QUEUE );
051
052        String repositoryId = (String) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_REPOSITORY );
053        RepositoryTask task = new RepositoryTask();
054        task.setRepositoryId( repositoryId );
055
056        try
057        {
058            taskQueue.put( task );
059        }
060        catch ( TaskQueueException e )
061        {
062            throw new JobExecutionException( e );
063        }
064    }
065}