aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationEvent.java16
-rw-r--r--archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationFeature.java85
2 files changed, 90 insertions, 11 deletions
diff --git a/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationEvent.java b/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationEvent.java
index 4c9dc8eae..49a3d444a 100644
--- a/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationEvent.java
+++ b/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationEvent.java
@@ -27,10 +27,22 @@ import java.net.URI;
public class IndexCreationEvent extends RepositoryEvent<URI> {
public enum Index implements EventType {
- URI_CHANGE
+ INDEX_URI_CHANGE, PACKED_INDEX_URI_CHANGE
}
IndexCreationEvent(Repository repo, URI oldValue, URI value) {
- super(Index.URI_CHANGE, repo, oldValue, value);
+ super(Index.INDEX_URI_CHANGE, repo, oldValue, value);
+ }
+
+ IndexCreationEvent(Index type, Repository repo, URI oldValue, URI value) {
+ super(type, repo, oldValue, value);
+ }
+
+ public static final IndexCreationEvent indexUriChange(Repository repo, URI oldValue, URI newValue) {
+ return new IndexCreationEvent(Index.INDEX_URI_CHANGE, repo, oldValue, newValue);
+ }
+
+ public static final IndexCreationEvent packedIndexUriChange(Repository repo, URI oldValue, URI newValue) {
+ return new IndexCreationEvent(Index.PACKED_INDEX_URI_CHANGE, repo, oldValue, newValue);
}
}
diff --git a/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationFeature.java b/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationFeature.java
index 0aa44a20b..6289cc651 100644
--- a/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationFeature.java
+++ b/archiva-modules/archiva-base/archiva-repository-api/src/main/java/org/apache/archiva/repository/features/IndexCreationFeature.java
@@ -38,31 +38,42 @@ import java.util.List;
*/
public class IndexCreationFeature extends AbstractFeature implements RepositoryFeature<IndexCreationFeature>{
+ public static final String DEFAULT_INDEX_PATH = ".indexer";
+ public static final String DEFAULT_PACKED_INDEX_PATH = ".index";
private boolean skipPackedIndexCreation = false;
private URI indexPath;
+ private URI packedIndexPath;
+
private Path localIndexPath;
+ private Path localPackedIndexPath;
+
private Repository repo;
public IndexCreationFeature(Repository repoId, RepositoryEventListener listener) {
super(listener);
this.repo = repoId;
- try
- {
- setIndexPath(new URI(".indexer"));
- }
- catch ( URISyntaxException e )
- {
- // This may not happen.
- e.printStackTrace( );
+ try {
+ this.indexPath = new URI(DEFAULT_INDEX_PATH);
+ this.packedIndexPath = new URI(DEFAULT_PACKED_INDEX_PATH);
+ } catch (URISyntaxException e) {
+ // Does not happen
+ e.printStackTrace();
}
}
public IndexCreationFeature(boolean skipPackedIndexCreation) {
this.skipPackedIndexCreation = skipPackedIndexCreation;
+ try {
+ this.indexPath = new URI(DEFAULT_INDEX_PATH);
+ this.packedIndexPath = new URI(DEFAULT_PACKED_INDEX_PATH);
+ } catch (URISyntaxException e) {
+ // Does not happen
+ e.printStackTrace();
+ }
}
@Override
@@ -104,7 +115,7 @@ public class IndexCreationFeature extends AbstractFeature implements RepositoryF
{
URI oldVal = this.indexPath;
this.indexPath = indexPath;
- raiseEvent(new IndexCreationEvent(repo, oldVal, this.indexPath));
+ raiseEvent(IndexCreationEvent.indexUriChange(repo, oldVal, this.indexPath));
}
@@ -113,11 +124,67 @@ public class IndexCreationFeature extends AbstractFeature implements RepositoryF
return this.indexPath!=null && !StringUtils.isEmpty( this.indexPath.getPath() );
}
+ /**
+ * Returns the path where the index is stored physically.
+ *
+ * @return
+ */
public Path getLocalIndexPath() {
return localIndexPath;
}
+ /**
+ * Sets the path where the index is stored physically. This method should only be used by the
+ * MavenIndexProvider implementations.
+ *
+ * @param localIndexPath
+ */
public void setLocalIndexPath(Path localIndexPath) {
this.localIndexPath = localIndexPath;
}
+
+
+ /**
+ * Returns the path of the packed index.
+ * @return
+ */
+ public URI getPackedIndexPath() {
+ return packedIndexPath;
+ }
+
+ /**
+ * Sets the path (relative or absolute) of the packed index.
+ * @param packedIndexPath
+ */
+ public void setPackedIndexPath(URI packedIndexPath) {
+ URI oldVal = this.packedIndexPath;
+ this.packedIndexPath = packedIndexPath;
+ raiseEvent(IndexCreationEvent.packedIndexUriChange(repo, oldVal, this.packedIndexPath));
+ }
+
+ /**
+ * Returns the directory where the packed index is stored.
+ * @return
+ */
+ public Path getLocalPackedIndexPath() {
+ return localPackedIndexPath;
+ }
+
+ /**
+ * Sets the path where the packed index is stored physically. This method should only be used by the
+ * MavenIndexProvider implementations.
+ *
+ * @param localPackedIndexPath
+ */
+ public void setLocalPackedIndexPath(Path localPackedIndexPath) {
+ this.localPackedIndexPath = localPackedIndexPath;
+ }
+
+ @Override
+ public String toString() {
+ StringBuilder sb = new StringBuilder();
+ sb.append("IndexCreationFeature:{").append("skipPackedIndexCreation=").append(skipPackedIndexCreation)
+ .append(",indexPath=").append(indexPath).append(",packedIndexPath=").append(packedIndexPath).append("}");
+ return sb.toString();
+ }
}