You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RepositoryContent.java 1.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package org.apache.archiva.repository;
  2. /*
  3. * Licensed to the Apache Software Foundation (ASF) under one
  4. * or more contributor license agreements. See the NOTICE file
  5. * distributed with this work for additional information
  6. * regarding copyright ownership. The ASF licenses this file
  7. * to you under the Apache License, Version 2.0 (the
  8. * "License"); you may not use this file except in compliance
  9. * with the License. You may obtain a copy of the License at
  10. *
  11. * http://www.apache.org/licenses/LICENSE-2.0
  12. *
  13. * Unless required by applicable law or agreed to in writing,
  14. * software distributed under the License is distributed on an
  15. * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
  16. * KIND, either express or implied. See the License for the
  17. * specific language governing permissions and limitations
  18. * under the License.
  19. */
  20. import org.apache.archiva.model.ArtifactReference;
  21. import org.apache.archiva.model.VersionedReference;
  22. /**
  23. * Common aspects of content provider interfaces
  24. */
  25. public interface RepositoryContent
  26. {
  27. /**
  28. * Given a repository relative path to a filename, return the {@link VersionedReference} object suitable for the path.
  29. *
  30. * @param path the path relative to the repository base dir for the artifact.
  31. * @return the {@link ArtifactReference} representing the path. (or null if path cannot be converted to
  32. * a {@link ArtifactReference})
  33. * @throws LayoutException if there was a problem converting the path to an artifact.
  34. */
  35. ArtifactReference toArtifactReference( String path )
  36. throws LayoutException;
  37. /**
  38. * Given an {@link ArtifactReference}, return the relative path to the artifact.
  39. *
  40. * @param reference the artifact reference to use.
  41. * @return the relative path to the artifact.
  42. */
  43. String toPath( ArtifactReference reference );
  44. }