View Javadoc
1   /*
2    * Licensed to the Apache Software Foundation (ASF) under one
3    * or more contributor license agreements.  See the NOTICE file
4    * distributed with this work for additional information
5    * regarding copyright ownership.  The ASF licenses this file
6    * to you under the Apache License, Version 2.0 (the
7    * "License"); you may not use this file except in compliance
8    * with the License.  You may obtain a copy of the License at
9    *
10   *   http://www.apache.org/licenses/LICENSE-2.0
11   *
12   * Unless required by applicable law or agreed to in writing,
13   * software distributed under the License is distributed on an
14   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15   * KIND, either express or implied.  See the License for the
16   * specific language governing permissions and limitations
17   * under the License.
18   */
19  package org.apache.maven.repository.internal;
20  
21  import java.util.Collection;
22  import java.util.Collections;
23  import java.util.Date;
24  import java.util.LinkedHashMap;
25  import java.util.Map;
26  
27  import org.eclipse.aether.RepositorySystemSession;
28  import org.eclipse.aether.artifact.Artifact;
29  import org.eclipse.aether.deployment.DeployRequest;
30  import org.eclipse.aether.impl.MetadataGenerator;
31  import org.eclipse.aether.metadata.Metadata;
32  import org.eclipse.aether.util.ConfigUtils;
33  
34  /**
35   * Maven remote GAV level metadata generator.
36   * <p>
37   * Remote snapshot metadata converts artifact on-the-fly to use timestamped snapshot version, and enlist it accordingly.
38   */
39  class RemoteSnapshotMetadataGenerator implements MetadataGenerator {
40  
41      private final Map<Object, RemoteSnapshotMetadata> snapshots;
42  
43      private final Date timestamp;
44  
45      RemoteSnapshotMetadataGenerator(RepositorySystemSession session, DeployRequest request) {
46          timestamp = (Date) ConfigUtils.getObject(session, new Date(), "maven.startTime");
47  
48          snapshots = new LinkedHashMap<>();
49  
50          /*
51           * NOTE: This should be considered a quirk to support interop with Maven's legacy ArtifactDeployer which
52           * processes one artifact at a time and hence cannot associate the artifacts from the same project to use the
53           * same timestamp+buildno for the snapshot versions. Allowing the caller to pass in metadata from a previous
54           * deployment allows to re-establish the association between the artifacts of the same project.
55           */
56          for (Metadata metadata : request.getMetadata()) {
57              if (metadata instanceof RemoteSnapshotMetadata) {
58                  RemoteSnapshotMetadata snapshotMetadata = (RemoteSnapshotMetadata) metadata;
59                  snapshots.put(snapshotMetadata.getKey(), snapshotMetadata);
60              }
61          }
62      }
63  
64      @Override
65      public Collection<? extends Metadata> prepare(Collection<? extends Artifact> artifacts) {
66          for (Artifact artifact : artifacts) {
67              if (artifact.isSnapshot()) {
68                  Object key = RemoteSnapshotMetadata.getKey(artifact);
69                  RemoteSnapshotMetadata snapshotMetadata = snapshots.get(key);
70                  if (snapshotMetadata == null) {
71                      snapshotMetadata = new RemoteSnapshotMetadata(artifact, timestamp);
72                      snapshots.put(key, snapshotMetadata);
73                  }
74                  snapshotMetadata.bind(artifact);
75              }
76          }
77  
78          return snapshots.values();
79      }
80  
81      @Override
82      public Artifact transformArtifact(Artifact artifact) {
83          if (artifact.isSnapshot() && artifact.getVersion().equals(artifact.getBaseVersion())) {
84              Object key = RemoteSnapshotMetadata.getKey(artifact);
85              RemoteSnapshotMetadata snapshotMetadata = snapshots.get(key);
86              if (snapshotMetadata != null) {
87                  artifact = artifact.setVersion(snapshotMetadata.getExpandedVersion(artifact));
88              }
89          }
90  
91          return artifact;
92      }
93  
94      @Override
95      public Collection<? extends Metadata> finish(Collection<? extends Artifact> artifacts) {
96          return Collections.emptyList();
97      }
98  }