Skip to content

A python library for generating dataclasses based on GraphQL schema

License

Notifications You must be signed in to change notification settings

Nikikuzi/graphql-dataclass

 
 

Repository files navigation

graphql-dataclass

A python library to generate dataclasses for graphql schema.

Introduction

This library generates dataclasses which corresponding python code convention. Library is not working as client for graphql, only dataclasses mappers for GraphQL types

This document contains a quick overview of the functionalities, for more details and options you can read here:

The package using autoflake, black, isort libraries for generateed code formatting and also python 3 (3.10+) standard libraries.

Usage in a nutshell

Installation

Available in PyPI, the following command will install the library:

pip install graphql-dataclass

Generate python code from schema

To generate the code execute the following command:

gqldataclass generate ./pathToOutputFolder -apiArgs ./<pathToArgsFile>/generatorArgs.json

This command requires a json file containing the parameters needed to get the GraphQL schema

A sample is available in the main folder 'cli_args.json'.

The following python files will be generated:

  • scalars.py -> GraphQL scalar types as python type aliases
  • enums.py -> GraphQL enum types as Enum classes
  • gql_types.py -> GraphQL object types as classes
  • gql_simple_types.py -> GraphQL object types as classes not using other object types
  • unions.py -> GraphQL Unions as python Unions
  • gql_forward_reference.py -> file with types forward references, dacite-compatible
  • ${class_name}.py -> GraphQL object types as classes, which affected by circular dependencies

These links show code generated using the library Github GraphQL API, and GeoDBCities API

More command options are available here

About

A python library for generating dataclasses based on GraphQL schema

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%