Skip to main content

Comprehensive GraphQL implementation for Python.

Project description

py-gql

GitHub Workflow Status Codecov PyPI PyPI - Python Version Wheel Read the Docs (version)

py-gql is a pure python GraphQL implementation aimed at creating GraphQL servers and providing common tooling.

It supports:

  • Parsing the GraphQL query language and schema definition language.
  • Building a GraphQL type schema programmatically and from Schema Definition files (including support for schema directives).
  • Validating and Executing a GraphQL request against a type schema.

Quick links

Installation

pip install py-gql

For more details see install.rst.

Usage & Examples

from py_gql import build_schema, graphql_blocking


schema = build_schema(
    """
    type Query {
        hello(value: String = "world"): String!
    }
    """
)

@schema.resolver("Query.hello")
def resolve_hello(*_, value):
    return "Hello {}!".format(value)


result = graphql_blocking(schema, '{ hello(value: "World") }')

assert result.response() == {
    "data": {
        "hello": "Hello World!"
    }
}

For more usage examples, you can refer to the User Guide and some more involved examples available in the examples folder.

The tests should also provide some contrived examples.

Goals & Status

This project was initially born as an experiment / learning project following some frustration with graphql-core and Graphene I encountered at work.

The main goals were originally to:

  • Get a deeper understanding of GraphQL

  • Provide an alternative to graphql-core which:

    • tracks the latest version of the spec (which graphql-core didn't at the time)
    • does so without being a port of the JS code which leads to some weird edge case when we tried to extend the library
    • keeps support for Python 2
    • (subjective) attempts to be a bit more usable for our use cases, the ideal result would sit somewhere in between Graphene and graphql-core
    • makes it easier for us to build / include some extra tooling such as custom tracing, custom validation and SDL based tools as well as builder infrastructure to support easily implementing graphql layers over existing data layers (such as ORM)

Not all these points are satisfied yet, and some have been changed over time, but py-gql should be ready for general use. It is however still in a fairly experimental phase and to reflect that versions are still in the 0.x.y.The API is still subject to change as different part of the codebase are iterated on and are getting more use against production codebases.

Development setup

Make sure you are using Python 3.6+ (you can run the tests under 3.5 but `other development tasks such as black are not guaranteed to work).

Clone this repo and create a virtualenv before installing the development dependencies:

git clone git@github.com:lirsacc/py-gql.git
python -m venv $WORKON_HOME/py-gql --copies
pip install -U -r requirements-dev.txt
pip install -e .

Development tasks are available through invoke. Check tasks.py or use inv -l to list all available tasks and inv --help {TASK} to get help on a specific task. Most of the tools used should be usable directly, but the tasks provide some common aliases and targets.

As a shortcut, inv check will run all checks that are normally run on CI (lint, typecheck and tests).

CI is done on Github Actions.

Branches

  • The last tag should correspond to the latest release version
  • master contains unreleased changes that are planned to be released
  • dev is used for experimenting and hard changes such as rebase and force pushed should be expected. For now this is the branch I used in side projects and where most of the iteration happens.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

py_gql-0.6.1.tar.gz (247.9 kB view details)

Uploaded Source

Built Distribution

py_gql-0.6.1-py3-none-any.whl (143.2 kB view details)

Uploaded Python 3

File details

Details for the file py_gql-0.6.1.tar.gz.

File metadata

  • Download URL: py_gql-0.6.1.tar.gz
  • Upload date:
  • Size: 247.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1+

File hashes

Hashes for py_gql-0.6.1.tar.gz
Algorithm Hash digest
SHA256 8df8496302dacb71b6076db72ef363a1f05ac6dd41ac2a5a96efa99ef6b90d09
MD5 1731abed3745fb982535fcc8fa1006fa
BLAKE2b-256 51f3c299e8f6de546c3d2540da076c4437bdff32c24014c91e2437b4ade9ec8c

See more details on using hashes here.

File details

Details for the file py_gql-0.6.1-py3-none-any.whl.

File metadata

  • Download URL: py_gql-0.6.1-py3-none-any.whl
  • Upload date:
  • Size: 143.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.1.3 requests-toolbelt/0.9.1 tqdm/4.42.1 CPython/3.8.1+

File hashes

Hashes for py_gql-0.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 15707a69e5fc9c6a079ae54a2c33829567c8e1b066a2683f22c019be2553ffa1
MD5 dc80610855d4aec2c93c0118edd4fb50
BLAKE2b-256 6decedcbf6f32b6f95d8c566fad2669427784b4a7caf236c7d7a0d380a263290

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page