1package org.apache.archiva.scheduler.repository;
23/*4 * Licensed to the Apache Software Foundation (ASF) under one5 * or more contributor license agreements. See the NOTICE file6 * distributed with this work for additional information7 * regarding copyright ownership. The ASF licenses this file8 * to you under the Apache License, Version 2.0 (the9 * "License"); you may not use this file except in compliance10 * with the License. You may obtain a copy of the License at11 *12 * http://www.apache.org/licenses/LICENSE-2.013 *14 * Unless required by applicable law or agreed to in writing,15 * software distributed under the License is distributed on an16 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY17 * KIND, either express or implied. See the License for the18 * specific language governing permissions and limitations19 * under the License.20 */2122import org.apache.archiva.components.scheduler.AbstractJob;
23import org.apache.archiva.components.taskqueue.TaskQueue;
24import org.apache.archiva.components.taskqueue.TaskQueueException;
25import org.apache.archiva.scheduler.repository.model.RepositoryTask;
26import org.quartz.JobDataMap;
27import org.quartz.JobExecutionContext;
28import org.quartz.JobExecutionException;
2930/**31 * This class is the repository job that is executed by the scheduler.32 */33publicclassRepositoryTaskJob34extends AbstractJob
35 {
36/**37 * Execute the discoverer and the indexer.38 * 39 * @param context40 * @throws org.quartz.JobExecutionException41 */42 @SuppressWarnings( "unchecked" )
43 @Override
44publicvoid execute( JobExecutionContext context )
45throws JobExecutionException
46 {
47 JobDataMap dataMap = context.getJobDetail().getJobDataMap();
48 setJobDataMap( dataMap );
4950 TaskQueue taskQueue = (TaskQueue) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_QUEUE );
5152 String repositoryId = (String) dataMap.get( DefaultRepositoryArchivaTaskScheduler.TASK_REPOSITORY );
53RepositoryTaskpository/model/RepositoryTask.html#RepositoryTask">RepositoryTask task = newRepositoryTask();
54 task.setRepositoryId( repositoryId );
5556try57 {
58 taskQueue.put( task );
59 }
60catch ( TaskQueueException e )
61 {
62thrownew JobExecutionException( e );
63 }
64 }
65 }