]> source.dussan.org Git - archiva.git/commitdiff
start refactoring merging remote indexes to have a cron job doing it
authorOlivier Lamy <olamy@apache.org>
Mon, 16 Dec 2013 06:53:37 +0000 (06:53 +0000)
committerOlivier Lamy <olamy@apache.org>
Mon, 16 Dec 2013 06:53:37 +0000 (06:53 +0000)
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1551123 13f79535-47bb-0310-9956-ffa450edef68

archiva-modules/archiva-base/archiva-indexer/src/main/java/org/apache/archiva/indexer/merger/MergedRemoteIndexesTaskJob.java [new file with mode: 0644]

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 (file)
index 0000000..5fe7488
--- /dev/null
@@ -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;
+        }
+    }
+}