org.apache.wink.common.internal.providers.entity.atom.AtomEntrySyndEntryProvider Maven / Gradle / Ivy
The newest version!
/*******************************************************************************
* 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.wink.common.internal.providers.entity.atom;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import javax.ws.rs.Consumes;
import javax.ws.rs.Produces;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.ext.MessageBodyReader;
import javax.ws.rs.ext.MessageBodyWriter;
import javax.ws.rs.ext.Provider;
import javax.ws.rs.ext.Providers;
import org.apache.wink.common.internal.runtime.RuntimeContextTLS;
import org.apache.wink.common.internal.utils.MediaTypeUtils;
import org.apache.wink.common.model.atom.AtomEntry;
import org.apache.wink.common.model.synd.SyndContent;
import org.apache.wink.common.model.synd.SyndEntry;
@Provider
@Consumes( {MediaType.APPLICATION_ATOM_XML, MediaType.APPLICATION_JSON, MediaTypeUtils.JAVASCRIPT})
@Produces( {MediaType.APPLICATION_ATOM_XML, MediaType.APPLICATION_JSON, MediaTypeUtils.JAVASCRIPT})
public class AtomEntrySyndEntryProvider implements MessageBodyReader,
MessageBodyWriter {
@Context
private Providers providers;
public boolean isReadable(Class type,
Type genericType,
Annotation[] annotations,
MediaType mediaType) {
return type == SyndEntry.class;
}
public SyndEntry readFrom(Class type,
Type genericType,
Annotation[] annotations,
MediaType mediaType,
MultivaluedMap httpHeaders,
InputStream entityStream) throws IOException, WebApplicationException {
MessageBodyReader reader =
providers.getMessageBodyReader(AtomEntry.class, genericType, annotations, mediaType);
AtomEntry entry =
reader.readFrom(AtomEntry.class,
genericType,
annotations,
mediaType,
httpHeaders,
entityStream);
/*
* The value in the AtomContent object is arbitrary, set by the server. We want to use the
* built-in AND client application supplied providers. Because these providers are collected
* on the thread local store, and the unmarshalling of the AtomContent value is done lazily
* (after the client-server context has expired), we need some way to hold onto the Providers
* long enough for the client app to be able to seamlessly get the value off the AtomContent
* object. Thus the need to set the *real* providers list on the AtomContent object, so it
* can use the list to pass to ModelUtils when it needs to retrieve and unmarshal the AtomContent
* value.
*
* We have to be careful to use the real Providers list instead of the one from the injected
* local providers field in this class. The injected object may be a "proxy" to the real
* providers, and could cause an infinite loop when ModelUtils.readValue calls back through
* the providers.
*/
SyndEntry returnVal = entry.toSynd(new SyndEntry());
SyndContent content = returnVal.getContent();
if (content != null) {
content.setProviders(RuntimeContextTLS.getRuntimeContext().getAttribute(Providers.class));
}
return returnVal;
}
public boolean isWriteable(Class type,
Type genericType,
Annotation[] annotations,
MediaType mediaType) {
MessageBodyWriter writer =
providers.getMessageBodyWriter(AtomEntry.class, genericType, annotations, mediaType);
return ((type.isAssignableFrom(SyndEntry.class)) && (writer != null));
}
public void writeTo(SyndEntry t,
Class type,
Type genericType,
Annotation[] annotations,
MediaType mediaType,
MultivaluedMap httpHeaders,
OutputStream entityStream) throws IOException, WebApplicationException {
AtomEntry entry = new AtomEntry(t);
MessageBodyWriter writer =
providers.getMessageBodyWriter(AtomEntry.class, genericType, annotations, mediaType);
// already checked for non-null writer in isWriteable
writer.writeTo(entry,
AtomEntry.class,
genericType,
annotations,
mediaType,
httpHeaders,
entityStream);
}
public long getSize(SyndEntry t,
Class type,
Type genericType,
Annotation[] annotations,
MediaType mediaType) {
return -1;
}
}