/*
 * Copyright (c) 2010, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package org.glassfish.jersey.jaxb.internal;

import org.glassfish.jersey.internal.inject.InjectionManager;
import org.glassfish.jersey.jaxb.FeatureSupplier;

import jakarta.ws.rs.core.Configuration;

import jakarta.inject.Inject;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import java.util.LinkedHashMap;
import java.util.Map;

Thread-scoped injection provider of SAX parser factories. If MessageProperties.XML_SECURITY_DISABLE is not set, the SecureSaxParserFactory is returned. By default, the http://apache.org/xml/features/disallow-doctype-decl feature is set to TRUE. To override this settings, it is possible to register the FeatureSupplier.allowDoctypeDeclFeature().
Author:Paul Sandoz, Marek Potociar, Martin Matula
See Also:
/** * Thread-scoped injection provider of {@link SAXParserFactory SAX parser factories}. * * If {@link org.glassfish.jersey.message.MessageProperties#XML_SECURITY_DISABLE} is not set, * the {@link SecureSaxParserFactory} is returned. By default, the {@code http://apache.org/xml/features/disallow-doctype-decl} * feature is set to {@code TRUE}. To override this settings, it is possible to register the * {@link FeatureSupplier#allowDoctypeDeclFeature()}. * * @see FeatureSupplier * * @author Paul Sandoz * @author Marek Potociar * @author Martin Matula */
public class SaxParserFactoryInjectionProvider extends AbstractXmlFactory<SAXParserFactory> {
Create new SAX parser factory provider.
Params:
  • config – Jersey configuration properties.
/** * Create new SAX parser factory provider. * * @param config Jersey configuration properties. */
// TODO This provider should be registered and configured via a feature. @Inject public SaxParserFactoryInjectionProvider(final Configuration config) { super(config); } @Inject private InjectionManager injectionManager; @Override public SAXParserFactory get() { final SecureSaxParserFactory factory = new SecureSaxParserFactory(SAXParserFactory.newInstance(), !isXmlSecurityDisabled()); factory.setNamespaceAware(true); final Map<String, Object> saxParserProperties = new LinkedHashMap<>(); JaxbFeatureUtil.setProperties(injectionManager, SAXParser.class, saxParserProperties::put); factory.setSaxParserProperties(saxParserProperties); JaxbFeatureUtil.setFeatures(injectionManager, SAXParserFactory.class, factory::setFeature); return factory; } }