This project has retired. For details please refer to its
Attic page.
AbstractDefaultRepositoryContent xref
1 package org.apache.archiva.repository.content.maven2;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22 import org.apache.archiva.common.utils.VersionUtil;
23 import org.apache.archiva.metadata.repository.storage.RepositoryPathTranslator;
24 import org.apache.archiva.metadata.repository.storage.maven2.ArtifactMappingProvider;
25 import org.apache.archiva.metadata.repository.storage.maven2.Maven2RepositoryPathTranslator;
26 import org.apache.archiva.model.ArchivaArtifact;
27 import org.apache.archiva.model.ArtifactReference;
28 import org.apache.archiva.model.ProjectReference;
29 import org.apache.archiva.model.VersionedReference;
30 import org.apache.archiva.repository.content.PathParser;
31 import org.apache.archiva.repository.layout.LayoutException;
32 import org.apache.commons.lang.StringUtils;
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
35
36 import javax.annotation.PostConstruct;
37 import javax.inject.Inject;
38 import java.util.List;
39
40
41
42
43 public abstract class AbstractDefaultRepositoryContent
44 {
45 protected Logger log = LoggerFactory.getLogger( getClass() );
46
47 public static final String MAVEN_METADATA = "maven-metadata.xml";
48
49 protected static final char PATH_SEPARATOR = '/';
50
51 protected static final char GROUP_SEPARATOR = '.';
52
53 protected static final char ARTIFACT_SEPARATOR = '-';
54
55 private RepositoryPathTranslator pathTranslator = new Maven2RepositoryPathTranslator();
56
57 private PathParser defaultPathParser = new DefaultPathParser();
58
59
60
61
62 @Inject
63 protected List<? extends ArtifactMappingProvider> artifactMappingProviders;
64
65 @PostConstruct
66 protected void initialize()
67 {
68
69 }
70
71 public ArtifactReference toArtifactReference( String path )
72 throws LayoutException
73 {
74 return defaultPathParser.toArtifactReference( path );
75 }
76
77 public String toMetadataPath( ProjectReference reference )
78 {
79 StringBuilder path = new StringBuilder();
80
81 path.append( formatAsDirectory( reference.getGroupId() ) ).append( PATH_SEPARATOR );
82 path.append( reference.getArtifactId() ).append( PATH_SEPARATOR );
83 path.append( MAVEN_METADATA );
84
85 return path.toString();
86 }
87
88 public String toMetadataPath( VersionedReference reference )
89 {
90 StringBuilder path = new StringBuilder();
91
92 path.append( formatAsDirectory( reference.getGroupId() ) ).append( PATH_SEPARATOR );
93 path.append( reference.getArtifactId() ).append( PATH_SEPARATOR );
94 if ( reference.getVersion() != null )
95 {
96
97 path.append( VersionUtil.getBaseVersion( reference.getVersion() ) ).append( PATH_SEPARATOR );
98 }
99 path.append( MAVEN_METADATA );
100
101 return path.toString();
102 }
103
104 public String toPath( ArchivaArtifact reference )
105 {
106 if ( reference == null )
107 {
108 throw new IllegalArgumentException( "ArchivaArtifact cannot be null" );
109 }
110
111 String baseVersion = VersionUtil.getBaseVersion( reference.getVersion() );
112 return toPath( reference.getGroupId(), reference.getArtifactId(), baseVersion, reference.getVersion(),
113 reference.getClassifier(), reference.getType() );
114 }
115
116 public String toPath( ArtifactReference reference )
117 {
118 if ( reference == null )
119 {
120 throw new IllegalArgumentException( "Artifact reference cannot be null" );
121 }
122 if ( reference.getVersion() != null )
123 {
124 String baseVersion = VersionUtil.getBaseVersion( reference.getVersion() );
125 return toPath( reference.getGroupId(), reference.getArtifactId(), baseVersion, reference.getVersion(),
126 reference.getClassifier(), reference.getType() );
127 }
128 return toPath( reference.getGroupId(), reference.getArtifactId(), null, null,
129 reference.getClassifier(), reference.getType() );
130 }
131
132 private String formatAsDirectory( String directory )
133 {
134 return directory.replace( GROUP_SEPARATOR, PATH_SEPARATOR );
135 }
136
137 private String toPath( String groupId, String artifactId, String baseVersion, String version, String classifier,
138 String type )
139 {
140 if ( baseVersion != null )
141 {
142 return pathTranslator.toPath( groupId, artifactId, baseVersion,
143 constructId( artifactId, version, classifier, type ) );
144 }
145 else
146 {
147 return pathTranslator.toPath( groupId, artifactId );
148 }
149 }
150
151
152
153 private String constructId( String artifactId, String version, String classifier, String type )
154 {
155 String ext = null;
156 for ( ArtifactMappingProvider provider : artifactMappingProviders )
157 {
158 ext = provider.mapTypeToExtension( type );
159 if ( ext != null )
160 {
161 break;
162 }
163 }
164 if ( ext == null )
165 {
166 ext = type;
167 }
168
169 StringBuilder id = new StringBuilder();
170 if ( ( version != null ) && ( type != null ) )
171 {
172 id.append( artifactId ).append( ARTIFACT_SEPARATOR ).append( version );
173
174 if ( StringUtils.isNotBlank( classifier ) )
175 {
176 id.append( ARTIFACT_SEPARATOR ).append( classifier );
177 }
178
179 id.append( "." ).append( ext );
180 }
181 return id.toString();
182 }
183 }