All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jetty.rewrite.handler.PatternRule Maven / Gradle / Ivy

There is a newer version: 12.1.0.alpha1
Show newest version
//
// ========================================================================
// Copyright (c) 1995 Mort Bay Consulting Pty Ltd and others.
//
// This program and the accompanying materials are made available under the
// terms of the Eclipse Public License v. 2.0 which is available at
// https://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
// which is available at https://www.apache.org/licenses/LICENSE-2.0.
//
// SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
// ========================================================================
//

package org.eclipse.jetty.rewrite.handler;

import java.io.IOException;

import org.eclipse.jetty.http.pathmap.ServletPathSpec;

/**
 * 

Abstract rule that uses the Servlet pattern syntax via * {@link ServletPathSpec} for path pattern matching.

*/ public abstract class PatternRule extends Rule { private String _pattern; protected PatternRule() { } protected PatternRule(String pattern) { _pattern = pattern; } public String getPattern() { return _pattern; } public void setPattern(String pattern) { _pattern = pattern; } @Override public Handler matchAndApply(Handler input) throws IOException { if (ServletPathSpec.match(_pattern, input.getHttpURI().getPath())) return apply(input); return null; } /** *

Invoked after the Servlet pattern matched the URI path to apply the rule's logic.

* * @param input the input {@code Request} and {@code Handler} * @return the possibly wrapped {@code Request} and {@code Handler} * @throws IOException if applying the rule failed */ protected abstract Handler apply(Handler input) throws IOException; @Override public String toString() { return "%s[pattern=%s]".formatted(super.toString(), getPattern()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy