![JAR search and dependency download from the Maven repository](/logo.png)
org.opendaylight.restconf.server.api.ServerRequest Maven / Gradle / Ivy
/*
* Copyright (c) 2024 PANTHEON.tech, s.r.o. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.restconf.server.api;
import static java.util.Objects.requireNonNull;
import org.eclipse.jdt.annotation.NonNullByDefault;
import org.opendaylight.restconf.api.QueryParameters;
import org.opendaylight.restconf.api.query.PrettyPrintParam;
/**
* A request to {@link RestconfServer}. It contains state and binding established by whoever is performing binding to
* HTTP transport layer. This includes:
*
* - HTTP request {@link #queryParameters() query parameters},
* - {@link #prettyPrint() pretty printing}, including affected by query parameters
-
*
* It notably does not hold the HTTP request path, nor the request body. Those are passed as separate arguments
* to server methods as implementations of those methods are expected to act on them.
*/
@NonNullByDefault
public record ServerRequest(QueryParameters queryParameters, PrettyPrintParam prettyPrint) {
// TODO: this is where a binding to security principal and access control should be:
// - we would like to be able to have java.security.Principal#name() for logging purposes
// - we need to have a NACM-capable interface, through which we can check permissions (such as data PUT) and
// establish output filters (i.e. excluding paths inaccessible path to user from a data GET a ContainerNode)
public ServerRequest {
requireNonNull(queryParameters);
requireNonNull(prettyPrint);
}
public static ServerRequest of(final QueryParameters queryParameters, final PrettyPrintParam defaultPrettyPrint) {
final var prettyPrint = queryParameters.lookup(PrettyPrintParam.uriName, PrettyPrintParam::forUriValue);
return prettyPrint == null ? new ServerRequest(queryParameters, defaultPrettyPrint)
: new ServerRequest(queryParameters.withoutParam(PrettyPrintParam.uriName), prettyPrint);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy