210 lines
9.2 KiB
Plaintext
210 lines
9.2 KiB
Plaintext
Metadata-Version: 2.1
|
|
Name: gql
|
|
Version: 3.5.3
|
|
Summary: GraphQL client for Python
|
|
Home-page: https://github.com/graphql-python/gql
|
|
Author: Syrus Akbary
|
|
Author-email: me@syrusakbary.com
|
|
License: MIT
|
|
Keywords: api graphql protocol rest relay gql client
|
|
Platform: any
|
|
Classifier: Development Status :: 5 - Production/Stable
|
|
Classifier: Intended Audience :: Developers
|
|
Classifier: Topic :: Software Development :: Libraries
|
|
Classifier: Programming Language :: Python :: 3
|
|
Classifier: Programming Language :: Python :: 3 :: Only
|
|
Classifier: Programming Language :: Python :: 3.7
|
|
Classifier: Programming Language :: Python :: 3.8
|
|
Classifier: Programming Language :: Python :: 3.9
|
|
Classifier: Programming Language :: Python :: 3.10
|
|
Classifier: Programming Language :: Python :: 3.11
|
|
Classifier: Programming Language :: Python :: 3.12
|
|
Classifier: Programming Language :: Python :: Implementation :: PyPy
|
|
Description-Content-Type: text/markdown
|
|
Requires-Dist: graphql-core<3.2.7,>=3.2
|
|
Requires-Dist: yarl<2.0,>=1.6
|
|
Requires-Dist: backoff<3.0,>=1.11.1
|
|
Requires-Dist: anyio<5,>=3.0
|
|
Provides-Extra: aiohttp
|
|
Requires-Dist: aiohttp<4,>=3.8.0; python_version <= "3.11" and extra == "aiohttp"
|
|
Requires-Dist: aiohttp<4,>=3.9.0b0; python_version > "3.11" and extra == "aiohttp"
|
|
Provides-Extra: all
|
|
Requires-Dist: requests<3,>=2.26; extra == "all"
|
|
Requires-Dist: requests-toolbelt<2,>=1.0.0; extra == "all"
|
|
Requires-Dist: httpx<1,>=0.23.1; extra == "all"
|
|
Requires-Dist: websockets<12,>=10; extra == "all"
|
|
Requires-Dist: botocore<2,>=1.21; extra == "all"
|
|
Requires-Dist: aiohttp<4,>=3.8.0; python_version <= "3.11" and extra == "all"
|
|
Requires-Dist: aiohttp<4,>=3.9.0b0; python_version > "3.11" and extra == "all"
|
|
Provides-Extra: botocore
|
|
Requires-Dist: botocore<2,>=1.21; extra == "botocore"
|
|
Provides-Extra: dev
|
|
Requires-Dist: requests<3,>=2.26; extra == "dev"
|
|
Requires-Dist: requests-toolbelt<2,>=1.0.0; extra == "dev"
|
|
Requires-Dist: httpx<1,>=0.23.1; extra == "dev"
|
|
Requires-Dist: websockets<12,>=10; extra == "dev"
|
|
Requires-Dist: botocore<2,>=1.21; extra == "dev"
|
|
Requires-Dist: black==22.3.0; extra == "dev"
|
|
Requires-Dist: check-manifest<1,>=0.42; extra == "dev"
|
|
Requires-Dist: flake8==3.8.1; extra == "dev"
|
|
Requires-Dist: isort==4.3.21; extra == "dev"
|
|
Requires-Dist: mypy==0.910; extra == "dev"
|
|
Requires-Dist: sphinx<6,>=5.3.0; extra == "dev"
|
|
Requires-Dist: sphinx-rtd-theme<1,>=0.4; extra == "dev"
|
|
Requires-Dist: sphinx-argparse==0.2.5; extra == "dev"
|
|
Requires-Dist: types-aiofiles; extra == "dev"
|
|
Requires-Dist: types-mock; extra == "dev"
|
|
Requires-Dist: types-requests; extra == "dev"
|
|
Requires-Dist: parse==1.15.0; extra == "dev"
|
|
Requires-Dist: pytest==7.4.2; extra == "dev"
|
|
Requires-Dist: pytest-asyncio==0.21.1; extra == "dev"
|
|
Requires-Dist: pytest-console-scripts==1.3.1; extra == "dev"
|
|
Requires-Dist: pytest-cov==3.0.0; extra == "dev"
|
|
Requires-Dist: mock==4.0.2; extra == "dev"
|
|
Requires-Dist: aiofiles; extra == "dev"
|
|
Requires-Dist: aiohttp<4,>=3.8.0; python_version <= "3.11" and extra == "dev"
|
|
Requires-Dist: vcrpy==4.4.0; python_version <= "3.8" and extra == "dev"
|
|
Requires-Dist: aiohttp<4,>=3.9.0b0; python_version > "3.11" and extra == "dev"
|
|
Requires-Dist: vcrpy==7.0.0; python_version > "3.8" and extra == "dev"
|
|
Provides-Extra: httpx
|
|
Requires-Dist: httpx<1,>=0.23.1; extra == "httpx"
|
|
Provides-Extra: requests
|
|
Requires-Dist: requests<3,>=2.26; extra == "requests"
|
|
Requires-Dist: requests-toolbelt<2,>=1.0.0; extra == "requests"
|
|
Provides-Extra: test
|
|
Requires-Dist: requests<3,>=2.26; extra == "test"
|
|
Requires-Dist: requests-toolbelt<2,>=1.0.0; extra == "test"
|
|
Requires-Dist: httpx<1,>=0.23.1; extra == "test"
|
|
Requires-Dist: websockets<12,>=10; extra == "test"
|
|
Requires-Dist: botocore<2,>=1.21; extra == "test"
|
|
Requires-Dist: parse==1.15.0; extra == "test"
|
|
Requires-Dist: pytest==7.4.2; extra == "test"
|
|
Requires-Dist: pytest-asyncio==0.21.1; extra == "test"
|
|
Requires-Dist: pytest-console-scripts==1.3.1; extra == "test"
|
|
Requires-Dist: pytest-cov==3.0.0; extra == "test"
|
|
Requires-Dist: mock==4.0.2; extra == "test"
|
|
Requires-Dist: aiofiles; extra == "test"
|
|
Requires-Dist: aiohttp<4,>=3.8.0; python_version <= "3.11" and extra == "test"
|
|
Requires-Dist: vcrpy==4.4.0; python_version <= "3.8" and extra == "test"
|
|
Requires-Dist: aiohttp<4,>=3.9.0b0; python_version > "3.11" and extra == "test"
|
|
Requires-Dist: vcrpy==7.0.0; python_version > "3.8" and extra == "test"
|
|
Provides-Extra: test_no_transport
|
|
Requires-Dist: parse==1.15.0; extra == "test-no-transport"
|
|
Requires-Dist: pytest==7.4.2; extra == "test-no-transport"
|
|
Requires-Dist: pytest-asyncio==0.21.1; extra == "test-no-transport"
|
|
Requires-Dist: pytest-console-scripts==1.3.1; extra == "test-no-transport"
|
|
Requires-Dist: pytest-cov==3.0.0; extra == "test-no-transport"
|
|
Requires-Dist: mock==4.0.2; extra == "test-no-transport"
|
|
Requires-Dist: aiofiles; extra == "test-no-transport"
|
|
Requires-Dist: vcrpy==4.4.0; python_version <= "3.8" and extra == "test_no_transport"
|
|
Requires-Dist: vcrpy==7.0.0; python_version > "3.8" and extra == "test_no_transport"
|
|
Provides-Extra: websockets
|
|
Requires-Dist: websockets<12,>=10; extra == "websockets"
|
|
|
|
# GQL
|
|
|
|
This is a GraphQL client for Python 3.7+.
|
|
Plays nicely with `graphene`, `graphql-core`, `graphql-js` and any other GraphQL implementation compatible with the spec.
|
|
|
|
GQL architecture is inspired by `React-Relay` and `Apollo-Client`.
|
|
|
|
[![GitHub-Actions][gh-image]][gh-url]
|
|
[![pyversion][pyversion-image]][pyversion-url]
|
|
[![pypi][pypi-image]][pypi-url]
|
|
[![Anaconda-Server Badge][conda-image]][conda-url]
|
|
[![codecov][codecov-image]][codecov-url]
|
|
|
|
[gh-image]: https://github.com/graphql-python/gql/workflows/Tests/badge.svg
|
|
[gh-url]: https://github.com/graphql-python/gql/actions?query=workflow%3ATests
|
|
[pyversion-image]: https://img.shields.io/pypi/pyversions/gql
|
|
[pyversion-url]: https://pypi.org/project/gql/
|
|
[pypi-image]: https://img.shields.io/pypi/v/gql.svg?style=flat
|
|
[pypi-url]: https://pypi.org/project/gql/
|
|
[conda-image]: https://img.shields.io/conda/vn/conda-forge/gql.svg
|
|
[conda-url]: https://anaconda.org/conda-forge/gql
|
|
[codecov-image]: https://codecov.io/gh/graphql-python/gql/branch/master/graph/badge.svg
|
|
[codecov-url]: https://codecov.io/gh/graphql-python/gql
|
|
|
|
## Documentation
|
|
|
|
The complete documentation for GQL can be found at
|
|
[gql.readthedocs.io](https://gql.readthedocs.io).
|
|
|
|
## Features
|
|
|
|
* Execute GraphQL queries using [different protocols](https://gql.readthedocs.io/en/latest/transports/index.html):
|
|
* http
|
|
* websockets:
|
|
* apollo or graphql-ws protocol
|
|
* Phoenix channels
|
|
* AWS AppSync realtime protocol (experimental)
|
|
* Possibility to [validate the queries locally](https://gql.readthedocs.io/en/latest/usage/validation.html) using a GraphQL schema provided locally or fetched from the backend using an instrospection query
|
|
* Supports GraphQL queries, mutations and [subscriptions](https://gql.readthedocs.io/en/latest/usage/subscriptions.html)
|
|
* Supports [sync or async usage](https://gql.readthedocs.io/en/latest/async/index.html), [allowing concurrent requests](https://gql.readthedocs.io/en/latest/advanced/async_advanced_usage.html#async-advanced-usage)
|
|
* Supports [File uploads](https://gql.readthedocs.io/en/latest/usage/file_upload.html)
|
|
* Supports [Custom scalars / Enums](https://gql.readthedocs.io/en/latest/usage/custom_scalars_and_enums.html)
|
|
* [gql-cli script](https://gql.readthedocs.io/en/latest/gql-cli/intro.html) to execute GraphQL queries or download schemas from the command line
|
|
* [DSL module](https://gql.readthedocs.io/en/latest/advanced/dsl_module.html) to compose GraphQL queries dynamically
|
|
|
|
## Installation
|
|
|
|
You can install GQL with all the optional dependencies using pip:
|
|
|
|
```bash
|
|
# Quotes may be required on certain shells such as zsh.
|
|
pip install "gql[all]"
|
|
```
|
|
|
|
> **NOTE**: See also [the documentation](https://gql.readthedocs.io/en/latest/intro.html#less-dependencies) to install GQL with less extra dependencies depending on the transports you would like to use or for alternative installation methods.
|
|
|
|
## Usage
|
|
|
|
### Basic usage
|
|
|
|
```python
|
|
from gql import gql, Client
|
|
from gql.transport.aiohttp import AIOHTTPTransport
|
|
|
|
# Select your transport with a defined url endpoint
|
|
transport = AIOHTTPTransport(url="https://countries.trevorblades.com/")
|
|
|
|
# Create a GraphQL client using the defined transport
|
|
client = Client(transport=transport, fetch_schema_from_transport=True)
|
|
|
|
# Provide a GraphQL query
|
|
query = gql(
|
|
"""
|
|
query getContinents {
|
|
continents {
|
|
code
|
|
name
|
|
}
|
|
}
|
|
"""
|
|
)
|
|
|
|
# Execute the query on the transport
|
|
result = client.execute(query)
|
|
print(result)
|
|
```
|
|
|
|
Executing the above code should output the following result:
|
|
|
|
```
|
|
$ python basic_example.py
|
|
{'continents': [{'code': 'AF', 'name': 'Africa'}, {'code': 'AN', 'name': 'Antarctica'}, {'code': 'AS', 'name': 'Asia'}, {'code': 'EU', 'name': 'Europe'}, {'code': 'NA', 'name': 'North America'}, {'code': 'OC', 'name': 'Oceania'}, {'code': 'SA', 'name': 'South America'}]}
|
|
```
|
|
|
|
> **WARNING**: Please note that this basic example won't work if you have an asyncio event loop running. In some
|
|
> python environments (as with Jupyter which uses IPython) an asyncio event loop is created for you. In that case you
|
|
> should use instead the [async usage example](https://gql.readthedocs.io/en/latest/async/async_usage.html#async-usage).
|
|
|
|
## Contributing
|
|
See [CONTRIBUTING.md](CONTRIBUTING.md)
|
|
|
|
## License
|
|
|
|
[MIT License](https://github.com/graphql-python/gql/blob/master/LICENSE)
|
|
|
|
|