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.model.superpom;
20  
21  import javax.inject.Inject;
22  import javax.inject.Named;
23  import javax.inject.Singleton;
24  
25  import java.io.IOException;
26  import java.io.InputStream;
27  import java.util.HashMap;
28  import java.util.Map;
29  import java.util.Objects;
30  import java.util.concurrent.ConcurrentHashMap;
31  
32  import org.apache.maven.api.model.InputSource;
33  import org.apache.maven.model.Model;
34  import org.apache.maven.model.building.ModelProcessor;
35  
36  /**
37   * Provides the super POM that all models implicitly inherit from.
38   *
39   */
40  @Named
41  @Singleton
42  public class DefaultSuperPomProvider implements SuperPomProvider {
43  
44      private final ModelProcessor modelProcessor;
45  
46      /**
47       * The cached super POM, lazily created.
48       */
49      private static final Map<String, Model> SUPER_MODELS = new ConcurrentHashMap<>();
50  
51      @Inject
52      public DefaultSuperPomProvider(ModelProcessor modelProcessor) {
53          this.modelProcessor = modelProcessor;
54      }
55  
56      @Override
57      public Model getSuperModel(String version) {
58          return SUPER_MODELS.computeIfAbsent(Objects.requireNonNull(version), v -> {
59              String resource = "/org/apache/maven/model/pom-" + v + ".xml";
60  
61              InputStream is = getClass().getResourceAsStream(resource);
62  
63              if (is == null) {
64                  throw new IllegalStateException("The super POM " + resource + " was not found"
65                          + ", please verify the integrity of your Maven installation");
66              }
67  
68              try {
69                  Map<String, Object> options = new HashMap<>(2);
70                  options.put("xml:" + version, "xml:" + version);
71  
72                  String modelId = "org.apache.maven:maven-model-builder:" + version + "-"
73                          + this.getClass().getPackage().getImplementationVersion() + ":super-pom";
74                  InputSource inputSource = new InputSource(
75                          modelId, getClass().getResource(resource).toExternalForm());
76                  options.put(ModelProcessor.INPUT_SOURCE, new org.apache.maven.model.InputSource(inputSource));
77  
78                  return modelProcessor.read(is, options);
79              } catch (IOException e) {
80                  throw new IllegalStateException(
81                          "The super POM " + resource + " is damaged"
82                                  + ", please verify the integrity of your Maven installation",
83                          e);
84              }
85          });
86      }
87  }