/*
* This file is part of ReadonlyREST.
*
* ReadonlyREST is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* ReadonlyREST is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with ReadonlyREST. If not, see http://www.gnu.org/licenses/
*/
package org.elasticsearch.plugin.readonlyrest.settings.rules;
import org.elasticsearch.plugin.readonlyrest.acl.domain.HttpMethod;
import org.elasticsearch.plugin.readonlyrest.settings.SettingsMalformedException;
import org.elasticsearch.plugin.readonlyrest.settings.RuleSettings;
import java.util.Set;
import java.util.stream.Collectors;
public class MethodsRuleSettings implements RuleSettings {
public static final String ATTRIBUTE_NAME = "methods";
private final Set<HttpMethod> methods;
public static MethodsRuleSettings from(Set<String> methods) {
return new MethodsRuleSettings(methods.stream()
.map(value -> HttpMethod.fromString(value)
.<SettingsMalformedException>orElseThrow(() -> new SettingsMalformedException("Unknown/unsupported http method: " + value)))
.collect(Collectors.toSet()));
}
public MethodsRuleSettings(Set<HttpMethod> methods) {
this.methods = methods;
}
public Set<HttpMethod> getMethods() {
return methods;
}
@Override
public String getName() {
return ATTRIBUTE_NAME;
}
}