org.atmosphere.cpr.AtmosphereInterceptorWriter Maven / Gradle / Ivy
/*
* Copyright 2015 Async-IO.org
*
* 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 org.atmosphere.cpr;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.IOException;
import java.util.LinkedList;
/**
* An {@link AsyncIOWriter} that delegates the write operation to its {@link AsyncIOInterceptor}. If no
* AsyncIOInterceptor is specified, this class does nothing and the responses will never get written.
*
* @author Jeanfrancois Arcand
*/
public class AtmosphereInterceptorWriter extends AsyncIOWriterAdapter {
private final Logger logger = LoggerFactory.getLogger(AtmosphereInterceptorWriter.class);
protected final LinkedList filters = new LinkedList();
protected final LinkedList reversedFilters = new LinkedList();
public AtmosphereInterceptorWriter() {
}
@Override
public AsyncIOWriter redirect(AtmosphereResponse response, String location) throws IOException {
for (AsyncIOInterceptor i : filters) {
i.redirect(response, location);
}
return this;
}
@Override
public AsyncIOWriter writeError(AtmosphereResponse response, int errorCode, String message) throws IOException {
for (AsyncIOInterceptor i : filters) {
byte[] b = i.error(response, errorCode, message);
writeReady(response, b);
}
return this;
}
@Override
public AsyncIOWriter write(AtmosphereResponse response, String data) throws IOException {
return write(response, data.getBytes(response.getCharacterEncoding()));
}
@Override
public AsyncIOWriter write(AtmosphereResponse response, byte[] data) throws IOException {
return write(response, data, 0, data.length);
}
@Override
public AsyncIOWriter write(AtmosphereResponse response, byte[] data, int offset, int length) throws IOException {
invokeInterceptor(response, data, offset, length);
return this;
}
protected void invokeInterceptor(AtmosphereResponse response, byte[] data, int offset, int length) throws IOException {
for (AsyncIOInterceptor i : filters) {
i.prePayload(response, data, offset, length);
}
byte[] responseDraft = new byte[length];
System.arraycopy(data, offset, responseDraft, 0, length);
for (AsyncIOInterceptor i : filters) {
responseDraft = i.transformPayload(response, responseDraft, data);
}
writeReady(response, responseDraft);
for (AsyncIOInterceptor i : reversedFilters) {
i.postPayload(response, data, offset, length);
}
}
protected void writeReady(AtmosphereResponse response, byte[] responseDraft) throws IOException {
response.write(responseDraft);
}
@Override
public void close(AtmosphereResponse response) throws IOException {
response.closeStreamOrWriter();
}
@Override
public AsyncIOWriter flush(AtmosphereResponse response) throws IOException {
response.flushBuffer();
return this;
}
/**
* Add an {@link AsyncIOInterceptor} that will be invoked in the order it was added.
*
* @param filter {@link AsyncIOInterceptor
* @return this
*/
public AtmosphereInterceptorWriter interceptor(AsyncIOInterceptor filter) {
if (!filters.contains(filter)) {
logger.trace("Adding AsyncIOInterceptor {}", filter.getClass().getName());
filters.addLast(filter);
reversedFilters.addFirst(filter);
}
return this;
}
/**
* Add an {@link AsyncIOInterceptor} that will be invoked at the specified index position.
*
* @param filter {@link AsyncIOInterceptor
* @param index
* @return this
*/
public AtmosphereInterceptorWriter interceptor(AsyncIOInterceptor filter, int index) {
if (!filters.contains(filter)) {
if (logger.isTraceEnabled()) {
logger.trace("Adding AsyncIOInterceptor {} at index {}", filter.getClass().getName(), index);
}
filters.add(index, filter);
reversedFilters.add(reversedFilters.size() - index, filter);
}
return this;
}
public LinkedList filters(){
return filters;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy