org.apache.juneau.serializer.OutputStreamSerializer Maven / Gradle / Ivy
// ***************************************************************************************************************************
// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file *
// * distributed with this work for additional information regarding copyright ownership. The ASF licenses this file *
// * to you 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 org.apache.juneau.serializer;
import static org.apache.juneau.internal.StringUtils.*;
import org.apache.juneau.*;
/**
* Subclass of {@link Serializer} for byte-based serializers.
*/
public abstract class OutputStreamSerializer extends Serializer {
/**
* Constructor.
*
* @param propertyStore
* The property store containing all the settings for this object.
* @param produces
* The media type that this serializer produces.
* @param accept
* The accept media types that the serializer can handle.
*
* Can contain meta-characters per the media-type
specification of
* RFC2616/14.1
*
* If empty, then assumes the only media type supported is produces
.
*
* For example, if this serializer produces "application/json" but should handle media types of
* "application/json" and "text/json" , then the arguments should be:
*
super (propertyStore, "application/json" , "application/json" , "text/json" );
*
...or...
*
super (propertyStore, "application/json" , "*/json" );
*/
protected OutputStreamSerializer(PropertyStore propertyStore, String produces, String...accept) {
super(propertyStore, produces, accept);
}
//--------------------------------------------------------------------------------
// Abstract methods
//--------------------------------------------------------------------------------
@Override /* SerializerSession */
public abstract OutputStreamSerializerSession createSession(SerializerSessionArgs args);
//--------------------------------------------------------------------------------
// Other methods
//--------------------------------------------------------------------------------
@Override /* Serializer */
public final boolean isWriterSerializer() {
return false;
}
/**
* Convenience method for serializing an object to a byte
.
*
* @param o The object to serialize.
* @return The output serialized to a byte array.
* @throws SerializeException If a problem occurred trying to convert the output.
*/
@Override
public final byte[] serialize(Object o) throws SerializeException {
return createSession(createDefaultSessionArgs()).serialize(o);
}
/**
* Convenience method for serializing an object to a hex-encoded String.
*
* @param o The object to serialize.
* @return The output serialized to a hex-encoded string.
* @throws SerializeException If a problem occurred trying to convert the output.
*/
public final String serializeToHex(Object o) throws SerializeException {
return toHex(serialize(o));
}
}