graphql.language.DirectivesContainer Maven / Gradle / Ivy
package graphql.language;
import com.google.common.collect.ImmutableMap;
import graphql.PublicApi;
import java.util.List;
import java.util.Map;
import static graphql.language.NodeUtil.allDirectivesByName;
import static java.util.Collections.emptyList;
/**
* Represents a language node that can contain Directives. Directives can be repeatable and (by default) non repeatable.
*
* There are access methods here that get the two different types.
*
* @see graphql.language.DirectiveDefinition
* @see DirectiveDefinition#isRepeatable()
*/
@PublicApi
public interface DirectivesContainer extends Node {
/**
* This will return a list of all the directives that have been put on {@link graphql.language.Node} as a flat list, which may contain repeatable
* and non repeatable directives.
*
* @return a list of all the directives associated with this Node
*/
List getDirectives();
/**
* This will return a Map of the all directives that are associated with a {@link graphql.language.Node}, including both repeatable and non repeatable directives.
*
* @return a map of all directives by directive name
*/
default Map> getDirectivesByName() {
return ImmutableMap.copyOf(allDirectivesByName(getDirectives()));
}
/**
* Returns all of the directives with the provided name, including repeatable and non repeatable directives.
*
* @param directiveName the name of the directives to retrieve
*
* @return the directives or empty list if there is not one with that name
*/
default List getDirectives(String directiveName) {
return getDirectivesByName().getOrDefault(directiveName, emptyList());
}
/**
* This returns true if the AST node contains one or more directives by the specified name
*
* @param directiveName the name ot check
*
* @return true if the AST node contains one or more directives by the specified name
*/
default boolean hasDirective(String directiveName) {
return !getDirectives(directiveName).isEmpty();
}
}