package org.hl7.fhir.dstu3.formats; /* Copyright (c) 2011+, HL7, Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. * Neither the name of HL7 nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.math.BigDecimal; import java.text.ParseException; import java.util.HashMap; import java.util.Map; import org.apache.commons.codec.binary.Base64; import org.hl7.fhir.exceptions.FHIRFormatError; import org.hl7.fhir.dstu3.model.Resource; import org.hl7.fhir.dstu3.model.Type; import org.hl7.fhir.utilities.Utilities; public abstract class ParserBase extends FormatUtilities implements IParser { // -- implementation of variant type methods from the interface -------------------------------- public Resource parse(String input) throws FHIRFormatError, IOException { return parse(input.getBytes("UTF-8")); } public Resource parse(byte[] bytes) throws FHIRFormatError, IOException { ByteArrayInputStream bi = new ByteArrayInputStream(bytes); return parse(bi); } public Type parseType(String input, String typeName) throws FHIRFormatError, IOException { return parseType(input.getBytes("UTF-8"), typeName); } public Type parseType(byte[] bytes, String typeName) throws FHIRFormatError, IOException { ByteArrayInputStream bi = new ByteArrayInputStream(bytes); return parseType(bi, typeName); } public String composeString(Resource resource) throws IOException { return new String(composeBytes(resource)); } public byte[] composeBytes(Resource resource) throws IOException { ByteArrayOutputStream bytes = new ByteArrayOutputStream(); compose(bytes, resource); bytes.close(); return bytes.toByteArray(); } public String composeString(Type type, String typeName) throws IOException { return new String(composeBytes(type, typeName)); } public byte[] composeBytes(Type type, String typeName) throws IOException { ByteArrayOutputStream bytes = new ByteArrayOutputStream(); compose(bytes, type, typeName); bytes.close(); return bytes.toByteArray(); } // -- Parser Configuration -------------------------------- protected String xhtmlMessage; @Override public IParser setSuppressXhtml(String message) { xhtmlMessage = message; return this; } protected boolean handleComments = false; public boolean getHandleComments() { return handleComments; } public IParser setHandleComments(boolean value) { this.handleComments = value; return this; } /** * Whether to throw an exception if unknown content is found (or just skip it) */ protected boolean allowUnknownContent; /** * @return Whether to throw an exception if unknown content is found (or just skip it) */ public boolean isAllowUnknownContent() { return allowUnknownContent; } /** * @param allowUnknownContent Whether to throw an exception if unknown content is found (or just skip it) */ public IParser setAllowUnknownContent(boolean allowUnknownContent) { this.allowUnknownContent = allowUnknownContent; return this; } protected OutputStyle style = OutputStyle.NORMAL; public OutputStyle getOutputStyle() { return style; } public IParser setOutputStyle(OutputStyle style) { this.style = style; return this; } // -- Parser Utilities -------------------------------- protected Map<String, Object> idMap = new HashMap<String, Object>(); protected int parseIntegerPrimitive(String value) { if (value.startsWith("+") && Utilities.isInteger(value.substring(1))) value = value.substring(1); return java.lang.Integer.parseInt(value); } protected int parseIntegerPrimitive(java.lang.Long value) { if (value < java.lang.Integer.MIN_VALUE || value > java.lang.Integer.MAX_VALUE) { throw new IllegalArgumentException (value + " cannot be cast to int without changing its value."); } return value.intValue(); } protected String parseCodePrimitive(String value) { return value; } protected String parseTimePrimitive(String value) throws ParseException { return value; } protected BigDecimal parseDecimalPrimitive(BigDecimal value) { return value; } protected BigDecimal parseDecimalPrimitive(String value) { return new BigDecimal(value); } protected String parseUriPrimitive(String value) { return value; } protected byte[] parseBase64BinaryPrimitive(String value) { return Base64.decodeBase64(value.getBytes()); } protected String parseOidPrimitive(String value) { return value; } protected Boolean parseBooleanPrimitive(String value) { return java.lang.Boolean.valueOf(value); } protected Boolean parseBooleanPrimitive(Boolean value) { return java.lang.Boolean.valueOf(value); } protected String parseIdPrimitive(String value) { return value; } protected String parseStringPrimitive(String value) { return value; } protected String parseUuidPrimitive(String value) { return value; } }