freshcells/graphqlite-misc-types

A collection of non-standard GraphQL types to be used with GraphQLite.

2.0.1 2022-08-08 12:40 UTC

This package is auto-updated.

Last update: 2024-10-08 19:34:06 UTC


README

This package is an add-on to the GraphQLite PHP library. It contains a set of GraphQL scalar types that can be added to GraphQLite.

This is a takeover drop-in fork of https://github.com/thecodingmachine/graphqlite-misc-types which seems to be abandoned.
We left the namespace as TheCodingMachine to assure drop-in replacement.

Install

$ composer require freshcells/graphqlite-misc-types

"Any" scalar type

This types adds support for a "AnyScalar" type that can be any of "string", "int", "float" or "bool".

Usage

/**
 * @Query()
 * @param scalar $scalar
 * @return scalar
 */
public function echoScalar($scalar)
{
    return $scalar;
}

Use the "scalar" type-hint in the DocBlock to cast a value to "AnyScalar".

Registering AnyScalar

Using the SchemaFactory

If you are using the SchemaFactory to initialize GraphQLite, use this code to add support for AnyScalar:

$schemaFactory->addRootTypeMapper(new \TheCodingMachine\GraphQLite\Types\AnyScalar\AnyScalarTypeMapper());

Using the Symfony bundle

If you are using the Symfony bundle to initialize GraphQLite, register the AnyScalarTypeMapper as a service:

# config/services.yaml
services:
    TheCodingMachine\GraphQLite\Types\AnyScalar\AnyScalarTypeMapper:
        tags: ['graphql.root_type_mapper']

"JSON" type

This type adds support for a "JSON" type that can be used to represent JSON data.

Using the Symfony bundle

If you are using the Symfony bundle to initialize GraphQLite, register the JSONScalarTypeMapperFactory as a service:

# config/services.yaml
services:
    TheCodingMachine\GraphQLite\Types\JSONScalar\JSONScalarTypeMapperFactory:
        tags: ['graphql.root_type_mapper_factory']