Classes in this File | Line Coverage | Branch Coverage | Complexity | ||||
EarModuleFactory |
|
| 8.666666666666666;8.667 |
1 | package org.apache.maven.plugin.ear; | |
2 | ||
3 | /* | |
4 | * Licensed to the Apache Software Foundation (ASF) under one | |
5 | * or more contributor license agreements. See the NOTICE file | |
6 | * distributed with this work for additional information | |
7 | * regarding copyright ownership. The ASF licenses this file | |
8 | * to you under the Apache License, Version 2.0 (the | |
9 | * "License"); you may not use this file except in compliance | |
10 | * with the License. You may obtain a copy of the License at | |
11 | * | |
12 | * http://www.apache.org/licenses/LICENSE-2.0 | |
13 | * | |
14 | * Unless required by applicable law or agreed to in writing, | |
15 | * software distributed under the License is distributed on an | |
16 | * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | |
17 | * KIND, either express or implied. See the License for the | |
18 | * specific language governing permissions and limitations | |
19 | * under the License. | |
20 | */ | |
21 | ||
22 | import org.apache.maven.artifact.Artifact; | |
23 | import org.apache.maven.plugin.ear.util.ArtifactTypeMappingService; | |
24 | import org.apache.maven.plugin.ear.util.JavaEEVersion; | |
25 | ||
26 | import java.util.ArrayList; | |
27 | import java.util.Collections; | |
28 | import java.util.List; | |
29 | ||
30 | /** | |
31 | * Builds an {@link EarModule} based on an <tt>Artifact</tt>. | |
32 | * | |
33 | * @author <a href="snicoll@apache.org">Stephane Nicoll</a> | |
34 | * @version $Id: EarModuleFactory.java 1050900 2010-12-19 17:10:52Z snicoll $ | |
35 | */ | |
36 | 0 | public final class EarModuleFactory |
37 | { | |
38 | public final static List standardArtifactTypes; | |
39 | ||
40 | static | |
41 | { | |
42 | 0 | List temp = new ArrayList(); |
43 | 0 | temp.add( "jar" ); |
44 | 0 | temp.add( "ejb" ); |
45 | 0 | temp.add( "ejb3" ); |
46 | 0 | temp.add( "par" ); |
47 | 0 | temp.add( "ejb-client" ); |
48 | 0 | temp.add( "rar" ); |
49 | 0 | temp.add( "war" ); |
50 | 0 | temp.add( "sar" ); |
51 | 0 | temp.add( "wsr" ); |
52 | 0 | temp.add( "har" ); |
53 | 0 | standardArtifactTypes = Collections.unmodifiableList( temp ); |
54 | 0 | } |
55 | ||
56 | /** | |
57 | * Creates a new {@link EarModule} based on the | |
58 | * specified {@link Artifact} and the specified | |
59 | * execution configuration. | |
60 | * | |
61 | * @param artifact the artifact | |
62 | * @param javaEEVersion the javaEE version to use | |
63 | * @param defaultLibBundleDir the default bundle dir for {@link org.apache.maven.plugin.ear.JarModule} | |
64 | * @param includeInApplicationXml should {@link org.apache.maven.plugin.ear.JarModule} be included in application Xml | |
65 | * @param typeMappingService The artifact type mapping service | |
66 | * @return an ear module for this artifact | |
67 | * @throws UnknownArtifactTypeException if the artifact is not handled | |
68 | */ | |
69 | public static EarModule newEarModule( Artifact artifact, JavaEEVersion javaEEVersion, String defaultLibBundleDir, | |
70 | Boolean includeInApplicationXml, | |
71 | ArtifactTypeMappingService typeMappingService ) | |
72 | throws UnknownArtifactTypeException | |
73 | { | |
74 | // Get the standard artifact type based on default config and user-defined mapping(s) | |
75 | 0 | final String artifactType = typeMappingService.getStandardType( artifact.getType() ); |
76 | ||
77 | 0 | if ( "jar".equals( artifactType ) ) |
78 | { | |
79 | 0 | return new JarModule( artifact, defaultLibBundleDir, includeInApplicationXml ); |
80 | } | |
81 | 0 | else if ( "ejb".equals( artifactType ) ) |
82 | { | |
83 | 0 | return new EjbModule( artifact ); |
84 | } | |
85 | 0 | else if ( "ejb3".equals( artifactType ) ) |
86 | { | |
87 | 0 | return new Ejb3Module( artifact ); |
88 | } | |
89 | 0 | else if ( "par".equals( artifactType ) ) |
90 | { | |
91 | 0 | return new ParModule( artifact ); |
92 | } | |
93 | 0 | else if ( "ejb-client".equals( artifactType ) ) |
94 | { | |
95 | // Somewhat weird way to tackle the problem described in MEAR-85 | |
96 | 0 | if ( javaEEVersion.le( JavaEEVersion.OneDotFour ) ) |
97 | { | |
98 | 0 | return new EjbClientModule( artifact, null ); |
99 | } | |
100 | else | |
101 | { | |
102 | 0 | return new EjbClientModule( artifact, defaultLibBundleDir ); |
103 | } | |
104 | } | |
105 | 0 | else if ( "rar".equals( artifactType ) ) |
106 | { | |
107 | 0 | return new RarModule( artifact ); |
108 | } | |
109 | 0 | else if ( "war".equals( artifactType ) ) |
110 | { | |
111 | 0 | return new WebModule( artifact ); |
112 | } | |
113 | 0 | else if ( "sar".equals( artifactType ) ) |
114 | { | |
115 | 0 | return new SarModule( artifact ); |
116 | } | |
117 | 0 | else if ( "wsr".equals( artifactType ) ) |
118 | { | |
119 | 0 | return new WsrModule( artifact ); |
120 | } | |
121 | 0 | else if ( "har".equals( artifactType ) ) |
122 | { | |
123 | 0 | return new HarModule( artifact ); |
124 | } | |
125 | else | |
126 | { | |
127 | 0 | throw new IllegalStateException( "Could not handle artifact type[" + artifactType + "]" ); |
128 | } | |
129 | } | |
130 | ||
131 | /** | |
132 | * Returns a list of standard artifact types. | |
133 | * | |
134 | * @return the standard artifact types | |
135 | */ | |
136 | public static List getStandardArtifactTypes() | |
137 | { | |
138 | 0 | return standardArtifactTypes; |
139 | } | |
140 | ||
141 | /** | |
142 | * Specify whether the specified type is standard artifact | |
143 | * type. | |
144 | * | |
145 | * @param type the type to check | |
146 | * @return true if the specified type is a standard artifact type | |
147 | */ | |
148 | public static boolean isStandardArtifactType( final String type ) | |
149 | { | |
150 | 0 | return standardArtifactTypes.contains( type ); |
151 | } | |
152 | ||
153 | } |