File: SAAJMetaFactory.java

package info (click to toggle)
libjboss-web-services-java 0.0%2Bsvn5660%2Bdak2-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 7,252 kB
  • ctags: 12,475
  • sloc: java: 79,207; xml: 29; makefile: 19; sh: 16
file content (81 lines) | stat: -rw-r--r-- 4,417 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
 * JBoss, Home of Professional Open Source
 * Copyright 2005, JBoss Inc., and individual contributors as indicated
 * by the @authors tag. See the copyright.txt in the distribution for a
 * full listing of individual contributors.
 *
 * This is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */
package javax.xml.soap;

// $Id: SAAJMetaFactory.java 4583 2007-09-18 13:15:44Z thomas.diesler@jboss.com $

/**
 * The access point for the implementation classes of the factories defined in the SAAJ API.
 * All of the newInstance methods defined on factories in SAAJ 1.3 defer to instances of this class to do the actual object creation.
 * The implementations of newInstance() methods (in SOAPFactory and MessageFactory) that existed in SAAJ 1.2
 * have been updated to also delegate to the SAAJMetaFactory when the SAAJ 1.2 defined lookup fails to locate the Factory implementation class name.
 * 
 * SAAJMetaFactory is a service provider interface. There are no public methods on this class.
 * 
 * @since SAAJ 1.3
 */
public abstract class SAAJMetaFactory
{
   protected SAAJMetaFactory()
   {
   }
   
   /**
    * Creates a new instance of a concrete SAAJMetaFactory object. The SAAJMetaFactory is an SPI, 
    * it pulls the creation of the other factories together into a single place. Changing out the SAAJMetaFactory 
    * has the effect of changing out the entire SAAJ implementation. Service providers provide the name of their SAAJMetaFactory 
    * implementation. This method uses the following ordered lookup procedure to determine the SAAJMetaFactory implementation class to load:
    * 
    *   - Use the javax.xml.soap.MetaFactory system property.
    *   - Use the properties file "lib/jaxm.properties" in the JRE directory. This configuration file is in standard java.util.Properties format and contains the fully qualified name of the implementation class with the key being the system property defined above.
    *   - Use the Services API (as detailed in the JAR specification), if available, to determine the classname. The Services API will look for a classname in the file META-INF/services/javax.xml.soap.MetaFactory in jars available to the runtime.
    *   - Default to com.sun.xml.messaging.saaj.soap.SAAJMetaFactoryImpl.
    *    
    * @return a concrete SAAJMetaFactory object
    * @throws SOAPException if there is an error in creating the SAAJMetaFactory
    */
   static SAAJMetaFactory getInstance() throws SOAPException
   {
      String propertyName = "javax.xml.soap.MetaFactory";
      String defaultImpl = "org.jboss.ws.core.soap.SAAJMetaFactoryImpl";
      SAAJMetaFactory factory = (SAAJMetaFactory)SAAJFactoryLoader.loadFactory(propertyName, defaultImpl);
      
      if (factory == null)
         throw new SOAPException("Failed to to determine the implementation class for: " + propertyName);

      return factory;
   }
   
   /**
    * Creates a MessageFactory object for the given String protocol.
    * @param protocol a String indicating the protocol (SOAPConstants.SOAP_1_1_PROTOCOL, SOAPConstants.SOAP_1_2_PROTOCOL, SOAPConstants.DYNAMIC_SOAP_PROTOCOL)
    * @throws SOAPException if there is an error in creating the MessageFactory
    */
   protected abstract MessageFactory newMessageFactory(String protocol) throws SOAPException;
   
   /**
    * Creates a SOAPFactory object for the given String protocol.
    * @param protocol a String indicating the protocol (SOAPConstants.SOAP_1_1_PROTOCOL, SOAPConstants.SOAP_1_2_PROTOCOL, SOAPConstants.DYNAMIC_SOAP_PROTOCOL)
    * @throws SOAPException if there is an error in creating the SOAPFactory
    */
   protected abstract SOAPFactory newSOAPFactory(String protocol) throws SOAPException;
}