Java tutorial
// Copyright 2016 The Nomulus Authors. All Rights Reserved. // // 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 domains.donuts.module.backend; import google.registry.monitoring.metrics.MetricReporter; import google.registry.util.FormattingLogger; import org.bouncycastle.jce.provider.BouncyCastleProvider; import java.io.IOException; import java.security.Security; import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeoutException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** Servlet that should handle all requests to our "backend" App Engine module. */ public final class BackendServlet extends HttpServlet { private static final BackendComponent component = DaggerBackendComponent.create(); private static final BackendRequestHandler requestHandler = component.requestHandler(); private static final MetricReporter metricReporter = component.metricReporter(); private static final FormattingLogger logger = FormattingLogger.getLoggerForCallerClass(); @Override public void init() { Security.addProvider(new BouncyCastleProvider()); try { metricReporter.startAsync().awaitRunning(10, TimeUnit.SECONDS); logger.info("Started up MetricReporter"); } catch (TimeoutException timeoutException) { logger.severefmt("Failed to initialize MetricReporter: %s", timeoutException); } } @Override public void destroy() { try { metricReporter.stopAsync().awaitTerminated(10, TimeUnit.SECONDS); logger.info("Shut down MetricReporter"); } catch (TimeoutException timeoutException) { logger.severefmt("Failed to stop MetricReporter: %s", timeoutException); } } @Override public void service(HttpServletRequest req, HttpServletResponse rsp) throws IOException { requestHandler.handleRequest(req, rsp); } }