Coder Social home page Coder Social logo

graphene-tornado's Introduction

Build Status Coverage Status

graphene-tornado

A project for running Graphene on top of Tornado for Python 3. The codebase was originally a port of graphene-django.

Getting started

Create a Tornado application and add the GraphQL handlers:

import tornado.web
from tornado.ioloop import IOLoop

from graphene_tornado.schema import schema
from graphene_tornado.tornado_graphql_handler import TornadoGraphQLHandler


class ExampleApplication(tornado.web.Application):

    def __init__(self):
        handlers = [
            (r'/graphql', TornadoGraphQLHandler, dict(graphiql=True, schema=schema)),
            (r'/graphql/batch', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, batch=True)),
            (r'/graphql/graphiql', TornadoGraphQLHandler, dict(graphiql=True, schema=schema))
        ]
        tornado.web.Application.__init__(self, handlers)

if __name__ == '__main__':
    app = ExampleApplication()
    app.listen(5000)
    IOLoop.instance().start()

When writing your resolvers, decorate them with either Tornado's @coroutine decorator for Python 2.7:

@gen.coroutine
def resolve_foo(self, info):
  foo = yield db.get_foo()
  raise Return(foo)

Or use the async / await pattern in Python 3:

async def resolve_foo(self, info):
  foo = await db.get_foo()
  return foo

Extensions

graphene-tornado supports server-side extensions like Apollo Server. The extensions go a step further than Graphene middleware to allow for finer grained interception of request processing. The canonical use case is for tracing; see graphene_tornado/apollo_engine_reporting/engine_agent.py for an example.

Extensions are experimental and most likely will change in future releases as they should be extensions provided by graphql-server-core.

Apollo Engine Reporting

You can integrate with Apollo Engine Reporting by enabling the extension.

$ pip install graphene-tornado[apollo-engine-reporting]
engine_options = EngineReportingOptions()
agent = EngineReportingAgent(engine_options, generate_schema_hash(schema))


class ExampleEngineReportingApplication(tornado.web.Application):

    def __init__(self):
        engine_extension = lambda: EngineReportingExtension(engine_options, agent.add_trace)
        handlers = [
            (r'/graphql', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, extensions=[engine_extension])),
            (r'/graphql/batch', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, batch=True, 
                                                            extensions=[engine_extension])),
            (r'/graphql/graphiql', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, 
                                                               extensions=[engine_extension]))
        ]
        tornado.web.Application.__init__(self, handlers)
ENGINE_API_KEY=<your engine API key here> python -m examples.apollo_engine_reporting_example

Then visit http://localhost:5000/graphql/graphiql, make some queries, and view the results in Apollo Engine.

OpenCensus

You can also use OpenCensus for tracing:

$ pip install graphene-tornado[opencensus]
class ExampleOpenCensusApplication(tornado.web.Application):

    def __init__(self):
        extension = lambda: OpenCensusExtension()
        handlers = [
            (r'/graphql', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, extensions=[extension])),
            (r'/graphql/batch', TornadoGraphQLHandler, dict(graphiql=True, schema=schema, batch=True)),
        ]
        tornado.web.Application.__init__(self, handlers)

graphene-tornado's People

Contributors

ewhauser avatar kinow avatar erikwrede avatar codeocelot avatar jkimbo avatar xchikux avatar dependabot[bot] avatar jimshepherd avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.