You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commons-dev@ws.apache.org by sc...@apache.org on 2008/01/16 23:42:43 UTC
svn commit: r612601 -
/webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java
Author: scheu
Date: Wed Jan 16 14:42:42 2008
New Revision: 612601
URL: http://svn.apache.org/viewvc?rev=612601&view=rev
Log:
WSCOMMONS-297
Contributor:Rich Scheuerle
Tester: Brent Ulbricht
Surround create* logic with doPriv blocks just in case the plugged in StAX implementation
uses J2S sensitive logic.
Modified:
webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java
Modified: webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java
URL: http://svn.apache.org/viewvc/webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java?rev=612601&r1=612600&r2=612601&view=diff
==============================================================================
--- webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java (original)
+++ webservices/commons/trunk/modules/axiom/modules/axiom-api/src/main/java/org/apache/axiom/om/util/StAXUtils.java Wed Jan 16 14:42:42 2008
@@ -34,6 +34,8 @@
import java.io.Writer;
import java.security.AccessController;
import java.security.PrivilegedAction;
+import java.security.PrivilegedActionException;
+import java.security.PrivilegedExceptionAction;
import java.util.ArrayList;
import java.util.List;
@@ -168,43 +170,71 @@
xmlInputFactoryPool.releaseInstance(factory);
}
- public static XMLStreamReader createXMLStreamReader(InputStream in, String encoding)
+ public static XMLStreamReader createXMLStreamReader(final InputStream in, final String encoding)
throws XMLStreamException {
- XMLInputFactory inputFactory = getXMLInputFactory();
+ final XMLInputFactory inputFactory = getXMLInputFactory();
try {
- XMLStreamReader reader = inputFactory.createXMLStreamReader(in, encoding);
+ XMLStreamReader reader =
+ (XMLStreamReader)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return inputFactory.createXMLStreamReader(in, encoding);
+ }
+ }
+ );
if (isDebugEnabled) {
log.debug("XMLStreamReader is " + reader.getClass().getName());
}
return reader;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLInputFactory(inputFactory);
}
}
- public static XMLStreamReader createXMLStreamReader(InputStream in)
+ public static XMLStreamReader createXMLStreamReader(final InputStream in)
throws XMLStreamException {
- XMLInputFactory inputFactory = getXMLInputFactory();
+ final XMLInputFactory inputFactory = getXMLInputFactory();
try {
- XMLStreamReader reader = inputFactory.createXMLStreamReader(in);
+ XMLStreamReader reader =
+ (XMLStreamReader)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return inputFactory.createXMLStreamReader(in);
+ }
+ }
+ );
+
if (isDebugEnabled) {
log.debug("XMLStreamReader is " + reader.getClass().getName());
}
return reader;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLInputFactory(inputFactory);
}
}
- public static XMLStreamReader createXMLStreamReader(Reader in)
+ public static XMLStreamReader createXMLStreamReader(final Reader in)
throws XMLStreamException {
- XMLInputFactory inputFactory = getXMLInputFactory();
+ final XMLInputFactory inputFactory = getXMLInputFactory();
try {
- XMLStreamReader reader = inputFactory.createXMLStreamReader(in);
+ XMLStreamReader reader =
+ (XMLStreamReader)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return inputFactory.createXMLStreamReader(in);
+ }
+ }
+ );
if (isDebugEnabled) {
log.debug("XMLStreamReader is " + reader.getClass().getName());
}
return reader;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLInputFactory(inputFactory);
}
@@ -228,43 +258,72 @@
xmlOutputFactoryPool.releaseInstance(factory);
}
- public static XMLStreamWriter createXMLStreamWriter(OutputStream out)
+ public static XMLStreamWriter createXMLStreamWriter(final OutputStream out)
throws XMLStreamException {
- XMLOutputFactory outputFactory = getXMLOutputFactory();
+ final XMLOutputFactory outputFactory = getXMLOutputFactory();
try {
- XMLStreamWriter writer = outputFactory.createXMLStreamWriter(out, OMConstants.DEFAULT_CHAR_SET_ENCODING);
+ XMLStreamWriter writer =
+ (XMLStreamWriter)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return outputFactory.createXMLStreamWriter(out, OMConstants.DEFAULT_CHAR_SET_ENCODING);
+ }
+ }
+ );
+
if (isDebugEnabled) {
log.debug("XMLStreamWriter is " + writer.getClass().getName());
}
return writer;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLOutputFactory(outputFactory);
}
}
- public static XMLStreamWriter createXMLStreamWriter(OutputStream out, String encoding)
+ public static XMLStreamWriter createXMLStreamWriter(final OutputStream out, final String encoding)
throws XMLStreamException {
- XMLOutputFactory outputFactory = getXMLOutputFactory();
+ final XMLOutputFactory outputFactory = getXMLOutputFactory();
try {
- XMLStreamWriter writer = outputFactory.createXMLStreamWriter(out, encoding);
+ XMLStreamWriter writer =
+ (XMLStreamWriter)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return outputFactory.createXMLStreamWriter(out, encoding);
+ }
+ }
+ );
+
if (isDebugEnabled) {
log.debug("XMLStreamWriter is " + writer.getClass().getName());
}
return writer;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLOutputFactory(outputFactory);
}
}
- public static XMLStreamWriter createXMLStreamWriter(Writer out)
+ public static XMLStreamWriter createXMLStreamWriter(final Writer out)
throws XMLStreamException {
- XMLOutputFactory outputFactory = getXMLOutputFactory();
+ final XMLOutputFactory outputFactory = getXMLOutputFactory();
try {
- XMLStreamWriter writer = outputFactory.createXMLStreamWriter(out);
+ XMLStreamWriter writer =
+ (XMLStreamWriter)
+ AccessController.doPrivileged(new PrivilegedExceptionAction() {
+ public Object run() throws XMLStreamException {
+ return outputFactory.createXMLStreamWriter(out);
+ }
+ }
+ );
if (isDebugEnabled) {
log.debug("XMLStreamWriter is " + writer.getClass().getName());
}
return writer;
+ } catch (PrivilegedActionException pae) {
+ throw (XMLStreamException) pae.getException();
} finally {
releaseXMLOutputFactory(outputFactory);
}
---------------------------------------------------------------------
To unsubscribe, e-mail: commons-dev-unsubscribe@ws.apache.org
For additional commands, e-mail: commons-dev-help@ws.apache.org