/*
* Copyright (c) 2011-2013 The original author or authors
* ------------------------------------------------------
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* The Apache License v2.0 is available at
* http://www.opensource.org/licenses/apache2.0.php
*
* You may elect to redistribute this code under either of these licenses.
*/
package io.vertx.core.http.impl;
import io.netty.handler.codec.http.HttpHeaders;
import io.vertx.core.MultiMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
/**
* @author <a href="mailto:nmaurer@redhat.com">Norman Maurer</a>
*/
public class HeadersAdaptor implements MultiMap {
private final HttpHeaders headers;
public HeadersAdaptor(HttpHeaders headers) {
this.headers = headers;
}
@Override
public String get(String name) {
return headers.get(name);
}
@Override
public List<String> getAll(String name) {
return headers.getAll(name);
}
@Override
public List<Map.Entry<String, String>> entries() {
return headers.entries();
}
@Override
public boolean contains(String name) {
return headers.contains(name);
}
@Override
public boolean isEmpty() {
return headers.isEmpty();
}
@Override
public Set<String> names() {
return headers.names();
}
@Override
public MultiMap add(String name, String value) {
headers.add(name, value);
return this;
}
@Override
public MultiMap add(String name, Iterable<String> values) {
headers.add(name, values);
return this;
}
@Override
public MultiMap addAll(MultiMap headers) {
for (Map.Entry<String, String> entry: headers.entries()) {
add(entry.getKey(), entry.getValue());
}
return this;
}
@Override
public MultiMap addAll(Map<String, String> map) {
for (Map.Entry<String, String> entry: map.entrySet()) {
add(entry.getKey(), entry.getValue());
}
return this;
}
@Override
public MultiMap set(String name, String value) {
headers.set(name, value);
return this;
}
@Override
public MultiMap set(String name, Iterable<String> values) {
headers.set(name, values);
return this;
}
@Override
public MultiMap setAll(MultiMap httpHeaders) {
clear();
for (Map.Entry<String, String> entry: httpHeaders) {
add(entry.getKey(), entry.getValue());
}
return this;
}
@Override
public MultiMap remove(String name) {
headers.remove(name);
return this;
}
@Override
public MultiMap clear() {
headers.clear();
return this;
}
@Override
public Iterator<Map.Entry<String, String>> iterator() {
return headers.iterator();
}
@Override
public int size() {
return names().size();
}
@Override
public MultiMap setAll(Map<String, String> headers) {
for (Map.Entry<String, String> entry: headers.entrySet()) {
add(entry.getKey(), entry.getValue());
}
return this;
}
@Override
public String get(CharSequence name) {
return headers.get(name);
}
@Override
public List<String> getAll(CharSequence name) {
return headers.getAll(name);
}
@Override
public boolean contains(CharSequence name) {
return headers.contains(name);
}
@Override
public MultiMap add(CharSequence name, CharSequence value) {
headers.add(name, value);
return this;
}
@Override
public MultiMap add(CharSequence name, Iterable<CharSequence> values) {
headers.add(name, values);
return this;
}
@Override
public MultiMap set(CharSequence name, CharSequence value) {
headers.set(name, value);
return this;
}
@Override
public MultiMap set(CharSequence name, Iterable<CharSequence> values) {
headers.set(name, values);
return this;
}
@Override
public MultiMap remove(CharSequence name) {
headers.remove(name);
return this;
}
}