2 * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
8 package org.opendaylight.restconf.nb.rfc8040;
10 import static java.util.Objects.requireNonNull;
13 import org.eclipse.jdt.annotation.NonNull;
16 * This class represents a {@code filter} parameter as defined in
17 * <a href="https://datatracker.ietf.org/doc/html/rfc8040#section-4.8.4">RFC8040 section 4.8.4</a>.
20 public final class FilterParam implements RestconfQueryParam<FilterParam> {
21 // API consistency: must not be confused with enum constants
22 @SuppressWarnings("checkstyle:ConstantName")
23 public static final @NonNull String uriName = "filter";
25 private static final @NonNull URI CAPABILITY = URI.create("urn:ietf:params:restconf:capability:filter:1.0");
27 // FIXME: can we have a parsed, but not bound version of an XPath, please?
28 private final @NonNull String value;
30 private FilterParam(final String value) {
31 this.value = requireNonNull(value);
35 public Class<@NonNull FilterParam> javaClass() {
36 return FilterParam.class;
40 public String paramName() {
45 public String paramValue() {
49 public static @NonNull FilterParam forUriValue(final String uriValue) {
50 return new FilterParam(uriValue);
53 public static @NonNull URI capabilityUri() {