@PublicApi public class GraphQLScalarType extends java.lang.Object implements GraphQLNamedInputType, GraphQLNamedOutputType, GraphQLUnmodifiedType, GraphQLNullableType, GraphQLDirectiveContainer
GraphQL provides a number of built‐in scalars, but type systems can add additional scalars with semantic meaning, for example, a GraphQL system could define a scalar called Time which, while serialized as a string, promises to conform to ISO‐8601. When querying a field of type Time, you can then rely on the ability to parse the result with an ISO‐8601 parser and use a client‐specific primitive for time.From the spec : http://facebook.github.io/graphql/#sec-Scalars
graphql-java ships with a set of predefined scalar types via Scalars
Scalars| Modifier and Type | Class and Description |
|---|---|
static class |
GraphQLScalarType.Builder |
| Modifier and Type | Field and Description |
|---|---|
static java.lang.String |
CHILD_DIRECTIVES |
| Constructor and Description |
|---|
GraphQLScalarType(java.lang.String name,
java.lang.String description,
Coercing coercing)
Deprecated.
use the
newScalar() builder pattern instead, as this constructor will be made private in a future version. |
GraphQLScalarType(java.lang.String name,
java.lang.String description,
Coercing coercing,
java.util.List<GraphQLDirective> directives,
ScalarTypeDefinition definition)
Deprecated.
use the
newScalar() builder pattern instead, as this constructor will be made private in a future version. |
| Modifier and Type | Method and Description |
|---|---|
TraversalControl |
accept(TraverserContext<GraphQLSchemaElement> context,
GraphQLTypeVisitor visitor) |
boolean |
equals(java.lang.Object o)
No GraphQLSchemaElement implements `equals` because we need object identity
to treat a GraphQLSchema as an abstract graph.
|
java.util.Map<java.lang.String,java.util.List<GraphQLDirective>> |
getAllDirectivesByName()
This will return a Map of the all directives that are associated with a
GraphQLNamedSchemaElement, including both
repeatable and non repeatable directives. |
java.util.List<GraphQLSchemaElement> |
getChildren() |
SchemaElementChildrenContainer |
getChildrenWithTypeReferences() |
Coercing |
getCoercing() |
ScalarTypeDefinition |
getDefinition()
The AST
Node this schema element is based on. |
java.lang.String |
getDescription() |
GraphQLDirective |
getDirective(java.lang.String directiveName)
Returns a non repeatable directive with the provided name.
|
java.util.List<GraphQLDirective> |
getDirectives()
This will return a list of all the directives that have been put on
GraphQLNamedSchemaElement as a flat list, which may contain repeatable
and non repeatable directives. |
java.util.Map<java.lang.String,GraphQLDirective> |
getDirectivesByName()
This will return a Map of the non repeatable directives that are associated with a
GraphQLNamedSchemaElement. |
java.util.List<ScalarTypeExtensionDefinition> |
getExtensionDefinitions() |
java.lang.String |
getName() |
java.lang.String |
getSpecifiedByUrl() |
int |
hashCode()
No GraphQLSchemaElement implements `equals/hashCode` because we need object identity
to treat a GraphQLSchema as an abstract graph.
|
static GraphQLScalarType.Builder |
newScalar() |
static GraphQLScalarType.Builder |
newScalar(GraphQLScalarType existing) |
java.lang.String |
toString() |
GraphQLScalarType |
transform(java.util.function.Consumer<GraphQLScalarType.Builder> builderConsumer)
This helps you transform the current GraphQLObjectType into another one by starting a builder with all
the current values and allows you to transform it how you want.
|
GraphQLScalarType |
withNewChildren(SchemaElementChildrenContainer newChildren) |
clone, finalize, getClass, notify, notifyAll, wait, wait, waitgetDirectivespublic static final java.lang.String CHILD_DIRECTIVES
@Deprecated
public GraphQLScalarType(java.lang.String name,
java.lang.String description,
Coercing coercing)
newScalar() builder pattern instead, as this constructor will be made private in a future version.name - the namedescription - the descriptioncoercing - the coercing function@Deprecated
public GraphQLScalarType(java.lang.String name,
java.lang.String description,
Coercing coercing,
java.util.List<GraphQLDirective> directives,
ScalarTypeDefinition definition)
newScalar() builder pattern instead, as this constructor will be made private in a future version.name - the namedescription - the descriptioncoercing - the coercing functiondirectives - the directives on this type elementdefinition - the AST definitionpublic java.lang.String getName()
getName in interface GraphQLNamedSchemaElementpublic java.lang.String getDescription()
getDescription in interface GraphQLNamedSchemaElementpublic java.lang.String getSpecifiedByUrl()
public Coercing getCoercing()
public ScalarTypeDefinition getDefinition()
GraphQLNamedSchemaElementNode this schema element is based on. Is null if the GraphQLSchema
is not based on a SDL document.
Some elements also have additional extension Nodes. See for example GraphQLObjectType.getExtensionDefinitions()getDefinition in interface GraphQLNamedSchemaElementpublic java.util.List<ScalarTypeExtensionDefinition> getExtensionDefinitions()
public java.util.List<GraphQLDirective> getDirectives()
GraphQLDirectiveContainerGraphQLNamedSchemaElement as a flat list, which may contain repeatable
and non repeatable directives.getDirectives in interface GraphQLDirectiveContainerpublic java.util.Map<java.lang.String,GraphQLDirective> getDirectivesByName()
GraphQLDirectiveContainerGraphQLNamedSchemaElement. Any repeatable directives
will be filtered out of this map.getDirectivesByName in interface GraphQLDirectiveContainerpublic java.util.Map<java.lang.String,java.util.List<GraphQLDirective>> getAllDirectivesByName()
GraphQLDirectiveContainerGraphQLNamedSchemaElement, including both
repeatable and non repeatable directives.getAllDirectivesByName in interface GraphQLDirectiveContainerpublic GraphQLDirective getDirective(java.lang.String directiveName)
GraphQLDirectiveContainerAssertException if
the directive is a repeatable directive that has more then one instance.getDirective in interface GraphQLDirectiveContainerdirectiveName - the name of the directive to retrievepublic java.lang.String toString()
toString in class java.lang.Objectpublic GraphQLScalarType transform(java.util.function.Consumer<GraphQLScalarType.Builder> builderConsumer)
builderConsumer - the consumer code that will be given a builder to transformpublic TraversalControl accept(TraverserContext<GraphQLSchemaElement> context, GraphQLTypeVisitor visitor)
accept in interface GraphQLSchemaElementpublic java.util.List<GraphQLSchemaElement> getChildren()
getChildren in interface GraphQLSchemaElementpublic SchemaElementChildrenContainer getChildrenWithTypeReferences()
getChildrenWithTypeReferences in interface GraphQLSchemaElementpublic GraphQLScalarType withNewChildren(SchemaElementChildrenContainer newChildren)
withNewChildren in interface GraphQLSchemaElementpublic final boolean equals(java.lang.Object o)
equals in interface GraphQLSchemaElementequals in class java.lang.Objecto - the reference object with which to compare.true if this object is the same as the obj
argument; false otherwise.public final int hashCode()
hashCode in interface GraphQLSchemaElementhashCode in class java.lang.Objectpublic static GraphQLScalarType.Builder newScalar()
public static GraphQLScalarType.Builder newScalar(GraphQLScalarType existing)