All Downloads are FREE. Search and download functionalities are using the official Maven repository.

no.digipost.xml.parsers.SaxParserProvider Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) Posten Norge AS
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package no.digipost.xml.parsers;

import org.xml.sax.InputSource;
import org.xml.sax.SAXException;
import org.xml.sax.SAXNotRecognizedException;
import org.xml.sax.SAXNotSupportedException;
import org.xml.sax.XMLReader;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import javax.xml.transform.sax.SAXSource;

import static javax.xml.XMLConstants.FEATURE_SECURE_PROCESSING;

public interface SaxParserProvider {

    public static SaxParserProvider createSecuredProvider() {
        SAXParserFactory factory = SAXParserFactory.newInstance();
        factory.setNamespaceAware(true);

        // configuration to align with OWASP recommendations:
        // https://cheatsheetseries.owasp.org/cheatsheets/XML_External_Entity_Prevention_Cheat_Sheet.html#jaxb-unmarshaller
        try {
            factory.setFeature(FEATURE_SECURE_PROCESSING, true);
            factory.setFeature("http://apache.org/xml/features/disallow-doctype-decl", true);
            factory.setValidating(false);     // this only concerns DTD validation
            factory.setXIncludeAware(false);  // already false by default, but setting anyway
        } catch (SAXNotRecognizedException | SAXNotSupportedException | ParserConfigurationException e) {
            throw new IllegalStateException(
                    "Unable to configure SAXParserFactory " + factory.getClass().getName() + " for secure processing " +
                    "because " + e.getClass().getSimpleName() + ": " + e.getMessage(), e);
        }

        return new SharedFactorySaxParserProvider(factory);
    }



    SAXParser createParser();


    default XMLReader createXMLReader() {
        SAXParser parser = createParser();
        try {
            return parser.getXMLReader();
        } catch (SAXException e) {
            throw new IllegalStateException(
                    "Unable to get " + XMLReader.class.getName() + " from the created " + parser.getClass().getName() +
                    " because " + e.getClass().getSimpleName() + ": " + e.getMessage(), e);
        }
    }

    default SAXSource createSource(InputSource inputSource) {
        return new SAXSource(createXMLReader(), inputSource);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy