All Downloads are FREE. Search and download functionalities are using the official Maven repository.

graphql.execution.instrumentation.FieldFetchingInstrumentationContext Maven / Gradle / Ivy

package graphql.execution.instrumentation;

import graphql.Internal;
import graphql.PublicSpi;
import graphql.execution.instrumentation.parameters.InstrumentationFieldFetchParameters;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

/**
 * FieldFetchingInstrumentationContext is returned back from the {@link Instrumentation#beginFieldFetching(InstrumentationFieldFetchParameters, InstrumentationState)}
 * method, and it's much like the normal {@link InstrumentationContext} type except it also
 * gives the value that was returned by a fields {@link graphql.schema.DataFetcher}.  This allows
 * you to know if the field value is a completely materialised field or if it's a {@link java.util.concurrent.CompletableFuture}
 * promise to a value.
 */
@PublicSpi
public interface FieldFetchingInstrumentationContext extends InstrumentationContext {

    /**
     * This is called back with the value fetched for the field by its {@link graphql.schema.DataFetcher}.
     * This can be a materialised java object or it maybe a {@link java.util.concurrent.CompletableFuture}
     * promise to some async value that has not yet completed.
     *
     * @param fetchedValue a value that a field's {@link graphql.schema.DataFetcher} returned
     */
    default void onFetchedValue(Object fetchedValue) {
    }

    @Internal
    FieldFetchingInstrumentationContext NOOP = new FieldFetchingInstrumentationContext() {
        @Override
        public void onDispatched() {
        }

        @Override
        public void onCompleted(Object result, Throwable t) {
        }
    };

    /**
     * This creates a no-op {@link InstrumentationContext} if the one passed in is null
     *
     * @param nullableContext a {@link InstrumentationContext} that can be null
     * @return a non-null {@link InstrumentationContext} that maybe a no-op
     */
    @NotNull
    @Internal
    static FieldFetchingInstrumentationContext nonNullCtx(FieldFetchingInstrumentationContext nullableContext) {
        return nullableContext == null ? NOOP : nullableContext;
    }

    @Internal
    static FieldFetchingInstrumentationContext adapter(@Nullable InstrumentationContext context) {
        if (context == null) {
            return null;
        }
        return new FieldFetchingInstrumentationContext() {
            @Override
            public void onDispatched() {
                context.onDispatched();
            }

            @Override
            public void onCompleted(Object result, Throwable t) {
                context.onCompleted(result, t);
            }
        };
    }
}