summaryrefslogtreecommitdiffstats
path: root/archiva-modules/archiva-base
diff options
context:
space:
mode:
authorOlivier Lamy <olamy@apache.org>2013-12-16 06:53:37 +0000
committerOlivier Lamy <olamy@apache.org>2013-12-16 06:53:37 +0000
commit56d48bd36ebbf29679fb32bb050504a1c4e50230 (patch)
treeff254d8a42062370116de7f49dfe7293f924da02 /archiva-modules/archiva-base
parent28898793f51c03b1259d3a1b1f1612f450cf634c (diff)
downloadarchiva-56d48bd36ebbf29679fb32bb050504a1c4e50230.tar.gz
archiva-56d48bd36ebbf29679fb32bb050504a1c4e50230.zip
start refactoring merging remote indexes to have a cron job doing it
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1551123 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'archiva-modules/archiva-base')
-rw-r--r--archiva-modules/archiva-base/archiva-indexer/src/main/java/org/apache/archiva/indexer/merger/MergedRemoteIndexesTaskJob.java111
1 files changed, 111 insertions, 0 deletions
diff --git a/archiva-modules/archiva-base/archiva-indexer/src/main/java/org/apache/archiva/indexer/merger/MergedRemoteIndexesTaskJob.java b/archiva-modules/archiva-base/archiva-indexer/src/main/java/org/apache/archiva/indexer/merger/MergedRemoteIndexesTaskJob.java
new file mode 100644
index 000000000..5fe748871
--- /dev/null
+++ b/archiva-modules/archiva-base/archiva-indexer/src/main/java/org/apache/archiva/indexer/merger/MergedRemoteIndexesTaskJob.java
@@ -0,0 +1,111 @@
+package org.apache.archiva.indexer.merger;
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ */
+
+import org.apache.archiva.redback.components.scheduler.AbstractJob;
+import org.apache.maven.index.context.IndexingContext;
+import org.quartz.JobExecutionContext;
+import org.quartz.JobExecutionException;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.io.File;
+
+/**
+ * @author Olivier Lamy
+ * @since 2.0.0
+ */
+public class MergedRemoteIndexesTaskJob
+ extends AbstractJob
+{
+
+ private Logger logger = LoggerFactory.getLogger( getClass() );
+
+ @Override
+ public void execute( JobExecutionContext context )
+ throws JobExecutionException
+ {
+
+ }
+
+ public MergedRemoteIndexesTaskResult execute( MergedRemoteIndexesTaskRequest mergedRemoteIndexesTaskRequest )
+ throws IndexMergerException
+ {
+ IndexMerger indexMerger = mergedRemoteIndexesTaskRequest.indexMerger;
+
+ IndexingContext indexingContext =
+ indexMerger.buildMergedIndex( mergedRemoteIndexesTaskRequest.indexMergerRequest );
+
+ return new MergedRemoteIndexesTaskResult( indexingContext );
+ }
+
+ public static class MergedRemoteIndexesTaskRequest
+ {
+ private IndexMergerRequest indexMergerRequest;
+
+ private IndexMerger indexMerger;
+
+ public MergedRemoteIndexesTaskRequest( IndexMergerRequest indexMergerRequest, IndexMerger indexMerger )
+ {
+ this.indexMergerRequest = indexMergerRequest;
+ this.indexMerger = indexMerger;
+ }
+
+ public IndexMergerRequest getIndexMergerRequest()
+ {
+ return indexMergerRequest;
+ }
+
+ public void setIndexMergerRequest( IndexMergerRequest indexMergerRequest )
+ {
+ this.indexMergerRequest = indexMergerRequest;
+ }
+
+ public IndexMerger getIndexMerger()
+ {
+ return indexMerger;
+ }
+
+ public void setIndexMerger( IndexMerger indexMerger )
+ {
+ this.indexMerger = indexMerger;
+ }
+ }
+
+ public static class MergedRemoteIndexesTaskResult
+ {
+ private IndexingContext indexingContext;
+
+ public MergedRemoteIndexesTaskResult( IndexingContext indexingContext )
+ {
+ this.indexingContext = indexingContext;
+ }
+
+ public IndexingContext getIndexingContext()
+ {
+ return indexingContext;
+ }
+
+ public void setIndexingContext( IndexingContext indexingContext )
+ {
+ this.indexingContext = indexingContext;
+ }
+ }
+}