2 * Copyright © 2016-2018 European Support Limited
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 package org.openecomp.sdc.logging.servlet;
19 import java.util.function.Function;
22 * Handles any of possible header names to read a value for that header. This is useful for backward compatibility, if
23 * multiple headers may have the same meaning. For instance, when requests come from multiple service, some using an old
24 * header and others using a new header to pass the same information.
29 public class HttpHeader {
31 private final String[] keys;
33 public HttpHeader(String... keys) {
38 * Returns the value of any of the possible headers.
40 * @param reader function for reading an HTTP header.
41 * @return value or null if not found
43 public String getAny(Function<String, String> reader) {
45 for (String k : keys) {
47 String value = reader.apply(k);