io.vertx.reactivex.ext.web.handler.StaticHandler Maven / Gradle / Ivy
/*
* Copyright 2014 Red Hat, Inc.
*
* Red Hat 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 io.vertx.reactivex.ext.web.handler;
import io.vertx.reactivex.RxHelper;
import io.vertx.reactivex.ObservableHelper;
import io.vertx.reactivex.FlowableHelper;
import io.vertx.reactivex.impl.AsyncResultMaybe;
import io.vertx.reactivex.impl.AsyncResultSingle;
import io.vertx.reactivex.impl.AsyncResultCompletable;
import io.vertx.reactivex.WriteStreamObserver;
import io.vertx.reactivex.WriteStreamSubscriber;
import java.util.Map;
import java.util.Set;
import java.util.List;
import java.util.Iterator;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import io.vertx.core.Handler;
import io.vertx.core.AsyncResult;
import io.vertx.core.json.JsonObject;
import io.vertx.core.json.JsonArray;
import io.vertx.lang.rx.RxGen;
import io.vertx.lang.rx.TypeArg;
import io.vertx.lang.rx.MappingIterator;
/**
* A handler for serving static resources from the file system or classpath.
*
*
* NOTE: This class has been automatically generated from the {@link io.vertx.ext.web.handler.StaticHandler original} non RX-ified interface using Vert.x codegen.
*/
@RxGen(io.vertx.ext.web.handler.StaticHandler.class)
public class StaticHandler implements Handler {
@Override
public String toString() {
return delegate.toString();
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
StaticHandler that = (StaticHandler) o;
return delegate.equals(that.delegate);
}
@Override
public int hashCode() {
return delegate.hashCode();
}
public static final TypeArg __TYPE_ARG = new TypeArg<>( obj -> new StaticHandler((io.vertx.ext.web.handler.StaticHandler) obj),
StaticHandler::getDelegate
);
private final io.vertx.ext.web.handler.StaticHandler delegate;
public StaticHandler(io.vertx.ext.web.handler.StaticHandler delegate) {
this.delegate = delegate;
}
public StaticHandler(Object delegate) {
this.delegate = (io.vertx.ext.web.handler.StaticHandler)delegate;
}
public io.vertx.ext.web.handler.StaticHandler getDelegate() {
return delegate;
}
/**
* Something has happened, so handle it.
* @param event the event to handle
*/
public void handle(io.vertx.reactivex.ext.web.RoutingContext event) {
delegate.handle(event.getDelegate());
}
/**
* Create a handler using defaults
* @return the handler
*/
public static io.vertx.reactivex.ext.web.handler.StaticHandler create() {
io.vertx.reactivex.ext.web.handler.StaticHandler ret = io.vertx.reactivex.ext.web.handler.StaticHandler.newInstance((io.vertx.ext.web.handler.StaticHandler)io.vertx.ext.web.handler.StaticHandler.create());
return ret;
}
/**
* Create a handler, specifying web-root
* @param root the web-root
* @return the handler
*/
public static io.vertx.reactivex.ext.web.handler.StaticHandler create(java.lang.String root) {
io.vertx.reactivex.ext.web.handler.StaticHandler ret = io.vertx.reactivex.ext.web.handler.StaticHandler.newInstance((io.vertx.ext.web.handler.StaticHandler)io.vertx.ext.web.handler.StaticHandler.create(root));
return ret;
}
/**
* Create a handler, specifying web-root
* and access option: absolute path or relative
* @param handlerVisibility CWD or file system root
* @param root the web-root
* @return the handler
*/
public static io.vertx.reactivex.ext.web.handler.StaticHandler create(io.vertx.ext.web.handler.FileSystemAccess handlerVisibility, java.lang.String root) {
io.vertx.reactivex.ext.web.handler.StaticHandler ret = io.vertx.reactivex.ext.web.handler.StaticHandler.newInstance((io.vertx.ext.web.handler.StaticHandler)io.vertx.ext.web.handler.StaticHandler.create(handlerVisibility, root));
return ret;
}
/**
* Set whether files are read-only and will never change
* @param readOnly whether files are read-only
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setFilesReadOnly(boolean readOnly) {
delegate.setFilesReadOnly(readOnly);
return this;
}
/**
* Set value for max age in caching headers
* @param maxAgeSeconds maximum time for browser to cache, in seconds
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setMaxAgeSeconds(long maxAgeSeconds) {
delegate.setMaxAgeSeconds(maxAgeSeconds);
return this;
}
/**
* Set whether cache header handling is enabled
* @param enabled true if enabled
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setCachingEnabled(boolean enabled) {
delegate.setCachingEnabled(enabled);
return this;
}
/**
* Set whether directory listing is enabled
* @param directoryListing true if enabled
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setDirectoryListing(boolean directoryListing) {
delegate.setDirectoryListing(directoryListing);
return this;
}
/**
* Set whether hidden files should be served
* @param includeHidden true if hidden files should be served
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setIncludeHidden(boolean includeHidden) {
delegate.setIncludeHidden(includeHidden);
return this;
}
/**
* Set the server cache entry timeout when caching is enabled
* @param timeout the timeout, in ms
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setCacheEntryTimeout(long timeout) {
delegate.setCacheEntryTimeout(timeout);
return this;
}
/**
* Set the index page
* @param indexPage the index page
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setIndexPage(java.lang.String indexPage) {
delegate.setIndexPage(indexPage);
return this;
}
/**
* Set the max cache size, when caching is enabled
* @param maxCacheSize the max cache size
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setMaxCacheSize(int maxCacheSize) {
delegate.setMaxCacheSize(maxCacheSize);
return this;
}
/**
* Set the file mapping for http2push and link preload
* @param http2PushMappings the mapping for http2 push
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setHttp2PushMapping(java.util.List http2PushMappings) {
delegate.setHttp2PushMapping(http2PushMappings);
return this;
}
/**
* Skip compression if the media type of the file to send is in the provided
* mediaTypes
set.
* Content-Encoding
header set to identity
for the types present
* in the mediaTypes
set
* @param mediaTypes the set of mime types that are already compressed
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler skipCompressionForMediaTypes(java.util.Set mediaTypes) {
delegate.skipCompressionForMediaTypes(mediaTypes);
return this;
}
/**
* Skip compression if the suffix of the file to send is in the provided
* fileSuffixes
set.
* Content-Encoding
header set to identity
for the suffixes
* present in the fileSuffixes
set
* @param fileSuffixes the set of file suffixes that are already compressed
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler skipCompressionForSuffixes(java.util.Set fileSuffixes) {
delegate.skipCompressionForSuffixes(fileSuffixes);
return this;
}
/**
* Set whether async filesystem access should always be used
* @param alwaysAsyncFS true for always async FS access
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setAlwaysAsyncFS(boolean alwaysAsyncFS) {
delegate.setAlwaysAsyncFS(alwaysAsyncFS);
return this;
}
/**
* Set whether async/sync filesystem tuning should enabled
* @param enableFSTuning true to enabled FS tuning
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setEnableFSTuning(boolean enableFSTuning) {
delegate.setEnableFSTuning(enableFSTuning);
return this;
}
/**
* Set the max serve time in ns, above which serves are considered slow
* @param maxAvgServeTimeNanoSeconds max serve time, in ns
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setMaxAvgServeTimeNs(long maxAvgServeTimeNanoSeconds) {
delegate.setMaxAvgServeTimeNs(maxAvgServeTimeNanoSeconds);
return this;
}
/**
* Set the directory template to be used when directory listing
* @param directoryTemplate the directory template
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setDirectoryTemplate(java.lang.String directoryTemplate) {
delegate.setDirectoryTemplate(directoryTemplate);
return this;
}
/**
* Set whether range requests (resumable downloads; media streaming) should be
* enabled.
* @param enableRangeSupport true to enable range support
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setEnableRangeSupport(boolean enableRangeSupport) {
delegate.setEnableRangeSupport(enableRangeSupport);
return this;
}
/**
* Set whether vary header should be sent with response.
* @param varyHeader true to sent vary header
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setSendVaryHeader(boolean varyHeader) {
delegate.setSendVaryHeader(varyHeader);
return this;
}
/**
* Set the default content encoding for text related files. This allows
* overriding the system settings default value.
* @param contentEncoding the desired content encoding e.g.: "UTF-8"
* @return a reference to this, so the API can be used fluently
*/
public io.vertx.reactivex.ext.web.handler.StaticHandler setDefaultContentEncoding(java.lang.String contentEncoding) {
delegate.setDefaultContentEncoding(contentEncoding);
return this;
}
/**
* Default value of the web-root, where files are served from
*/
public static final java.lang.String DEFAULT_WEB_ROOT = io.vertx.ext.web.handler.StaticHandler.DEFAULT_WEB_ROOT;
/**
* Default value of whether files are read -only and never will be updated
*/
public static final boolean DEFAULT_FILES_READ_ONLY = io.vertx.ext.web.handler.StaticHandler.DEFAULT_FILES_READ_ONLY;
/**
* Default max age for cache headers
*/
public static final long DEFAULT_MAX_AGE_SECONDS = io.vertx.ext.web.handler.StaticHandler.DEFAULT_MAX_AGE_SECONDS;
/**
* Default of whether cache header handling is enabled
*/
public static final boolean DEFAULT_CACHING_ENABLED = io.vertx.ext.web.handler.StaticHandler.DEFAULT_CACHING_ENABLED;
/**
* Default of whether directory listing is enabled
*/
public static final boolean DEFAULT_DIRECTORY_LISTING = io.vertx.ext.web.handler.StaticHandler.DEFAULT_DIRECTORY_LISTING;
/**
* Default template file to use for directory listing
*/
public static final java.lang.String DEFAULT_DIRECTORY_TEMPLATE = io.vertx.ext.web.handler.StaticHandler.DEFAULT_DIRECTORY_TEMPLATE;
/**
* Default of whether hidden files can be served
*/
public static final boolean DEFAULT_INCLUDE_HIDDEN = io.vertx.ext.web.handler.StaticHandler.DEFAULT_INCLUDE_HIDDEN;
/**
* Default cache entry timeout, when caching
*/
public static final long DEFAULT_CACHE_ENTRY_TIMEOUT = io.vertx.ext.web.handler.StaticHandler.DEFAULT_CACHE_ENTRY_TIMEOUT;
/**
* The default index page
*/
public static final java.lang.String DEFAULT_INDEX_PAGE = io.vertx.ext.web.handler.StaticHandler.DEFAULT_INDEX_PAGE;
/**
* The default max cache size
*/
public static final int DEFAULT_MAX_CACHE_SIZE = io.vertx.ext.web.handler.StaticHandler.DEFAULT_MAX_CACHE_SIZE;
/**
* Default of whether async filesystem access should always be used
*/
public static final boolean DEFAULT_ALWAYS_ASYNC_FS = io.vertx.ext.web.handler.StaticHandler.DEFAULT_ALWAYS_ASYNC_FS;
/**
* Default of whether fs async/sync tuning should be used
*/
public static final boolean DEFAULT_ENABLE_FS_TUNING = io.vertx.ext.web.handler.StaticHandler.DEFAULT_ENABLE_FS_TUNING;
/**
* Default max avg serve time, in ns, over which serving will be considered slow
*/
public static final long DEFAULT_MAX_AVG_SERVE_TIME_NS = io.vertx.ext.web.handler.StaticHandler.DEFAULT_MAX_AVG_SERVE_TIME_NS;
/**
* Default of whether Range request handling support should be used
*/
public static final boolean DEFAULT_RANGE_SUPPORT = io.vertx.ext.web.handler.StaticHandler.DEFAULT_RANGE_SUPPORT;
/**
* Default of whether access to the root of the file system should be allowed or
* just allow from the current working
* directory.
*/
public static final boolean DEFAULT_ROOT_FILESYSTEM_ACCESS = io.vertx.ext.web.handler.StaticHandler.DEFAULT_ROOT_FILESYSTEM_ACCESS;
/**
* Default of whether vary header should be sent.
*/
public static final boolean DEFAULT_SEND_VARY_HEADER = io.vertx.ext.web.handler.StaticHandler.DEFAULT_SEND_VARY_HEADER;
public static StaticHandler newInstance(io.vertx.ext.web.handler.StaticHandler arg) {
return arg != null ? new StaticHandler(arg) : null;
}
}