org.cryptomator.frontend.webdav.WebDavServerModule Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of webdav-nio-adapter Show documentation
Show all versions of webdav-nio-adapter Show documentation
Embedded Jetty serving a WebDAV servlet to access resources at a given NIO path.
/*******************************************************************************
* Copyright (c) 2016 Sebastian Stenzel and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the accompanying LICENSE.txt.
*
* Contributors:
* Sebastian Stenzel - initial API and implementation
*******************************************************************************/
package org.cryptomator.frontend.webdav;
import com.google.common.base.Preconditions;
import dagger.Module;
import dagger.Provides;
import org.cryptomator.frontend.webdav.mount.MounterModule;
import org.eclipse.jetty.server.Connector;
import org.eclipse.jetty.server.Server;
import org.eclipse.jetty.server.ServerConnector;
import org.eclipse.jetty.server.handler.ContextHandlerCollection;
import org.eclipse.jetty.servlet.ServletContextHandler;
import org.eclipse.jetty.servlet.ServletHolder;
import org.eclipse.jetty.util.thread.ExecutorThreadPool;
import org.eclipse.jetty.util.thread.ThreadPool;
import javax.inject.Qualifier;
import javax.inject.Singleton;
import java.lang.annotation.Documented;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.util.Collection;
import java.util.HashSet;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;
@Module(includes = {MounterModule.class})
class WebDavServerModule {
private static final int MAX_PENDING_REQUESTS = 400;
private static final int MAX_THREADS = 100;
private static final int THREAD_IDLE_SECONDS = 60;
private static final String ROOT_PATH = "/";
private AtomicInteger threadNum = new AtomicInteger(1);
@Provides
@Singleton
ThreadPoolExecutor provideThreadPoolExecutor() {
// set core pool size = MAX_THREADS and allow coreThreadTimeOut to enforce spawning threads till the maximum even if the queue is not full
BlockingQueue queue = new LinkedBlockingQueue<>(MAX_PENDING_REQUESTS);
ThreadPoolExecutor executor = new ThreadPoolExecutor(MAX_THREADS, MAX_THREADS, THREAD_IDLE_SECONDS, TimeUnit.SECONDS, queue);
executor.allowCoreThreadTimeOut(true);
return executor;
}
@Provides
@Singleton
ExecutorService provideExecutorService(ThreadPoolExecutor executorService) {
return executorService;
}
@Provides
@Singleton
ExecutorThreadPool provideThreadPool(ThreadPoolExecutor executorService) {
ExecutorThreadPool threadPool = new ExecutorThreadPool(executorService);
executorService.setThreadFactory(this::createServerThread);
try {
threadPool.start();
return threadPool;
} catch (Exception e) {
throw new IllegalStateException("Implementation known not to throw an exception.", e);
}
}
private Thread createServerThread(Runnable runnable) {
Thread t = new Thread(runnable, String.format("webdav-%03d", threadNum.getAndIncrement()));
t.setDaemon(true);
return t;
}
@Provides
@Singleton
Server provideServer(ExecutorThreadPool threadPool, ContextHandlerCollection servletCollection) {
Preconditions.checkState(threadPool.isStarted()); // otherwise addBean() will make the threadpool managed, i.e. it will be shut down when the server is stopped
Server server = new Server(threadPool);
server.setHandler(servletCollection);
return server;
}
@Provides
@Singleton
ServerConnector provideServerConnector(Server server) {
ServerConnector connector = new ServerConnector(server);
server.setConnectors(new Connector[] {connector});
return connector;
}
@Provides
@Singleton
ContextHandlerCollection provideContextHandlerCollection(@CatchAll ServletContextHandler catchAllServletHandler) {
ContextHandlerCollection collection = new ContextHandlerCollection();
collection.addHandler(catchAllServletHandler);
return collection;
}
@Provides
@Singleton
@CatchAll
ServletContextHandler provideServletContextHandler(DefaultServlet servlet) {
final ServletContextHandler servletContext = new ServletContextHandler(null, ROOT_PATH, ServletContextHandler.NO_SESSIONS);
final ServletHolder servletHolder = new ServletHolder(ROOT_PATH, servlet);
servletContext.addServlet(servletHolder, ROOT_PATH);
return servletContext;
}
@Provides
@Singleton
@ContextPaths
Collection provideContextPaths() {
return new HashSet<>();
}
@Qualifier
@Documented
@Retention(RetentionPolicy.RUNTIME)
@interface CatchAll {
}
@Qualifier
@Documented
@Retention(RetentionPolicy.RUNTIME)
@interface ContextPaths {
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy