├── .gitignore ├── .pre-commit-config.yaml ├── LICENSE ├── README.md ├── examples ├── federation │ ├── .gitignore │ ├── account.py │ ├── gateway.js │ ├── helper.py │ ├── package-lock.json │ ├── package.json │ ├── product.py │ └── review.py ├── fileupload │ ├── app.py │ ├── multi.sh │ └── single.sh ├── hello │ ├── app.py │ └── schema.gql └── subscribe │ └── app.py ├── poetry.lock ├── pyproject.toml └── stargql ├── __init__.py ├── applications.py └── subscription.py /.gitignore: -------------------------------------------------------------------------------- 1 | # Created by .ignore support plugin (hsz.mobi) 2 | ### Python template 3 | # Byte-compiled / optimized / DLL files 4 | __pycache__/ 5 | *.py[cod] 6 | *$py.class 7 | 8 | # C extensions 9 | *.so 10 | 11 | # Distribution / packaging 12 | .Python 13 | build/ 14 | develop-eggs/ 15 | dist/ 16 | downloads/ 17 | eggs/ 18 | .eggs/ 19 | lib/ 20 | lib64/ 21 | parts/ 22 | sdist/ 23 | var/ 24 | wheels/ 25 | pip-wheel-metadata/ 26 | share/python-wheels/ 27 | *.egg-info/ 28 | .installed.cfg 29 | *.egg 30 | MANIFEST 31 | 32 | # PyInstaller 33 | # Usually these files are written by a python script from a template 34 | # before PyInstaller builds the exe, so as to inject date/other infos into it. 35 | *.manifest 36 | *.spec 37 | 38 | # Installer logs 39 | pip-log.txt 40 | pip-delete-this-directory.txt 41 | 42 | # Unit test / coverage reports 43 | htmlcov/ 44 | .tox/ 45 | .nox/ 46 | .coverage 47 | .coverage.* 48 | .cache 49 | nosetests.xml 50 | coverage.xml 51 | *.cover 52 | *.py,cover 53 | .hypothesis/ 54 | .pytest_cache/ 55 | 56 | # Translations 57 | *.mo 58 | *.pot 59 | 60 | # Django stuff: 61 | *.log 62 | local_settings.py 63 | db.sqlite3 64 | db.sqlite3-journal 65 | 66 | # Flask stuff: 67 | instance/ 68 | .webassets-cache 69 | 70 | # Scrapy stuff: 71 | .scrapy 72 | 73 | # Sphinx documentation 74 | docs/_build/ 75 | 76 | # PyBuilder 77 | target/ 78 | 79 | # Jupyter Notebook 80 | .ipynb_checkpoints 81 | 82 | # IPython 83 | profile_default/ 84 | ipython_config.py 85 | 86 | # pyenv 87 | .python-version 88 | 89 | # pipenv 90 | # According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. 91 | # However, in case of collaboration, if having platform-specific dependencies or dependencies 92 | # having no cross-platform support, pipenv may install dependencies that don't work, or not 93 | # install all needed dependencies. 94 | #Pipfile.lock 95 | 96 | # PEP 582; used by e.g. github.com/David-OConnor/pyflow 97 | __pypackages__/ 98 | 99 | # Celery stuff 100 | celerybeat-schedule 101 | celerybeat.pid 102 | 103 | # SageMath parsed files 104 | *.sage.py 105 | 106 | # Environments 107 | .env 108 | .venv 109 | env/ 110 | venv/ 111 | ENV/ 112 | env.bak/ 113 | venv.bak/ 114 | 115 | # Spyder project settings 116 | .spyderproject 117 | .spyproject 118 | 119 | # Rope project settings 120 | .ropeproject 121 | 122 | # mkdocs documentation 123 | /site 124 | 125 | # mypy 126 | .mypy_cache/ 127 | .dmypy.json 128 | dmypy.json 129 | 130 | # Pyre type checker 131 | .pyre/ 132 | 133 | .idea 134 | .vscode 135 | .python-version -------------------------------------------------------------------------------- /.pre-commit-config.yaml: -------------------------------------------------------------------------------- 1 | # exclude: | 2 | # (?x)( 3 | # ^config/| 4 | # .*/migrations/ 5 | # ) 6 | repos: 7 | - repo: https://github.com/asottile/seed-isort-config 8 | rev: v1.9.3 9 | hooks: 10 | - id: seed-isort-config 11 | language_version: python3.8 12 | - repo: https://github.com/pre-commit/mirrors-isort 13 | rev: v4.3.21 14 | hooks: 15 | - id: isort 16 | args: [-rc] 17 | language_version: python3.8 18 | - repo: https://github.com/ambv/black 19 | rev: stable 20 | hooks: 21 | - id: black 22 | language_version: python3.8 23 | args: [--line-length=100, --skip-string-normalization] 24 | - repo: https://github.com/pre-commit/pre-commit-hooks 25 | rev: v1.2.3 26 | hooks: 27 | - id: flake8 28 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) [year] [fullname] 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Starlette GraphQL 2 | 3 | The starlette GraphQL implement, which support query, mutate and subscription. Based on [python-gql](https://github.com/syfun/python-gql). 4 | 5 | ## Requirement 6 | 7 | Python 3.7+ 8 | 9 | ## Installation 10 | 11 | `pip install starlette-graphql` 12 | 13 | 14 | ## Getting started 15 | 16 | ```python 17 | # app.py 18 | from gql import query, gql 19 | from stargql import GraphQL 20 | 21 | type_defs = gql(""" 22 | type Query { 23 | hello(name: String!): String! 24 | } 25 | """) 26 | 27 | 28 | @query 29 | async def hello(parent, info, name: str) -> str: 30 | return name 31 | 32 | 33 | app = GraphQL(type_defs=type_defs) 34 | ``` 35 | 36 | Use [uvicorn](https://www.uvicorn.org) to run app. 37 | 38 | `uvicorn app:app --reload` 39 | 40 | ## Upload File 41 | 42 | ```python 43 | import uvicorn 44 | from gql import gql, mutate 45 | from stargql import GraphQL 46 | 47 | type_defs = gql(""" 48 | scalar Upload 49 | 50 | type File { 51 | filename: String! 52 | } 53 | 54 | type Query { 55 | uploads: [File] 56 | } 57 | 58 | type Mutation { 59 | singleUpload(file: Upload!): File! 60 | multiUpload(files: [Upload!]!): [File!]! 61 | } 62 | """) 63 | 64 | 65 | @mutate 66 | def single_upload(parent, info, file): 67 | return file 68 | 69 | 70 | @mutate 71 | def multi_upload(parent, info, files): 72 | return files 73 | 74 | 75 | app = GraphQL(type_defs=type_defs) 76 | 77 | 78 | if __name__ == '__main__': 79 | uvicorn.run(app, port=8080) 80 | 81 | ``` 82 | 83 | ## Subscription 84 | 85 | For more about subscription, please see [gql-subscriptions](https://github.com/syfun/starlette-graphql). 86 | 87 | ## Apollo Federation 88 | 89 | [Example](https://github.com/syfun/starlette-graphql/tree/master/examples/federation) 90 | 91 | For more abount subscription, please see [Apollo Federation](https://www.apollographql.com/docs/apollo-server/federation/introduction/) 92 | -------------------------------------------------------------------------------- /examples/federation/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | -------------------------------------------------------------------------------- /examples/federation/account.py: -------------------------------------------------------------------------------- 1 | import uvicorn 2 | 3 | from gql import gql, reference_resolver, query 4 | from stargql import GraphQL 5 | 6 | from helper import get_user_by_id, users 7 | 8 | type_defs = gql(""" 9 | type Query { 10 | me: User 11 | } 12 | 13 | type User @key(fields: "id") { 14 | id: ID! 15 | name: String 16 | username: String 17 | } 18 | 19 | """) 20 | 21 | @query('me') 22 | def get_me(_, info): 23 | return users[0] 24 | 25 | 26 | @reference_resolver('User') 27 | def user_reference(_, info, representation): 28 | return get_user_by_id(representation['id']) 29 | 30 | 31 | app = GraphQL(type_defs=type_defs, federation=True) 32 | 33 | if __name__ == '__main__': 34 | uvicorn.run(app, port=8082) 35 | -------------------------------------------------------------------------------- /examples/federation/gateway.js: -------------------------------------------------------------------------------- 1 | const { ApolloServer } = require('apollo-server'); 2 | const { ApolloGateway } = require('@apollo/gateway'); 3 | 4 | // Initialize an ApolloGateway instance and pass it an array of 5 | // your implementing service names and URLs 6 | const gateway = new ApolloGateway({ 7 | serviceList: [ 8 | {name: 'product', url: 'http://localhost:8081'}, 9 | { name: 'account', url: 'http://localhost:8082' }, 10 | { name: 'review', url: 'http://localhost:8083' } 11 | // Define additional services here 12 | ], 13 | }); 14 | 15 | // Pass the ApolloGateway to the ApolloServer constructor 16 | const server = new ApolloServer({ 17 | gateway, 18 | 19 | // Disable subscriptions (not currently supported with ApolloGateway) 20 | subscriptions: false, 21 | }); 22 | 23 | server.listen().then(({ url }) => { 24 | console.log(`🚀 Server ready at ${url}`); 25 | }); 26 | -------------------------------------------------------------------------------- /examples/federation/helper.py: -------------------------------------------------------------------------------- 1 | reviews = [ 2 | {'id': '1', 'authorID': '1', 'product': {'upc': '1'}, 'body': 'Love it!'}, 3 | {'id': '2', 'authorID': '1', 'product': {'upc': '2'}, 'body': 'Too expensive.'}, 4 | {'id': '3', 'authorID': '2', 'product': {'upc': '3'}, 'body': 'Could be better.'}, 5 | {'id': '4', 'authorID': '2', 'product': {'upc': '1'}, 'body': 'Prefer something else.'}, 6 | ] 7 | users = [ 8 | {'id': '1', 'name': 'Ada Lovelace', 'birthDate': '1815-12-10', 'username': '@ada'}, 9 | {'id': '2', 'name': 'Alan Turing', 'birthDate': '1912-06-23', 'username': '@complete'}, 10 | ] 11 | products = [ 12 | {'upc': '1', 'name': 'Table', 'price': 899, 'weight': 100}, 13 | {'upc': '2', 'name': 'Couch', 'price': 1299, 'weight': 1000}, 14 | {'upc': '3', 'name': 'Chair', 'price': 54, 'weight': 50}, 15 | ] 16 | 17 | 18 | def find_one(dict_list, key, value): 19 | for item in dict_list: 20 | if item[key] == value: 21 | return item 22 | 23 | return None 24 | 25 | 26 | def find_many(dict_list, key, value): 27 | return filter(lambda x: x[key] == value, dict_list) 28 | 29 | 30 | def get_review_by_id(review_id): 31 | return find_one(reviews, 'id', review_id) 32 | 33 | 34 | def get_production_by_upc(upc): 35 | return find_one(products, 'upc', upc) 36 | 37 | 38 | def get_user_reviews(user_id): 39 | return find_many(reviews, 'authorID', user_id) 40 | 41 | 42 | def get_product_reviews(upc): 43 | return find_many(reviews, 'product', {'upc': upc}) 44 | 45 | 46 | def get_user_by_id(user_id): 47 | return find_one(users, 'id', user_id) 48 | 49 | -------------------------------------------------------------------------------- /examples/federation/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "federation", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@apollo/federation": { 8 | "version": "0.19.1", 9 | "resolved": "https://registry.npmjs.org/@apollo/federation/-/federation-0.19.1.tgz", 10 | "integrity": "sha512-32l2XoyDZfqwCObm2iazwa2vlsEYHzBLwsoCJccd6pdW8PAoK+IoKWJqNrMTwVYYNvRvd6YI+VtZPGo460GqDA==", 11 | "requires": { 12 | "apollo-graphql": "^0.5.0", 13 | "apollo-server-env": "^2.4.5", 14 | "core-js": "^3.4.0", 15 | "lodash.xorby": "^4.7.0" 16 | } 17 | }, 18 | "@apollo/gateway": { 19 | "version": "0.19.1", 20 | "resolved": "https://registry.npmjs.org/@apollo/gateway/-/gateway-0.19.1.tgz", 21 | "integrity": "sha512-3UlzR/xagO6waIwDkStXE9f/qs+DB8UvFnrmw4MT5Rne/6sh7+05ZiYM8ViAcLgmGUctXuMN1zpHtysjHy+ELg==", 22 | "requires": { 23 | "@apollo/federation": "^0.19.1", 24 | "@types/node-fetch": "2.5.4", 25 | "apollo-engine-reporting-protobuf": "^0.5.2", 26 | "apollo-env": "^0.6.1", 27 | "apollo-graphql": "^0.5.0", 28 | "apollo-server-caching": "^0.5.2", 29 | "apollo-server-core": "^2.16.1", 30 | "apollo-server-env": "^2.4.5", 31 | "apollo-server-errors": "^2.4.2", 32 | "apollo-server-types": "^0.5.1", 33 | "graphql-extensions": "^0.12.4", 34 | "loglevel": "^1.6.1", 35 | "make-fetch-happen": "^8.0.0", 36 | "pretty-format": "^26.0.0" 37 | } 38 | }, 39 | "@apollo/protobufjs": { 40 | "version": "1.0.5", 41 | "resolved": "https://registry.npmjs.org/@apollo/protobufjs/-/protobufjs-1.0.5.tgz", 42 | "integrity": "sha512-ZtyaBH1icCgqwIGb3zrtopV2D5Q8yxibkJzlaViM08eOhTQc7rACdYu0pfORFfhllvdMZ3aq69vifYHszY4gNA==", 43 | "requires": { 44 | "@protobufjs/aspromise": "^1.1.2", 45 | "@protobufjs/base64": "^1.1.2", 46 | "@protobufjs/codegen": "^2.0.4", 47 | "@protobufjs/eventemitter": "^1.1.0", 48 | "@protobufjs/fetch": "^1.1.0", 49 | "@protobufjs/float": "^1.0.2", 50 | "@protobufjs/inquire": "^1.1.0", 51 | "@protobufjs/path": "^1.1.2", 52 | "@protobufjs/pool": "^1.1.0", 53 | "@protobufjs/utf8": "^1.1.0", 54 | "@types/long": "^4.0.0", 55 | "@types/node": "^10.1.0", 56 | "long": "^4.0.0" 57 | }, 58 | "dependencies": { 59 | "@types/node": { 60 | "version": "10.17.28", 61 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.28.tgz", 62 | "integrity": "sha512-dzjES1Egb4c1a89C7lKwQh8pwjYmlOAG9dW1pBgxEk57tMrLnssOfEthz8kdkNaBd7lIqQx7APm5+mZ619IiCQ==" 63 | } 64 | } 65 | }, 66 | "@apollographql/apollo-tools": { 67 | "version": "0.4.8", 68 | "resolved": "https://registry.npmjs.org/@apollographql/apollo-tools/-/apollo-tools-0.4.8.tgz", 69 | "integrity": "sha512-W2+HB8Y7ifowcf3YyPHgDI05izyRtOeZ4MqIr7LbTArtmJ0ZHULWpn84SGMW7NAvTV1tFExpHlveHhnXuJfuGA==", 70 | "requires": { 71 | "apollo-env": "^0.6.5" 72 | } 73 | }, 74 | "@apollographql/graphql-playground-html": { 75 | "version": "1.6.26", 76 | "resolved": "https://registry.npmjs.org/@apollographql/graphql-playground-html/-/graphql-playground-html-1.6.26.tgz", 77 | "integrity": "sha512-XAwXOIab51QyhBxnxySdK3nuMEUohhDsHQ5Rbco/V1vjlP75zZ0ZLHD9dTpXTN8uxKxopb2lUvJTq+M4g2Q0HQ==", 78 | "requires": { 79 | "xss": "^1.0.6" 80 | } 81 | }, 82 | "@apollographql/graphql-upload-8-fork": { 83 | "version": "8.1.3", 84 | "resolved": "https://registry.npmjs.org/@apollographql/graphql-upload-8-fork/-/graphql-upload-8-fork-8.1.3.tgz", 85 | "integrity": "sha512-ssOPUT7euLqDXcdVv3Qs4LoL4BPtfermW1IOouaqEmj36TpHYDmYDIbKoSQxikd9vtMumFnP87OybH7sC9fJ6g==", 86 | "requires": { 87 | "@types/express": "*", 88 | "@types/fs-capacitor": "*", 89 | "@types/koa": "*", 90 | "busboy": "^0.3.1", 91 | "fs-capacitor": "^2.0.4", 92 | "http-errors": "^1.7.3", 93 | "object-path": "^0.11.4" 94 | } 95 | }, 96 | "@jest/types": { 97 | "version": "26.3.0", 98 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.3.0.tgz", 99 | "integrity": "sha512-BDPG23U0qDeAvU4f99haztXwdAg3hz4El95LkAM+tHAqqhiVzRpEGHHU8EDxT/AnxOrA65YjLBwDahdJ9pTLJQ==", 100 | "requires": { 101 | "@types/istanbul-lib-coverage": "^2.0.0", 102 | "@types/istanbul-reports": "^3.0.0", 103 | "@types/node": "*", 104 | "@types/yargs": "^15.0.0", 105 | "chalk": "^4.0.0" 106 | } 107 | }, 108 | "@josephg/resolvable": { 109 | "version": "1.0.1", 110 | "resolved": "https://registry.npmjs.org/@josephg/resolvable/-/resolvable-1.0.1.tgz", 111 | "integrity": "sha512-CtzORUwWTTOTqfVtHaKRJ0I1kNQd1bpn3sUh8I3nJDVY+5/M/Oe1DnEWzPQvqq/xPIIkzzzIP7mfCoAjFRvDhg==" 112 | }, 113 | "@npmcli/move-file": { 114 | "version": "1.0.1", 115 | "resolved": "https://registry.npmjs.org/@npmcli/move-file/-/move-file-1.0.1.tgz", 116 | "integrity": "sha512-Uv6h1sT+0DrblvIrolFtbvM1FgWm+/sy4B3pvLp67Zys+thcukzS5ekn7HsZFGpWP4Q3fYJCljbWQE/XivMRLw==", 117 | "requires": { 118 | "mkdirp": "^1.0.4" 119 | } 120 | }, 121 | "@protobufjs/aspromise": { 122 | "version": "1.1.2", 123 | "resolved": "https://registry.npmjs.org/@protobufjs/aspromise/-/aspromise-1.1.2.tgz", 124 | "integrity": "sha1-m4sMxmPWaafY9vXQiToU00jzD78=" 125 | }, 126 | "@protobufjs/base64": { 127 | "version": "1.1.2", 128 | "resolved": "https://registry.npmjs.org/@protobufjs/base64/-/base64-1.1.2.tgz", 129 | "integrity": "sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==" 130 | }, 131 | "@protobufjs/codegen": { 132 | "version": "2.0.4", 133 | "resolved": "https://registry.npmjs.org/@protobufjs/codegen/-/codegen-2.0.4.tgz", 134 | "integrity": "sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==" 135 | }, 136 | "@protobufjs/eventemitter": { 137 | "version": "1.1.0", 138 | "resolved": "https://registry.npmjs.org/@protobufjs/eventemitter/-/eventemitter-1.1.0.tgz", 139 | "integrity": "sha1-NVy8mLr61ZePntCV85diHx0Ga3A=" 140 | }, 141 | "@protobufjs/fetch": { 142 | "version": "1.1.0", 143 | "resolved": "https://registry.npmjs.org/@protobufjs/fetch/-/fetch-1.1.0.tgz", 144 | "integrity": "sha1-upn7WYYUr2VwDBYZ/wbUVLDYTEU=", 145 | "requires": { 146 | "@protobufjs/aspromise": "^1.1.1", 147 | "@protobufjs/inquire": "^1.1.0" 148 | } 149 | }, 150 | "@protobufjs/float": { 151 | "version": "1.0.2", 152 | "resolved": "https://registry.npmjs.org/@protobufjs/float/-/float-1.0.2.tgz", 153 | "integrity": "sha1-Xp4avctz/Ap8uLKR33jIy9l7h9E=" 154 | }, 155 | "@protobufjs/inquire": { 156 | "version": "1.1.0", 157 | "resolved": "https://registry.npmjs.org/@protobufjs/inquire/-/inquire-1.1.0.tgz", 158 | "integrity": "sha1-/yAOPnzyQp4tyvwRQIKOjMY48Ik=" 159 | }, 160 | "@protobufjs/path": { 161 | "version": "1.1.2", 162 | "resolved": "https://registry.npmjs.org/@protobufjs/path/-/path-1.1.2.tgz", 163 | "integrity": "sha1-bMKyDFya1q0NzP0hynZz2Nf79o0=" 164 | }, 165 | "@protobufjs/pool": { 166 | "version": "1.1.0", 167 | "resolved": "https://registry.npmjs.org/@protobufjs/pool/-/pool-1.1.0.tgz", 168 | "integrity": "sha1-Cf0V8tbTq/qbZbw2ZQbWrXhG/1Q=" 169 | }, 170 | "@protobufjs/utf8": { 171 | "version": "1.1.0", 172 | "resolved": "https://registry.npmjs.org/@protobufjs/utf8/-/utf8-1.1.0.tgz", 173 | "integrity": "sha1-p3c2C1s5oaLlEG+OhY8v0tBgxXA=" 174 | }, 175 | "@tootallnate/once": { 176 | "version": "1.1.2", 177 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 178 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==" 179 | }, 180 | "@types/accepts": { 181 | "version": "1.3.5", 182 | "resolved": "https://registry.npmjs.org/@types/accepts/-/accepts-1.3.5.tgz", 183 | "integrity": "sha512-jOdnI/3qTpHABjM5cx1Hc0sKsPoYCp+DP/GJRGtDlPd7fiV9oXGGIcjW/ZOxLIvjGz8MA+uMZI9metHlgqbgwQ==", 184 | "requires": { 185 | "@types/node": "*" 186 | } 187 | }, 188 | "@types/body-parser": { 189 | "version": "1.19.0", 190 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.0.tgz", 191 | "integrity": "sha512-W98JrE0j2K78swW4ukqMleo8R7h/pFETjM2DQ90MF6XK2i4LO4W3gQ71Lt4w3bfm2EvVSyWHplECvB5sK22yFQ==", 192 | "requires": { 193 | "@types/connect": "*", 194 | "@types/node": "*" 195 | } 196 | }, 197 | "@types/color-name": { 198 | "version": "1.1.1", 199 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 200 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==" 201 | }, 202 | "@types/connect": { 203 | "version": "3.4.33", 204 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.33.tgz", 205 | "integrity": "sha512-2+FrkXY4zllzTNfJth7jOqEHC+enpLeGslEhpnTAkg21GkRrWV4SsAtqchtT4YS9/nODBU2/ZfsBY2X4J/dX7A==", 206 | "requires": { 207 | "@types/node": "*" 208 | } 209 | }, 210 | "@types/content-disposition": { 211 | "version": "0.5.3", 212 | "resolved": "https://registry.npmjs.org/@types/content-disposition/-/content-disposition-0.5.3.tgz", 213 | "integrity": "sha512-P1bffQfhD3O4LW0ioENXUhZ9OIa0Zn+P7M+pWgkCKaT53wVLSq0mrKksCID/FGHpFhRSxRGhgrQmfhRuzwtKdg==" 214 | }, 215 | "@types/cookies": { 216 | "version": "0.7.4", 217 | "resolved": "https://registry.npmjs.org/@types/cookies/-/cookies-0.7.4.tgz", 218 | "integrity": "sha512-oTGtMzZZAVuEjTwCjIh8T8FrC8n/uwy+PG0yTvQcdZ7etoel7C7/3MSd7qrukENTgQtotG7gvBlBojuVs7X5rw==", 219 | "requires": { 220 | "@types/connect": "*", 221 | "@types/express": "*", 222 | "@types/keygrip": "*", 223 | "@types/node": "*" 224 | } 225 | }, 226 | "@types/cors": { 227 | "version": "2.8.10", 228 | "resolved": "https://registry.npmjs.org/@types/cors/-/cors-2.8.10.tgz", 229 | "integrity": "sha512-C7srjHiVG3Ey1nR6d511dtDkCEjxuN9W1HWAEjGq8kpcwmNM6JJkpC0xvabM7BXTG2wDq8Eu33iH9aQKa7IvLQ==" 230 | }, 231 | "@types/express": { 232 | "version": "4.17.7", 233 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.7.tgz", 234 | "integrity": "sha512-dCOT5lcmV/uC2J9k0rPafATeeyz+99xTt54ReX11/LObZgfzJqZNcW27zGhYyX+9iSEGXGt5qLPwRSvBZcLvtQ==", 235 | "requires": { 236 | "@types/body-parser": "*", 237 | "@types/express-serve-static-core": "*", 238 | "@types/qs": "*", 239 | "@types/serve-static": "*" 240 | } 241 | }, 242 | "@types/express-serve-static-core": { 243 | "version": "4.17.9", 244 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.9.tgz", 245 | "integrity": "sha512-DG0BYg6yO+ePW+XoDENYz8zhNGC3jDDEpComMYn7WJc4mY1Us8Rw9ax2YhJXxpyk2SF47PQAoQ0YyVT1a0bEkA==", 246 | "requires": { 247 | "@types/node": "*", 248 | "@types/qs": "*", 249 | "@types/range-parser": "*" 250 | } 251 | }, 252 | "@types/fs-capacitor": { 253 | "version": "2.0.0", 254 | "resolved": "https://registry.npmjs.org/@types/fs-capacitor/-/fs-capacitor-2.0.0.tgz", 255 | "integrity": "sha512-FKVPOCFbhCvZxpVAMhdBdTfVfXUpsh15wFHgqOKxh9N9vzWZVuWCSijZ5T4U34XYNnuj2oduh6xcs1i+LPI+BQ==", 256 | "requires": { 257 | "@types/node": "*" 258 | } 259 | }, 260 | "@types/graphql-upload": { 261 | "version": "8.0.3", 262 | "resolved": "https://registry.npmjs.org/@types/graphql-upload/-/graphql-upload-8.0.3.tgz", 263 | "integrity": "sha512-hmLg9pCU/GmxBscg8GCr1vmSoEmbItNNxdD5YH2TJkXm//8atjwuprB+xJBK714JG1dkxbbhp5RHX+Pz1KsCMA==", 264 | "requires": { 265 | "@types/express": "*", 266 | "@types/fs-capacitor": "*", 267 | "@types/koa": "*", 268 | "graphql": "^14.5.3" 269 | } 270 | }, 271 | "@types/http-assert": { 272 | "version": "1.5.1", 273 | "resolved": "https://registry.npmjs.org/@types/http-assert/-/http-assert-1.5.1.tgz", 274 | "integrity": "sha512-PGAK759pxyfXE78NbKxyfRcWYA/KwW17X290cNev/qAsn9eQIxkH4shoNBafH37wewhDG/0p1cHPbK6+SzZjWQ==" 275 | }, 276 | "@types/http-errors": { 277 | "version": "1.8.0", 278 | "resolved": "https://registry.npmjs.org/@types/http-errors/-/http-errors-1.8.0.tgz", 279 | "integrity": "sha512-2aoSC4UUbHDj2uCsCxcG/vRMXey/m17bC7UwitVm5hn22nI8O8Y9iDpA76Orc+DWkQ4zZrOKEshCqR/jSuXAHA==" 280 | }, 281 | "@types/istanbul-lib-coverage": { 282 | "version": "2.0.3", 283 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.3.tgz", 284 | "integrity": "sha512-sz7iLqvVUg1gIedBOvlkxPlc8/uVzyS5OwGz1cKjXzkl3FpL3al0crU8YGU1WoHkxn0Wxbw5tyi6hvzJKNzFsw==" 285 | }, 286 | "@types/istanbul-lib-report": { 287 | "version": "3.0.0", 288 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 289 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 290 | "requires": { 291 | "@types/istanbul-lib-coverage": "*" 292 | } 293 | }, 294 | "@types/istanbul-reports": { 295 | "version": "3.0.0", 296 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.0.tgz", 297 | "integrity": "sha512-nwKNbvnwJ2/mndE9ItP/zc2TCzw6uuodnF4EHYWD+gCQDVBuRQL5UzbZD0/ezy1iKsFU2ZQiDqg4M9dN4+wZgA==", 298 | "requires": { 299 | "@types/istanbul-lib-report": "*" 300 | } 301 | }, 302 | "@types/keygrip": { 303 | "version": "1.0.2", 304 | "resolved": "https://registry.npmjs.org/@types/keygrip/-/keygrip-1.0.2.tgz", 305 | "integrity": "sha512-GJhpTepz2udxGexqos8wgaBx4I/zWIDPh/KOGEwAqtuGDkOUJu5eFvwmdBX4AmB8Odsr+9pHCQqiAqDL/yKMKw==" 306 | }, 307 | "@types/koa": { 308 | "version": "2.11.4", 309 | "resolved": "https://registry.npmjs.org/@types/koa/-/koa-2.11.4.tgz", 310 | "integrity": "sha512-Etqs0kdqbuAsNr5k6mlZQelpZKVwMu9WPRHVVTLnceZlhr0pYmblRNJbCgoCMzKWWePldydU0AYEOX4Q9fnGUQ==", 311 | "requires": { 312 | "@types/accepts": "*", 313 | "@types/content-disposition": "*", 314 | "@types/cookies": "*", 315 | "@types/http-assert": "*", 316 | "@types/http-errors": "*", 317 | "@types/keygrip": "*", 318 | "@types/koa-compose": "*", 319 | "@types/node": "*" 320 | } 321 | }, 322 | "@types/koa-compose": { 323 | "version": "3.2.5", 324 | "resolved": "https://registry.npmjs.org/@types/koa-compose/-/koa-compose-3.2.5.tgz", 325 | "integrity": "sha512-B8nG/OoE1ORZqCkBVsup/AKcvjdgoHnfi4pZMn5UwAPCbhk/96xyv284eBYW8JlQbQ7zDmnpFr68I/40mFoIBQ==", 326 | "requires": { 327 | "@types/koa": "*" 328 | } 329 | }, 330 | "@types/long": { 331 | "version": "4.0.1", 332 | "resolved": "https://registry.npmjs.org/@types/long/-/long-4.0.1.tgz", 333 | "integrity": "sha512-5tXH6Bx/kNGd3MgffdmP4dy2Z+G4eaXw0SE81Tq3BNadtnMR5/ySMzX4SLEzHJzSmPNn4HIdpQsBvXMUykr58w==" 334 | }, 335 | "@types/mime": { 336 | "version": "2.0.3", 337 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-2.0.3.tgz", 338 | "integrity": "sha512-Jus9s4CDbqwocc5pOAnh8ShfrnMcPHuJYzVcSUU7lrh8Ni5HuIqX3oilL86p3dlTrk0LzHRCgA/GQ7uNCw6l2Q==" 339 | }, 340 | "@types/node": { 341 | "version": "14.6.0", 342 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.6.0.tgz", 343 | "integrity": "sha512-mikldZQitV94akrc4sCcSjtJfsTKt4p+e/s0AGscVA6XArQ9kFclP+ZiYUMnq987rc6QlYxXv/EivqlfSLxpKA==" 344 | }, 345 | "@types/node-fetch": { 346 | "version": "2.5.4", 347 | "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.5.4.tgz", 348 | "integrity": "sha512-Oz6id++2qAOFuOlE1j0ouk1dzl3mmI1+qINPNBhi9nt/gVOz0G+13Ao6qjhdF0Ys+eOkhu6JnFmt38bR3H0POQ==", 349 | "requires": { 350 | "@types/node": "*" 351 | } 352 | }, 353 | "@types/qs": { 354 | "version": "6.9.4", 355 | "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.4.tgz", 356 | "integrity": "sha512-+wYo+L6ZF6BMoEjtf8zB2esQsqdV6WsjRK/GP9WOgLPrq87PbNWgIxS76dS5uvl/QXtHGakZmwTznIfcPXcKlQ==" 357 | }, 358 | "@types/range-parser": { 359 | "version": "1.2.3", 360 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 361 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==" 362 | }, 363 | "@types/serve-static": { 364 | "version": "1.13.5", 365 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.5.tgz", 366 | "integrity": "sha512-6M64P58N+OXjU432WoLLBQxbA0LRGBCRm7aAGQJ+SMC1IMl0dgRVi9EFfoDcS2a7Xogygk/eGN94CfwU9UF7UQ==", 367 | "requires": { 368 | "@types/express-serve-static-core": "*", 369 | "@types/mime": "*" 370 | } 371 | }, 372 | "@types/ws": { 373 | "version": "7.2.6", 374 | "resolved": "https://registry.npmjs.org/@types/ws/-/ws-7.2.6.tgz", 375 | "integrity": "sha512-Q07IrQUSNpr+cXU4E4LtkSIBPie5GLZyyMC1QtQYRLWz701+XcoVygGUZgvLqElq1nU4ICldMYPnexlBsg3dqQ==", 376 | "requires": { 377 | "@types/node": "*" 378 | } 379 | }, 380 | "@types/yargs": { 381 | "version": "15.0.5", 382 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.5.tgz", 383 | "integrity": "sha512-Dk/IDOPtOgubt/IaevIUbTgV7doaKkoorvOyYM2CMwuDyP89bekI7H4xLIwunNYiK9jhCkmc6pUrJk3cj2AB9w==", 384 | "requires": { 385 | "@types/yargs-parser": "*" 386 | } 387 | }, 388 | "@types/yargs-parser": { 389 | "version": "15.0.0", 390 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-15.0.0.tgz", 391 | "integrity": "sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==" 392 | }, 393 | "@wry/equality": { 394 | "version": "0.1.11", 395 | "resolved": "https://registry.npmjs.org/@wry/equality/-/equality-0.1.11.tgz", 396 | "integrity": "sha512-mwEVBDUVODlsQQ5dfuLUS5/Tf7jqUKyhKYHmVi4fPB6bDMOfWvUPJmKgS1Z7Za/sOI3vzWt4+O7yCiL/70MogA==", 397 | "requires": { 398 | "tslib": "^1.9.3" 399 | } 400 | }, 401 | "accepts": { 402 | "version": "1.3.7", 403 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 404 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 405 | "requires": { 406 | "mime-types": "~2.1.24", 407 | "negotiator": "0.6.2" 408 | } 409 | }, 410 | "agent-base": { 411 | "version": "6.0.1", 412 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.1.tgz", 413 | "integrity": "sha512-01q25QQDwLSsyfhrKbn8yuur+JNw0H+0Y4JiGIKd3z9aYk/w/2kxD/Upc+t2ZBBSUNff50VjPsSW2YxM8QYKVg==", 414 | "requires": { 415 | "debug": "4" 416 | } 417 | }, 418 | "agentkeepalive": { 419 | "version": "4.1.3", 420 | "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-4.1.3.tgz", 421 | "integrity": "sha512-wn8fw19xKZwdGPO47jivonaHRTd+nGOMP1z11sgGeQzDy2xd5FG0R67dIMcKHDE2cJ5y+YXV30XVGUBPRSY7Hg==", 422 | "requires": { 423 | "debug": "^4.1.0", 424 | "depd": "^1.1.2", 425 | "humanize-ms": "^1.2.1" 426 | } 427 | }, 428 | "aggregate-error": { 429 | "version": "3.1.0", 430 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 431 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 432 | "requires": { 433 | "clean-stack": "^2.0.0", 434 | "indent-string": "^4.0.0" 435 | } 436 | }, 437 | "ansi-regex": { 438 | "version": "5.0.1", 439 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 440 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==" 441 | }, 442 | "ansi-styles": { 443 | "version": "4.2.1", 444 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 445 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 446 | "requires": { 447 | "@types/color-name": "^1.1.1", 448 | "color-convert": "^2.0.1" 449 | } 450 | }, 451 | "apollo-cache-control": { 452 | "version": "0.11.1", 453 | "resolved": "https://registry.npmjs.org/apollo-cache-control/-/apollo-cache-control-0.11.1.tgz", 454 | "integrity": "sha512-6iHa8TkcKt4rx5SKRzDNjUIpCQX+7/FlZwD7vRh9JDnM4VH8SWhpj8fUR3CiEY8Kuc4ChXnOY8bCcMju5KPnIQ==", 455 | "requires": { 456 | "apollo-server-env": "^2.4.5", 457 | "apollo-server-plugin-base": "^0.9.1" 458 | } 459 | }, 460 | "apollo-datasource": { 461 | "version": "0.7.2", 462 | "resolved": "https://registry.npmjs.org/apollo-datasource/-/apollo-datasource-0.7.2.tgz", 463 | "integrity": "sha512-ibnW+s4BMp4K2AgzLEtvzkjg7dJgCaw9M5b5N0YKNmeRZRnl/I/qBTQae648FsRKgMwTbRQIvBhQ0URUFAqFOw==", 464 | "requires": { 465 | "apollo-server-caching": "^0.5.2", 466 | "apollo-server-env": "^2.4.5" 467 | } 468 | }, 469 | "apollo-engine-reporting": { 470 | "version": "2.3.0", 471 | "resolved": "https://registry.npmjs.org/apollo-engine-reporting/-/apollo-engine-reporting-2.3.0.tgz", 472 | "integrity": "sha512-SbcPLFuUZcRqDEZ6mSs8uHM9Ftr8yyt2IEu0JA8c3LNBmYXSLM7MHqFe80SVcosYSTBgtMz8mLJO8orhYoSYZw==", 473 | "requires": { 474 | "apollo-engine-reporting-protobuf": "^0.5.2", 475 | "apollo-graphql": "^0.5.0", 476 | "apollo-server-caching": "^0.5.2", 477 | "apollo-server-env": "^2.4.5", 478 | "apollo-server-errors": "^2.4.2", 479 | "apollo-server-plugin-base": "^0.9.1", 480 | "apollo-server-types": "^0.5.1", 481 | "async-retry": "^1.2.1", 482 | "uuid": "^8.0.0" 483 | } 484 | }, 485 | "apollo-engine-reporting-protobuf": { 486 | "version": "0.5.2", 487 | "resolved": "https://registry.npmjs.org/apollo-engine-reporting-protobuf/-/apollo-engine-reporting-protobuf-0.5.2.tgz", 488 | "integrity": "sha512-4wm9FR3B7UvJxcK/69rOiS5CAJPEYKufeRWb257ZLfX7NGFTMqvbc1hu4q8Ch7swB26rTpkzfsftLED9DqH9qg==", 489 | "requires": { 490 | "@apollo/protobufjs": "^1.0.3" 491 | } 492 | }, 493 | "apollo-env": { 494 | "version": "0.6.5", 495 | "resolved": "https://registry.npmjs.org/apollo-env/-/apollo-env-0.6.5.tgz", 496 | "integrity": "sha512-jeBUVsGymeTHYWp3me0R2CZRZrFeuSZeICZHCeRflHTfnQtlmbSXdy5E0pOyRM9CU4JfQkKDC98S1YglQj7Bzg==", 497 | "requires": { 498 | "@types/node-fetch": "2.5.7", 499 | "core-js": "^3.0.1", 500 | "node-fetch": "^2.2.0", 501 | "sha.js": "^2.4.11" 502 | }, 503 | "dependencies": { 504 | "@types/node-fetch": { 505 | "version": "2.5.7", 506 | "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.5.7.tgz", 507 | "integrity": "sha512-o2WVNf5UhWRkxlf6eq+jMZDu7kjgpgJfl4xVNlvryc95O/6F2ld8ztKX+qu+Rjyet93WAWm5LjeX9H5FGkODvw==", 508 | "requires": { 509 | "@types/node": "*", 510 | "form-data": "^3.0.0" 511 | } 512 | } 513 | } 514 | }, 515 | "apollo-graphql": { 516 | "version": "0.5.0", 517 | "resolved": "https://registry.npmjs.org/apollo-graphql/-/apollo-graphql-0.5.0.tgz", 518 | "integrity": "sha512-YSdF/BKPbsnQpxWpmCE53pBJX44aaoif31Y22I/qKpB6ZSGzYijV5YBoCL5Q15H2oA/v/02Oazh9lbp4ek3eig==", 519 | "requires": { 520 | "apollo-env": "^0.6.5", 521 | "lodash.sortby": "^4.7.0" 522 | } 523 | }, 524 | "apollo-link": { 525 | "version": "1.2.14", 526 | "resolved": "https://registry.npmjs.org/apollo-link/-/apollo-link-1.2.14.tgz", 527 | "integrity": "sha512-p67CMEFP7kOG1JZ0ZkYZwRDa369w5PIjtMjvrQd/HnIV8FRsHRqLqK+oAZQnFa1DDdZtOtHTi+aMIW6EatC2jg==", 528 | "requires": { 529 | "apollo-utilities": "^1.3.0", 530 | "ts-invariant": "^0.4.0", 531 | "tslib": "^1.9.3", 532 | "zen-observable-ts": "^0.8.21" 533 | } 534 | }, 535 | "apollo-reporting-protobuf": { 536 | "version": "0.8.0", 537 | "resolved": "https://registry.npmjs.org/apollo-reporting-protobuf/-/apollo-reporting-protobuf-0.8.0.tgz", 538 | "integrity": "sha512-B3XmnkH6Y458iV6OsA7AhfwvTgeZnFq9nPVjbxmLKnvfkEl8hYADtz724uPa0WeBiD7DSFcnLtqg9yGmCkBohg==", 539 | "requires": { 540 | "@apollo/protobufjs": "1.2.2" 541 | }, 542 | "dependencies": { 543 | "@apollo/protobufjs": { 544 | "version": "1.2.2", 545 | "resolved": "https://registry.npmjs.org/@apollo/protobufjs/-/protobufjs-1.2.2.tgz", 546 | "integrity": "sha512-vF+zxhPiLtkwxONs6YanSt1EpwpGilThpneExUN5K3tCymuxNnVq2yojTvnpRjv2QfsEIt/n7ozPIIzBLwGIDQ==", 547 | "requires": { 548 | "@protobufjs/aspromise": "^1.1.2", 549 | "@protobufjs/base64": "^1.1.2", 550 | "@protobufjs/codegen": "^2.0.4", 551 | "@protobufjs/eventemitter": "^1.1.0", 552 | "@protobufjs/fetch": "^1.1.0", 553 | "@protobufjs/float": "^1.0.2", 554 | "@protobufjs/inquire": "^1.1.0", 555 | "@protobufjs/path": "^1.1.2", 556 | "@protobufjs/pool": "^1.1.0", 557 | "@protobufjs/utf8": "^1.1.0", 558 | "@types/long": "^4.0.0", 559 | "@types/node": "^10.1.0", 560 | "long": "^4.0.0" 561 | } 562 | }, 563 | "@types/node": { 564 | "version": "10.17.60", 565 | "resolved": "https://registry.npmjs.org/@types/node/-/node-10.17.60.tgz", 566 | "integrity": "sha512-F0KIgDJfy2nA3zMLmWGKxcH2ZVEtCZXHHdOQs2gSaQ27+lNeEfGxzkIw90aXswATX7AZ33tahPbzy6KAfUreVw==" 567 | } 568 | } 569 | }, 570 | "apollo-server": { 571 | "version": "2.25.3", 572 | "resolved": "https://registry.npmjs.org/apollo-server/-/apollo-server-2.25.3.tgz", 573 | "integrity": "sha512-+eUY2//DLkU7RkJLn6CTl1P89/ZMHuUQnWqv8La2iJ2hLT7Me+nMx+hgHl3LqlT/qDstQ8qA45T85FuCayplmQ==", 574 | "requires": { 575 | "apollo-server-core": "^2.25.3", 576 | "apollo-server-express": "^2.25.3", 577 | "express": "^4.0.0", 578 | "graphql-subscriptions": "^1.0.0", 579 | "graphql-tools": "^4.0.8", 580 | "stoppable": "^1.1.0" 581 | }, 582 | "dependencies": { 583 | "@apollographql/apollo-tools": { 584 | "version": "0.5.2", 585 | "resolved": "https://registry.npmjs.org/@apollographql/apollo-tools/-/apollo-tools-0.5.2.tgz", 586 | "integrity": "sha512-KxZiw0Us3k1d0YkJDhOpVH5rJ+mBfjXcgoRoCcslbgirjgLotKMzOcx4PZ7YTEvvEROmvG7X3Aon41GvMmyGsw==" 587 | }, 588 | "@apollographql/graphql-playground-html": { 589 | "version": "1.6.27", 590 | "resolved": "https://registry.npmjs.org/@apollographql/graphql-playground-html/-/graphql-playground-html-1.6.27.tgz", 591 | "integrity": "sha512-tea2LweZvn6y6xFV11K0KC8ETjmm52mQrW+ezgB2O/aTQf8JGyFmMcRPFgUaQZeHbWdm8iisDC6EjOKsXu0nfw==", 592 | "requires": { 593 | "xss": "^1.0.8" 594 | } 595 | }, 596 | "apollo-cache-control": { 597 | "version": "0.14.0", 598 | "resolved": "https://registry.npmjs.org/apollo-cache-control/-/apollo-cache-control-0.14.0.tgz", 599 | "integrity": "sha512-qN4BCq90egQrgNnTRMUHikLZZAprf3gbm8rC5Vwmc6ZdLolQ7bFsa769Hqi6Tq/lS31KLsXBLTOsRbfPHph12w==", 600 | "requires": { 601 | "apollo-server-env": "^3.1.0", 602 | "apollo-server-plugin-base": "^0.13.0" 603 | } 604 | }, 605 | "apollo-datasource": { 606 | "version": "0.9.0", 607 | "resolved": "https://registry.npmjs.org/apollo-datasource/-/apollo-datasource-0.9.0.tgz", 608 | "integrity": "sha512-y8H99NExU1Sk4TvcaUxTdzfq2SZo6uSj5dyh75XSQvbpH6gdAXIW9MaBcvlNC7n0cVPsidHmOcHOWxJ/pTXGjA==", 609 | "requires": { 610 | "apollo-server-caching": "^0.7.0", 611 | "apollo-server-env": "^3.1.0" 612 | } 613 | }, 614 | "apollo-graphql": { 615 | "version": "0.9.5", 616 | "resolved": "https://registry.npmjs.org/apollo-graphql/-/apollo-graphql-0.9.5.tgz", 617 | "integrity": "sha512-RGt5k2JeBqrmnwRM0VOgWFiGKlGJMfmiif/4JvdaEqhMJ+xqe/9cfDYzXfn33ke2eWixsAbjEbRfy8XbaN9nTw==", 618 | "requires": { 619 | "core-js-pure": "^3.10.2", 620 | "lodash.sortby": "^4.7.0", 621 | "sha.js": "^2.4.11" 622 | } 623 | }, 624 | "apollo-server-caching": { 625 | "version": "0.7.0", 626 | "resolved": "https://registry.npmjs.org/apollo-server-caching/-/apollo-server-caching-0.7.0.tgz", 627 | "integrity": "sha512-MsVCuf/2FxuTFVhGLK13B+TZH9tBd2qkyoXKKILIiGcZ5CDUEBO14vIV63aNkMkS1xxvK2U4wBcuuNj/VH2Mkw==", 628 | "requires": { 629 | "lru-cache": "^6.0.0" 630 | } 631 | }, 632 | "apollo-server-core": { 633 | "version": "2.25.3", 634 | "resolved": "https://registry.npmjs.org/apollo-server-core/-/apollo-server-core-2.25.3.tgz", 635 | "integrity": "sha512-Midow3uZoJ9TjFNeCNSiWElTVZlvmB7G7tG6PPoxIR9Px90/v16Q6EzunDIO0rTJHRC3+yCwZkwtf8w2AcP0sA==", 636 | "requires": { 637 | "@apollographql/apollo-tools": "^0.5.0", 638 | "@apollographql/graphql-playground-html": "1.6.27", 639 | "@apollographql/graphql-upload-8-fork": "^8.1.3", 640 | "@josephg/resolvable": "^1.0.0", 641 | "@types/ws": "^7.0.0", 642 | "apollo-cache-control": "^0.14.0", 643 | "apollo-datasource": "^0.9.0", 644 | "apollo-graphql": "^0.9.0", 645 | "apollo-reporting-protobuf": "^0.8.0", 646 | "apollo-server-caching": "^0.7.0", 647 | "apollo-server-env": "^3.1.0", 648 | "apollo-server-errors": "^2.5.0", 649 | "apollo-server-plugin-base": "^0.13.0", 650 | "apollo-server-types": "^0.9.0", 651 | "apollo-tracing": "^0.15.0", 652 | "async-retry": "^1.2.1", 653 | "fast-json-stable-stringify": "^2.0.0", 654 | "graphql-extensions": "^0.15.0", 655 | "graphql-tag": "^2.11.0", 656 | "graphql-tools": "^4.0.8", 657 | "loglevel": "^1.6.7", 658 | "lru-cache": "^6.0.0", 659 | "sha.js": "^2.4.11", 660 | "subscriptions-transport-ws": "^0.9.19", 661 | "uuid": "^8.0.0" 662 | } 663 | }, 664 | "apollo-server-env": { 665 | "version": "3.1.0", 666 | "resolved": "https://registry.npmjs.org/apollo-server-env/-/apollo-server-env-3.1.0.tgz", 667 | "integrity": "sha512-iGdZgEOAuVop3vb0F2J3+kaBVi4caMoxefHosxmgzAbbSpvWehB8Y1QiSyyMeouYC38XNVk5wnZl+jdGSsWsIQ==", 668 | "requires": { 669 | "node-fetch": "^2.6.1", 670 | "util.promisify": "^1.0.0" 671 | } 672 | }, 673 | "apollo-server-errors": { 674 | "version": "2.5.0", 675 | "resolved": "https://registry.npmjs.org/apollo-server-errors/-/apollo-server-errors-2.5.0.tgz", 676 | "integrity": "sha512-lO5oTjgiC3vlVg2RKr3RiXIIQ5pGXBFxYGGUkKDhTud3jMIhs+gel8L8zsEjKaKxkjHhCQAA/bcEfYiKkGQIvA==" 677 | }, 678 | "apollo-server-plugin-base": { 679 | "version": "0.13.0", 680 | "resolved": "https://registry.npmjs.org/apollo-server-plugin-base/-/apollo-server-plugin-base-0.13.0.tgz", 681 | "integrity": "sha512-L3TMmq2YE6BU6I4Tmgygmd0W55L+6XfD9137k+cWEBFu50vRY4Re+d+fL5WuPkk5xSPKd/PIaqzidu5V/zz8Kg==", 682 | "requires": { 683 | "apollo-server-types": "^0.9.0" 684 | } 685 | }, 686 | "apollo-server-types": { 687 | "version": "0.9.0", 688 | "resolved": "https://registry.npmjs.org/apollo-server-types/-/apollo-server-types-0.9.0.tgz", 689 | "integrity": "sha512-qk9tg4Imwpk732JJHBkhW0jzfG0nFsLqK2DY6UhvJf7jLnRePYsPxWfPiNkxni27pLE2tiNlCwoDFSeWqpZyBg==", 690 | "requires": { 691 | "apollo-reporting-protobuf": "^0.8.0", 692 | "apollo-server-caching": "^0.7.0", 693 | "apollo-server-env": "^3.1.0" 694 | } 695 | }, 696 | "apollo-tracing": { 697 | "version": "0.15.0", 698 | "resolved": "https://registry.npmjs.org/apollo-tracing/-/apollo-tracing-0.15.0.tgz", 699 | "integrity": "sha512-UP0fztFvaZPHDhIB/J+qGuy6hWO4If069MGC98qVs0I8FICIGu4/8ykpX3X3K6RtaQ56EDAWKykCxFv4ScxMeA==", 700 | "requires": { 701 | "apollo-server-env": "^3.1.0", 702 | "apollo-server-plugin-base": "^0.13.0" 703 | } 704 | }, 705 | "graphql-extensions": { 706 | "version": "0.15.0", 707 | "resolved": "https://registry.npmjs.org/graphql-extensions/-/graphql-extensions-0.15.0.tgz", 708 | "integrity": "sha512-bVddVO8YFJPwuACn+3pgmrEg6I8iBuYLuwvxiE+lcQQ7POotVZxm2rgGw0PvVYmWWf3DT7nTVDZ5ROh/ALp8mA==", 709 | "requires": { 710 | "@apollographql/apollo-tools": "^0.5.0", 711 | "apollo-server-env": "^3.1.0", 712 | "apollo-server-types": "^0.9.0" 713 | } 714 | }, 715 | "lru-cache": { 716 | "version": "6.0.0", 717 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 718 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 719 | "requires": { 720 | "yallist": "^4.0.0" 721 | } 722 | }, 723 | "subscriptions-transport-ws": { 724 | "version": "0.9.19", 725 | "resolved": "https://registry.npmjs.org/subscriptions-transport-ws/-/subscriptions-transport-ws-0.9.19.tgz", 726 | "integrity": "sha512-dxdemxFFB0ppCLg10FTtRqH/31FNRL1y1BQv8209MK5I4CwALb7iihQg+7p65lFcIl8MHatINWBLOqpgU4Kyyw==", 727 | "requires": { 728 | "backo2": "^1.0.2", 729 | "eventemitter3": "^3.1.0", 730 | "iterall": "^1.2.1", 731 | "symbol-observable": "^1.0.4", 732 | "ws": "^5.2.0 || ^6.0.0 || ^7.0.0" 733 | } 734 | }, 735 | "yallist": { 736 | "version": "4.0.0", 737 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 738 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 739 | } 740 | } 741 | }, 742 | "apollo-server-caching": { 743 | "version": "0.5.2", 744 | "resolved": "https://registry.npmjs.org/apollo-server-caching/-/apollo-server-caching-0.5.2.tgz", 745 | "integrity": "sha512-HUcP3TlgRsuGgeTOn8QMbkdx0hLPXyEJehZIPrcof0ATz7j7aTPA4at7gaiFHCo8gk07DaWYGB3PFgjboXRcWQ==", 746 | "requires": { 747 | "lru-cache": "^5.0.0" 748 | } 749 | }, 750 | "apollo-server-core": { 751 | "version": "2.16.1", 752 | "resolved": "https://registry.npmjs.org/apollo-server-core/-/apollo-server-core-2.16.1.tgz", 753 | "integrity": "sha512-nuwn5ZBbmzPwDetb3FgiFFJlNK7ZBFg8kis/raymrjd3eBGdNcOyMTJDl6J9673X9Xqp+dXQmFYDW/G3G8S1YA==", 754 | "requires": { 755 | "@apollographql/apollo-tools": "^0.4.3", 756 | "@apollographql/graphql-playground-html": "1.6.26", 757 | "@types/graphql-upload": "^8.0.0", 758 | "@types/ws": "^7.0.0", 759 | "apollo-cache-control": "^0.11.1", 760 | "apollo-datasource": "^0.7.2", 761 | "apollo-engine-reporting": "^2.3.0", 762 | "apollo-server-caching": "^0.5.2", 763 | "apollo-server-env": "^2.4.5", 764 | "apollo-server-errors": "^2.4.2", 765 | "apollo-server-plugin-base": "^0.9.1", 766 | "apollo-server-types": "^0.5.1", 767 | "apollo-tracing": "^0.11.1", 768 | "fast-json-stable-stringify": "^2.0.0", 769 | "graphql-extensions": "^0.12.4", 770 | "graphql-tag": "^2.9.2", 771 | "graphql-tools": "^4.0.0", 772 | "graphql-upload": "^8.0.2", 773 | "loglevel": "^1.6.7", 774 | "sha.js": "^2.4.11", 775 | "subscriptions-transport-ws": "^0.9.11", 776 | "ws": "^6.0.0" 777 | } 778 | }, 779 | "apollo-server-env": { 780 | "version": "2.4.5", 781 | "resolved": "https://registry.npmjs.org/apollo-server-env/-/apollo-server-env-2.4.5.tgz", 782 | "integrity": "sha512-nfNhmGPzbq3xCEWT8eRpoHXIPNcNy3QcEoBlzVMjeglrBGryLG2LXwBSPnVmTRRrzUYugX0ULBtgE3rBFNoUgA==", 783 | "requires": { 784 | "node-fetch": "^2.1.2", 785 | "util.promisify": "^1.0.0" 786 | } 787 | }, 788 | "apollo-server-errors": { 789 | "version": "2.4.2", 790 | "resolved": "https://registry.npmjs.org/apollo-server-errors/-/apollo-server-errors-2.4.2.tgz", 791 | "integrity": "sha512-FeGxW3Batn6sUtX3OVVUm7o56EgjxDlmgpTLNyWcLb0j6P8mw9oLNyAm3B+deHA4KNdNHO5BmHS2g1SJYjqPCQ==" 792 | }, 793 | "apollo-server-express": { 794 | "version": "2.25.3", 795 | "resolved": "https://registry.npmjs.org/apollo-server-express/-/apollo-server-express-2.25.3.tgz", 796 | "integrity": "sha512-tTFYn0oKH2qqLwVj7Ez2+MiKleXACODiGh5IxsB7VuYCPMAi9Yl8iUSlwTjQUvgCWfReZjnf0vFL2k5YhDlrtQ==", 797 | "requires": { 798 | "@apollographql/graphql-playground-html": "1.6.27", 799 | "@types/accepts": "^1.3.5", 800 | "@types/body-parser": "1.19.0", 801 | "@types/cors": "2.8.10", 802 | "@types/express": "^4.17.12", 803 | "@types/express-serve-static-core": "^4.17.21", 804 | "accepts": "^1.3.5", 805 | "apollo-server-core": "^2.25.3", 806 | "apollo-server-types": "^0.9.0", 807 | "body-parser": "^1.18.3", 808 | "cors": "^2.8.5", 809 | "express": "^4.17.1", 810 | "graphql-subscriptions": "^1.0.0", 811 | "graphql-tools": "^4.0.8", 812 | "parseurl": "^1.3.2", 813 | "subscriptions-transport-ws": "^0.9.19", 814 | "type-is": "^1.6.16" 815 | }, 816 | "dependencies": { 817 | "@apollographql/apollo-tools": { 818 | "version": "0.5.2", 819 | "resolved": "https://registry.npmjs.org/@apollographql/apollo-tools/-/apollo-tools-0.5.2.tgz", 820 | "integrity": "sha512-KxZiw0Us3k1d0YkJDhOpVH5rJ+mBfjXcgoRoCcslbgirjgLotKMzOcx4PZ7YTEvvEROmvG7X3Aon41GvMmyGsw==" 821 | }, 822 | "@apollographql/graphql-playground-html": { 823 | "version": "1.6.27", 824 | "resolved": "https://registry.npmjs.org/@apollographql/graphql-playground-html/-/graphql-playground-html-1.6.27.tgz", 825 | "integrity": "sha512-tea2LweZvn6y6xFV11K0KC8ETjmm52mQrW+ezgB2O/aTQf8JGyFmMcRPFgUaQZeHbWdm8iisDC6EjOKsXu0nfw==", 826 | "requires": { 827 | "xss": "^1.0.8" 828 | } 829 | }, 830 | "@types/express": { 831 | "version": "4.17.13", 832 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.13.tgz", 833 | "integrity": "sha512-6bSZTPaTIACxn48l50SR+axgrqm6qXFIxrdAKaG6PaJk3+zuUr35hBlgT7vOmJcum+OEaIBLtHV/qloEAFITeA==", 834 | "requires": { 835 | "@types/body-parser": "*", 836 | "@types/express-serve-static-core": "^4.17.18", 837 | "@types/qs": "*", 838 | "@types/serve-static": "*" 839 | } 840 | }, 841 | "@types/express-serve-static-core": { 842 | "version": "4.17.24", 843 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.24.tgz", 844 | "integrity": "sha512-3UJuW+Qxhzwjq3xhwXm2onQcFHn76frIYVbTu+kn24LFxI+dEhdfISDFovPB8VpEgW8oQCTpRuCe+0zJxB7NEA==", 845 | "requires": { 846 | "@types/node": "*", 847 | "@types/qs": "*", 848 | "@types/range-parser": "*" 849 | } 850 | }, 851 | "apollo-cache-control": { 852 | "version": "0.14.0", 853 | "resolved": "https://registry.npmjs.org/apollo-cache-control/-/apollo-cache-control-0.14.0.tgz", 854 | "integrity": "sha512-qN4BCq90egQrgNnTRMUHikLZZAprf3gbm8rC5Vwmc6ZdLolQ7bFsa769Hqi6Tq/lS31KLsXBLTOsRbfPHph12w==", 855 | "requires": { 856 | "apollo-server-env": "^3.1.0", 857 | "apollo-server-plugin-base": "^0.13.0" 858 | } 859 | }, 860 | "apollo-datasource": { 861 | "version": "0.9.0", 862 | "resolved": "https://registry.npmjs.org/apollo-datasource/-/apollo-datasource-0.9.0.tgz", 863 | "integrity": "sha512-y8H99NExU1Sk4TvcaUxTdzfq2SZo6uSj5dyh75XSQvbpH6gdAXIW9MaBcvlNC7n0cVPsidHmOcHOWxJ/pTXGjA==", 864 | "requires": { 865 | "apollo-server-caching": "^0.7.0", 866 | "apollo-server-env": "^3.1.0" 867 | } 868 | }, 869 | "apollo-graphql": { 870 | "version": "0.9.5", 871 | "resolved": "https://registry.npmjs.org/apollo-graphql/-/apollo-graphql-0.9.5.tgz", 872 | "integrity": "sha512-RGt5k2JeBqrmnwRM0VOgWFiGKlGJMfmiif/4JvdaEqhMJ+xqe/9cfDYzXfn33ke2eWixsAbjEbRfy8XbaN9nTw==", 873 | "requires": { 874 | "core-js-pure": "^3.10.2", 875 | "lodash.sortby": "^4.7.0", 876 | "sha.js": "^2.4.11" 877 | } 878 | }, 879 | "apollo-server-caching": { 880 | "version": "0.7.0", 881 | "resolved": "https://registry.npmjs.org/apollo-server-caching/-/apollo-server-caching-0.7.0.tgz", 882 | "integrity": "sha512-MsVCuf/2FxuTFVhGLK13B+TZH9tBd2qkyoXKKILIiGcZ5CDUEBO14vIV63aNkMkS1xxvK2U4wBcuuNj/VH2Mkw==", 883 | "requires": { 884 | "lru-cache": "^6.0.0" 885 | } 886 | }, 887 | "apollo-server-core": { 888 | "version": "2.25.3", 889 | "resolved": "https://registry.npmjs.org/apollo-server-core/-/apollo-server-core-2.25.3.tgz", 890 | "integrity": "sha512-Midow3uZoJ9TjFNeCNSiWElTVZlvmB7G7tG6PPoxIR9Px90/v16Q6EzunDIO0rTJHRC3+yCwZkwtf8w2AcP0sA==", 891 | "requires": { 892 | "@apollographql/apollo-tools": "^0.5.0", 893 | "@apollographql/graphql-playground-html": "1.6.27", 894 | "@apollographql/graphql-upload-8-fork": "^8.1.3", 895 | "@josephg/resolvable": "^1.0.0", 896 | "@types/ws": "^7.0.0", 897 | "apollo-cache-control": "^0.14.0", 898 | "apollo-datasource": "^0.9.0", 899 | "apollo-graphql": "^0.9.0", 900 | "apollo-reporting-protobuf": "^0.8.0", 901 | "apollo-server-caching": "^0.7.0", 902 | "apollo-server-env": "^3.1.0", 903 | "apollo-server-errors": "^2.5.0", 904 | "apollo-server-plugin-base": "^0.13.0", 905 | "apollo-server-types": "^0.9.0", 906 | "apollo-tracing": "^0.15.0", 907 | "async-retry": "^1.2.1", 908 | "fast-json-stable-stringify": "^2.0.0", 909 | "graphql-extensions": "^0.15.0", 910 | "graphql-tag": "^2.11.0", 911 | "graphql-tools": "^4.0.8", 912 | "loglevel": "^1.6.7", 913 | "lru-cache": "^6.0.0", 914 | "sha.js": "^2.4.11", 915 | "subscriptions-transport-ws": "^0.9.19", 916 | "uuid": "^8.0.0" 917 | } 918 | }, 919 | "apollo-server-env": { 920 | "version": "3.1.0", 921 | "resolved": "https://registry.npmjs.org/apollo-server-env/-/apollo-server-env-3.1.0.tgz", 922 | "integrity": "sha512-iGdZgEOAuVop3vb0F2J3+kaBVi4caMoxefHosxmgzAbbSpvWehB8Y1QiSyyMeouYC38XNVk5wnZl+jdGSsWsIQ==", 923 | "requires": { 924 | "node-fetch": "^2.6.1", 925 | "util.promisify": "^1.0.0" 926 | } 927 | }, 928 | "apollo-server-errors": { 929 | "version": "2.5.0", 930 | "resolved": "https://registry.npmjs.org/apollo-server-errors/-/apollo-server-errors-2.5.0.tgz", 931 | "integrity": "sha512-lO5oTjgiC3vlVg2RKr3RiXIIQ5pGXBFxYGGUkKDhTud3jMIhs+gel8L8zsEjKaKxkjHhCQAA/bcEfYiKkGQIvA==" 932 | }, 933 | "apollo-server-plugin-base": { 934 | "version": "0.13.0", 935 | "resolved": "https://registry.npmjs.org/apollo-server-plugin-base/-/apollo-server-plugin-base-0.13.0.tgz", 936 | "integrity": "sha512-L3TMmq2YE6BU6I4Tmgygmd0W55L+6XfD9137k+cWEBFu50vRY4Re+d+fL5WuPkk5xSPKd/PIaqzidu5V/zz8Kg==", 937 | "requires": { 938 | "apollo-server-types": "^0.9.0" 939 | } 940 | }, 941 | "apollo-server-types": { 942 | "version": "0.9.0", 943 | "resolved": "https://registry.npmjs.org/apollo-server-types/-/apollo-server-types-0.9.0.tgz", 944 | "integrity": "sha512-qk9tg4Imwpk732JJHBkhW0jzfG0nFsLqK2DY6UhvJf7jLnRePYsPxWfPiNkxni27pLE2tiNlCwoDFSeWqpZyBg==", 945 | "requires": { 946 | "apollo-reporting-protobuf": "^0.8.0", 947 | "apollo-server-caching": "^0.7.0", 948 | "apollo-server-env": "^3.1.0" 949 | } 950 | }, 951 | "apollo-tracing": { 952 | "version": "0.15.0", 953 | "resolved": "https://registry.npmjs.org/apollo-tracing/-/apollo-tracing-0.15.0.tgz", 954 | "integrity": "sha512-UP0fztFvaZPHDhIB/J+qGuy6hWO4If069MGC98qVs0I8FICIGu4/8ykpX3X3K6RtaQ56EDAWKykCxFv4ScxMeA==", 955 | "requires": { 956 | "apollo-server-env": "^3.1.0", 957 | "apollo-server-plugin-base": "^0.13.0" 958 | } 959 | }, 960 | "graphql-extensions": { 961 | "version": "0.15.0", 962 | "resolved": "https://registry.npmjs.org/graphql-extensions/-/graphql-extensions-0.15.0.tgz", 963 | "integrity": "sha512-bVddVO8YFJPwuACn+3pgmrEg6I8iBuYLuwvxiE+lcQQ7POotVZxm2rgGw0PvVYmWWf3DT7nTVDZ5ROh/ALp8mA==", 964 | "requires": { 965 | "@apollographql/apollo-tools": "^0.5.0", 966 | "apollo-server-env": "^3.1.0", 967 | "apollo-server-types": "^0.9.0" 968 | } 969 | }, 970 | "lru-cache": { 971 | "version": "6.0.0", 972 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 973 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 974 | "requires": { 975 | "yallist": "^4.0.0" 976 | } 977 | }, 978 | "subscriptions-transport-ws": { 979 | "version": "0.9.19", 980 | "resolved": "https://registry.npmjs.org/subscriptions-transport-ws/-/subscriptions-transport-ws-0.9.19.tgz", 981 | "integrity": "sha512-dxdemxFFB0ppCLg10FTtRqH/31FNRL1y1BQv8209MK5I4CwALb7iihQg+7p65lFcIl8MHatINWBLOqpgU4Kyyw==", 982 | "requires": { 983 | "backo2": "^1.0.2", 984 | "eventemitter3": "^3.1.0", 985 | "iterall": "^1.2.1", 986 | "symbol-observable": "^1.0.4", 987 | "ws": "^5.2.0 || ^6.0.0 || ^7.0.0" 988 | } 989 | }, 990 | "yallist": { 991 | "version": "4.0.0", 992 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 993 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 994 | } 995 | } 996 | }, 997 | "apollo-server-plugin-base": { 998 | "version": "0.9.1", 999 | "resolved": "https://registry.npmjs.org/apollo-server-plugin-base/-/apollo-server-plugin-base-0.9.1.tgz", 1000 | "integrity": "sha512-kvrX4Z3FdpjrZdHkyl5iY2A1Wvp4b6KQp00DeZqss7GyyKNUBKr80/7RQgBLEw7EWM7WB19j459xM/TjvW0FKQ==", 1001 | "requires": { 1002 | "apollo-server-types": "^0.5.1" 1003 | } 1004 | }, 1005 | "apollo-server-types": { 1006 | "version": "0.5.1", 1007 | "resolved": "https://registry.npmjs.org/apollo-server-types/-/apollo-server-types-0.5.1.tgz", 1008 | "integrity": "sha512-my2cPw+DAb2qVnIuBcsRKGyS28uIc2vjFxa1NpRoJZe9gK0BWUBk7wzXnIzWy3HZ5Er11e/40MPTUesNfMYNVA==", 1009 | "requires": { 1010 | "apollo-engine-reporting-protobuf": "^0.5.2", 1011 | "apollo-server-caching": "^0.5.2", 1012 | "apollo-server-env": "^2.4.5" 1013 | } 1014 | }, 1015 | "apollo-tracing": { 1016 | "version": "0.11.1", 1017 | "resolved": "https://registry.npmjs.org/apollo-tracing/-/apollo-tracing-0.11.1.tgz", 1018 | "integrity": "sha512-l7g+uILw7v32GA46IRXIx5XXbZhFI96BhSqrGK9yyvfq+NMcvVZrj3kIhRImPGhAjMdV+5biA/jztabElAbDjg==", 1019 | "requires": { 1020 | "apollo-server-env": "^2.4.5", 1021 | "apollo-server-plugin-base": "^0.9.1" 1022 | } 1023 | }, 1024 | "apollo-utilities": { 1025 | "version": "1.3.4", 1026 | "resolved": "https://registry.npmjs.org/apollo-utilities/-/apollo-utilities-1.3.4.tgz", 1027 | "integrity": "sha512-pk2hiWrCXMAy2fRPwEyhvka+mqwzeP60Jr1tRYi5xru+3ko94HI9o6lK0CT33/w4RDlxWchmdhDCrvdr+pHCig==", 1028 | "requires": { 1029 | "@wry/equality": "^0.1.2", 1030 | "fast-json-stable-stringify": "^2.0.0", 1031 | "ts-invariant": "^0.4.0", 1032 | "tslib": "^1.10.0" 1033 | } 1034 | }, 1035 | "array-flatten": { 1036 | "version": "1.1.1", 1037 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 1038 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" 1039 | }, 1040 | "async-limiter": { 1041 | "version": "1.0.1", 1042 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", 1043 | "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" 1044 | }, 1045 | "async-retry": { 1046 | "version": "1.3.1", 1047 | "resolved": "https://registry.npmjs.org/async-retry/-/async-retry-1.3.1.tgz", 1048 | "integrity": "sha512-aiieFW/7h3hY0Bq5d+ktDBejxuwR78vRu9hDUdR8rNhSaQ29VzPL4AoIRG7D/c7tdenwOcKvgPM6tIxB3cB6HA==", 1049 | "requires": { 1050 | "retry": "0.12.0" 1051 | } 1052 | }, 1053 | "asynckit": { 1054 | "version": "0.4.0", 1055 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 1056 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" 1057 | }, 1058 | "backo2": { 1059 | "version": "1.0.2", 1060 | "resolved": "https://registry.npmjs.org/backo2/-/backo2-1.0.2.tgz", 1061 | "integrity": "sha1-MasayLEpNjRj41s+u2n038+6eUc=" 1062 | }, 1063 | "balanced-match": { 1064 | "version": "1.0.0", 1065 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1066 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 1067 | }, 1068 | "body-parser": { 1069 | "version": "1.19.0", 1070 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 1071 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 1072 | "requires": { 1073 | "bytes": "3.1.0", 1074 | "content-type": "~1.0.4", 1075 | "debug": "2.6.9", 1076 | "depd": "~1.1.2", 1077 | "http-errors": "1.7.2", 1078 | "iconv-lite": "0.4.24", 1079 | "on-finished": "~2.3.0", 1080 | "qs": "6.7.0", 1081 | "raw-body": "2.4.0", 1082 | "type-is": "~1.6.17" 1083 | }, 1084 | "dependencies": { 1085 | "debug": { 1086 | "version": "2.6.9", 1087 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1088 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1089 | "requires": { 1090 | "ms": "2.0.0" 1091 | } 1092 | }, 1093 | "http-errors": { 1094 | "version": "1.7.2", 1095 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 1096 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 1097 | "requires": { 1098 | "depd": "~1.1.2", 1099 | "inherits": "2.0.3", 1100 | "setprototypeof": "1.1.1", 1101 | "statuses": ">= 1.5.0 < 2", 1102 | "toidentifier": "1.0.0" 1103 | } 1104 | }, 1105 | "iconv-lite": { 1106 | "version": "0.4.24", 1107 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1108 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1109 | "requires": { 1110 | "safer-buffer": ">= 2.1.2 < 3" 1111 | } 1112 | }, 1113 | "inherits": { 1114 | "version": "2.0.3", 1115 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1116 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 1117 | }, 1118 | "ms": { 1119 | "version": "2.0.0", 1120 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1121 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1122 | }, 1123 | "setprototypeof": { 1124 | "version": "1.1.1", 1125 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1126 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1127 | } 1128 | } 1129 | }, 1130 | "brace-expansion": { 1131 | "version": "1.1.11", 1132 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1133 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1134 | "requires": { 1135 | "balanced-match": "^1.0.0", 1136 | "concat-map": "0.0.1" 1137 | } 1138 | }, 1139 | "busboy": { 1140 | "version": "0.3.1", 1141 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-0.3.1.tgz", 1142 | "integrity": "sha512-y7tTxhGKXcyBxRKAni+awqx8uqaJKrSFSNFSeRG5CsWNdmy2BIK+6VGWEW7TZnIO/533mtMEA4rOevQV815YJw==", 1143 | "requires": { 1144 | "dicer": "0.3.0" 1145 | } 1146 | }, 1147 | "bytes": { 1148 | "version": "3.1.0", 1149 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 1150 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" 1151 | }, 1152 | "cacache": { 1153 | "version": "15.0.5", 1154 | "resolved": "https://registry.npmjs.org/cacache/-/cacache-15.0.5.tgz", 1155 | "integrity": "sha512-lloiL22n7sOjEEXdL8NAjTgv9a1u43xICE9/203qonkZUCj5X1UEWIdf2/Y0d6QcCtMzbKQyhrcDbdvlZTs/+A==", 1156 | "requires": { 1157 | "@npmcli/move-file": "^1.0.1", 1158 | "chownr": "^2.0.0", 1159 | "fs-minipass": "^2.0.0", 1160 | "glob": "^7.1.4", 1161 | "infer-owner": "^1.0.4", 1162 | "lru-cache": "^6.0.0", 1163 | "minipass": "^3.1.1", 1164 | "minipass-collect": "^1.0.2", 1165 | "minipass-flush": "^1.0.5", 1166 | "minipass-pipeline": "^1.2.2", 1167 | "mkdirp": "^1.0.3", 1168 | "p-map": "^4.0.0", 1169 | "promise-inflight": "^1.0.1", 1170 | "rimraf": "^3.0.2", 1171 | "ssri": "^8.0.0", 1172 | "tar": "^6.0.2", 1173 | "unique-filename": "^1.1.1" 1174 | }, 1175 | "dependencies": { 1176 | "lru-cache": { 1177 | "version": "6.0.0", 1178 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1179 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1180 | "requires": { 1181 | "yallist": "^4.0.0" 1182 | } 1183 | }, 1184 | "yallist": { 1185 | "version": "4.0.0", 1186 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1187 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1188 | } 1189 | } 1190 | }, 1191 | "chalk": { 1192 | "version": "4.1.0", 1193 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz", 1194 | "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==", 1195 | "requires": { 1196 | "ansi-styles": "^4.1.0", 1197 | "supports-color": "^7.1.0" 1198 | } 1199 | }, 1200 | "chownr": { 1201 | "version": "2.0.0", 1202 | "resolved": "https://registry.npmjs.org/chownr/-/chownr-2.0.0.tgz", 1203 | "integrity": "sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==" 1204 | }, 1205 | "clean-stack": { 1206 | "version": "2.2.0", 1207 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 1208 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==" 1209 | }, 1210 | "color-convert": { 1211 | "version": "2.0.1", 1212 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1213 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1214 | "requires": { 1215 | "color-name": "~1.1.4" 1216 | } 1217 | }, 1218 | "color-name": { 1219 | "version": "1.1.4", 1220 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1221 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" 1222 | }, 1223 | "combined-stream": { 1224 | "version": "1.0.8", 1225 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1226 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1227 | "requires": { 1228 | "delayed-stream": "~1.0.0" 1229 | } 1230 | }, 1231 | "commander": { 1232 | "version": "2.20.3", 1233 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 1234 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" 1235 | }, 1236 | "concat-map": { 1237 | "version": "0.0.1", 1238 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1239 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 1240 | }, 1241 | "content-disposition": { 1242 | "version": "0.5.3", 1243 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 1244 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 1245 | "requires": { 1246 | "safe-buffer": "5.1.2" 1247 | }, 1248 | "dependencies": { 1249 | "safe-buffer": { 1250 | "version": "5.1.2", 1251 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1252 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1253 | } 1254 | } 1255 | }, 1256 | "content-type": { 1257 | "version": "1.0.4", 1258 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 1259 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" 1260 | }, 1261 | "cookie": { 1262 | "version": "0.4.0", 1263 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 1264 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" 1265 | }, 1266 | "cookie-signature": { 1267 | "version": "1.0.6", 1268 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 1269 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" 1270 | }, 1271 | "core-js": { 1272 | "version": "3.6.5", 1273 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.6.5.tgz", 1274 | "integrity": "sha512-vZVEEwZoIsI+vPEuoF9Iqf5H7/M3eeQqWlQnYa8FSKKePuYTf5MWnxb5SDAzCa60b3JBRS5g9b+Dq7b1y/RCrA==" 1275 | }, 1276 | "core-js-pure": { 1277 | "version": "3.19.1", 1278 | "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.19.1.tgz", 1279 | "integrity": "sha512-Q0Knr8Es84vtv62ei6/6jXH/7izKmOrtrxH9WJTHLCMAVeU+8TF8z8Nr08CsH4Ot0oJKzBzJJL9SJBYIv7WlfQ==" 1280 | }, 1281 | "cors": { 1282 | "version": "2.8.5", 1283 | "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", 1284 | "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", 1285 | "requires": { 1286 | "object-assign": "^4", 1287 | "vary": "^1" 1288 | } 1289 | }, 1290 | "cssfilter": { 1291 | "version": "0.0.10", 1292 | "resolved": "https://registry.npmjs.org/cssfilter/-/cssfilter-0.0.10.tgz", 1293 | "integrity": "sha1-xtJnJjKi5cg+AT5oZKQs6N79IK4=" 1294 | }, 1295 | "debug": { 1296 | "version": "4.1.1", 1297 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1298 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1299 | "requires": { 1300 | "ms": "^2.1.1" 1301 | } 1302 | }, 1303 | "define-properties": { 1304 | "version": "1.1.3", 1305 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 1306 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 1307 | "requires": { 1308 | "object-keys": "^1.0.12" 1309 | } 1310 | }, 1311 | "delayed-stream": { 1312 | "version": "1.0.0", 1313 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1314 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" 1315 | }, 1316 | "depd": { 1317 | "version": "1.1.2", 1318 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 1319 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" 1320 | }, 1321 | "deprecated-decorator": { 1322 | "version": "0.1.6", 1323 | "resolved": "https://registry.npmjs.org/deprecated-decorator/-/deprecated-decorator-0.1.6.tgz", 1324 | "integrity": "sha1-AJZjF7ehL+kvPMgx91g68ym4bDc=" 1325 | }, 1326 | "destroy": { 1327 | "version": "1.0.4", 1328 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 1329 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" 1330 | }, 1331 | "dicer": { 1332 | "version": "0.3.0", 1333 | "resolved": "https://registry.npmjs.org/dicer/-/dicer-0.3.0.tgz", 1334 | "integrity": "sha512-MdceRRWqltEG2dZqO769g27N/3PXfcKl04VhYnBlo2YhH7zPi88VebsjTKclaOyiuMaGU72hTfw3VkUitGcVCA==", 1335 | "requires": { 1336 | "streamsearch": "0.1.2" 1337 | } 1338 | }, 1339 | "ee-first": { 1340 | "version": "1.1.1", 1341 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 1342 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" 1343 | }, 1344 | "encodeurl": { 1345 | "version": "1.0.2", 1346 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 1347 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" 1348 | }, 1349 | "encoding": { 1350 | "version": "0.1.13", 1351 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", 1352 | "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", 1353 | "optional": true, 1354 | "requires": { 1355 | "iconv-lite": "^0.6.2" 1356 | } 1357 | }, 1358 | "err-code": { 1359 | "version": "1.1.2", 1360 | "resolved": "https://registry.npmjs.org/err-code/-/err-code-1.1.2.tgz", 1361 | "integrity": "sha1-BuARbTAo9q70gGhJ6w6mp0iuaWA=" 1362 | }, 1363 | "es-abstract": { 1364 | "version": "1.17.6", 1365 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.6.tgz", 1366 | "integrity": "sha512-Fr89bON3WFyUi5EvAeI48QTWX0AyekGgLA8H+c+7fbfCkJwRWRMLd8CQedNEyJuoYYhmtEqY92pgte1FAhBlhw==", 1367 | "requires": { 1368 | "es-to-primitive": "^1.2.1", 1369 | "function-bind": "^1.1.1", 1370 | "has": "^1.0.3", 1371 | "has-symbols": "^1.0.1", 1372 | "is-callable": "^1.2.0", 1373 | "is-regex": "^1.1.0", 1374 | "object-inspect": "^1.7.0", 1375 | "object-keys": "^1.1.1", 1376 | "object.assign": "^4.1.0", 1377 | "string.prototype.trimend": "^1.0.1", 1378 | "string.prototype.trimstart": "^1.0.1" 1379 | } 1380 | }, 1381 | "es-to-primitive": { 1382 | "version": "1.2.1", 1383 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 1384 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 1385 | "requires": { 1386 | "is-callable": "^1.1.4", 1387 | "is-date-object": "^1.0.1", 1388 | "is-symbol": "^1.0.2" 1389 | } 1390 | }, 1391 | "escape-html": { 1392 | "version": "1.0.3", 1393 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 1394 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" 1395 | }, 1396 | "etag": { 1397 | "version": "1.8.1", 1398 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 1399 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" 1400 | }, 1401 | "eventemitter3": { 1402 | "version": "3.1.2", 1403 | "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-3.1.2.tgz", 1404 | "integrity": "sha512-tvtQIeLVHjDkJYnzf2dgVMxfuSGJeM/7UCG17TT4EumTfNtF+0nebF/4zWOIkCreAbtNqhGEboB6BWrwqNaw4Q==" 1405 | }, 1406 | "express": { 1407 | "version": "4.17.1", 1408 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 1409 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 1410 | "requires": { 1411 | "accepts": "~1.3.7", 1412 | "array-flatten": "1.1.1", 1413 | "body-parser": "1.19.0", 1414 | "content-disposition": "0.5.3", 1415 | "content-type": "~1.0.4", 1416 | "cookie": "0.4.0", 1417 | "cookie-signature": "1.0.6", 1418 | "debug": "2.6.9", 1419 | "depd": "~1.1.2", 1420 | "encodeurl": "~1.0.2", 1421 | "escape-html": "~1.0.3", 1422 | "etag": "~1.8.1", 1423 | "finalhandler": "~1.1.2", 1424 | "fresh": "0.5.2", 1425 | "merge-descriptors": "1.0.1", 1426 | "methods": "~1.1.2", 1427 | "on-finished": "~2.3.0", 1428 | "parseurl": "~1.3.3", 1429 | "path-to-regexp": "0.1.7", 1430 | "proxy-addr": "~2.0.5", 1431 | "qs": "6.7.0", 1432 | "range-parser": "~1.2.1", 1433 | "safe-buffer": "5.1.2", 1434 | "send": "0.17.1", 1435 | "serve-static": "1.14.1", 1436 | "setprototypeof": "1.1.1", 1437 | "statuses": "~1.5.0", 1438 | "type-is": "~1.6.18", 1439 | "utils-merge": "1.0.1", 1440 | "vary": "~1.1.2" 1441 | }, 1442 | "dependencies": { 1443 | "debug": { 1444 | "version": "2.6.9", 1445 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1446 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1447 | "requires": { 1448 | "ms": "2.0.0" 1449 | } 1450 | }, 1451 | "ms": { 1452 | "version": "2.0.0", 1453 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1454 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1455 | }, 1456 | "safe-buffer": { 1457 | "version": "5.1.2", 1458 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1459 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1460 | }, 1461 | "setprototypeof": { 1462 | "version": "1.1.1", 1463 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1464 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 1465 | } 1466 | } 1467 | }, 1468 | "fast-json-stable-stringify": { 1469 | "version": "2.1.0", 1470 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1471 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" 1472 | }, 1473 | "finalhandler": { 1474 | "version": "1.1.2", 1475 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 1476 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 1477 | "requires": { 1478 | "debug": "2.6.9", 1479 | "encodeurl": "~1.0.2", 1480 | "escape-html": "~1.0.3", 1481 | "on-finished": "~2.3.0", 1482 | "parseurl": "~1.3.3", 1483 | "statuses": "~1.5.0", 1484 | "unpipe": "~1.0.0" 1485 | }, 1486 | "dependencies": { 1487 | "debug": { 1488 | "version": "2.6.9", 1489 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1490 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1491 | "requires": { 1492 | "ms": "2.0.0" 1493 | } 1494 | }, 1495 | "ms": { 1496 | "version": "2.0.0", 1497 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1498 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1499 | } 1500 | } 1501 | }, 1502 | "form-data": { 1503 | "version": "3.0.0", 1504 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.0.tgz", 1505 | "integrity": "sha512-CKMFDglpbMi6PyN+brwB9Q/GOw0eAnsrEZDgcsH5Krhz5Od/haKHAX0NmQfha2zPPz0JpWzA7GJHGSnvCRLWsg==", 1506 | "requires": { 1507 | "asynckit": "^0.4.0", 1508 | "combined-stream": "^1.0.8", 1509 | "mime-types": "^2.1.12" 1510 | } 1511 | }, 1512 | "forwarded": { 1513 | "version": "0.2.0", 1514 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 1515 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==" 1516 | }, 1517 | "fresh": { 1518 | "version": "0.5.2", 1519 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 1520 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" 1521 | }, 1522 | "fs-capacitor": { 1523 | "version": "2.0.4", 1524 | "resolved": "https://registry.npmjs.org/fs-capacitor/-/fs-capacitor-2.0.4.tgz", 1525 | "integrity": "sha512-8S4f4WsCryNw2mJJchi46YgB6CR5Ze+4L1h8ewl9tEpL4SJ3ZO+c/bS4BWhB8bK+O3TMqhuZarTitd0S0eh2pA==" 1526 | }, 1527 | "fs-minipass": { 1528 | "version": "2.1.0", 1529 | "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", 1530 | "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", 1531 | "requires": { 1532 | "minipass": "^3.0.0" 1533 | } 1534 | }, 1535 | "fs.realpath": { 1536 | "version": "1.0.0", 1537 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1538 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 1539 | }, 1540 | "function-bind": { 1541 | "version": "1.1.1", 1542 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1543 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 1544 | }, 1545 | "glob": { 1546 | "version": "7.1.6", 1547 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1548 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1549 | "requires": { 1550 | "fs.realpath": "^1.0.0", 1551 | "inflight": "^1.0.4", 1552 | "inherits": "2", 1553 | "minimatch": "^3.0.4", 1554 | "once": "^1.3.0", 1555 | "path-is-absolute": "^1.0.0" 1556 | } 1557 | }, 1558 | "graphql": { 1559 | "version": "14.7.0", 1560 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-14.7.0.tgz", 1561 | "integrity": "sha512-l0xWZpoPKpppFzMfvVyFmp9vLN7w/ZZJPefUicMCepfJeQ8sMcztloGYY9DfjVPo6tIUDzU5Hw3MUbIjj9AVVA==", 1562 | "requires": { 1563 | "iterall": "^1.2.2" 1564 | } 1565 | }, 1566 | "graphql-extensions": { 1567 | "version": "0.12.4", 1568 | "resolved": "https://registry.npmjs.org/graphql-extensions/-/graphql-extensions-0.12.4.tgz", 1569 | "integrity": "sha512-GnR4LiWk3s2bGOqIh6V1JgnSXw2RCH4NOgbCFEWvB6JqWHXTlXnLZ8bRSkCiD4pltv7RHUPWqN/sGh8R6Ae/ag==", 1570 | "requires": { 1571 | "@apollographql/apollo-tools": "^0.4.3", 1572 | "apollo-server-env": "^2.4.5", 1573 | "apollo-server-types": "^0.5.1" 1574 | } 1575 | }, 1576 | "graphql-subscriptions": { 1577 | "version": "1.2.1", 1578 | "resolved": "https://registry.npmjs.org/graphql-subscriptions/-/graphql-subscriptions-1.2.1.tgz", 1579 | "integrity": "sha512-95yD/tKi24q8xYa7Q9rhQN16AYj5wPbrb8tmHGM3WRc9EBmWrG/0kkMl+tQG8wcEuE9ibR4zyOM31p5Sdr2v4g==", 1580 | "requires": { 1581 | "iterall": "^1.3.0" 1582 | } 1583 | }, 1584 | "graphql-tag": { 1585 | "version": "2.11.0", 1586 | "resolved": "https://registry.npmjs.org/graphql-tag/-/graphql-tag-2.11.0.tgz", 1587 | "integrity": "sha512-VmsD5pJqWJnQZMUeRwrDhfgoyqcfwEkvtpANqcoUG8/tOLkwNgU9mzub/Mc78OJMhHjx7gfAMTxzdG43VGg3bA==" 1588 | }, 1589 | "graphql-tools": { 1590 | "version": "4.0.8", 1591 | "resolved": "https://registry.npmjs.org/graphql-tools/-/graphql-tools-4.0.8.tgz", 1592 | "integrity": "sha512-MW+ioleBrwhRjalKjYaLQbr+920pHBgy9vM/n47sswtns8+96sRn5M/G+J1eu7IMeKWiN/9p6tmwCHU7552VJg==", 1593 | "requires": { 1594 | "apollo-link": "^1.2.14", 1595 | "apollo-utilities": "^1.0.1", 1596 | "deprecated-decorator": "^0.1.6", 1597 | "iterall": "^1.1.3", 1598 | "uuid": "^3.1.0" 1599 | }, 1600 | "dependencies": { 1601 | "uuid": { 1602 | "version": "3.4.0", 1603 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1604 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" 1605 | } 1606 | } 1607 | }, 1608 | "graphql-upload": { 1609 | "version": "8.1.0", 1610 | "resolved": "https://registry.npmjs.org/graphql-upload/-/graphql-upload-8.1.0.tgz", 1611 | "integrity": "sha512-U2OiDI5VxYmzRKw0Z2dmfk0zkqMRaecH9Smh1U277gVgVe9Qn+18xqf4skwr4YJszGIh7iQDZ57+5ygOK9sM/Q==", 1612 | "requires": { 1613 | "busboy": "^0.3.1", 1614 | "fs-capacitor": "^2.0.4", 1615 | "http-errors": "^1.7.3", 1616 | "object-path": "^0.11.4" 1617 | } 1618 | }, 1619 | "has": { 1620 | "version": "1.0.3", 1621 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1622 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1623 | "requires": { 1624 | "function-bind": "^1.1.1" 1625 | } 1626 | }, 1627 | "has-flag": { 1628 | "version": "4.0.0", 1629 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1630 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" 1631 | }, 1632 | "has-symbols": { 1633 | "version": "1.0.1", 1634 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", 1635 | "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==" 1636 | }, 1637 | "http-cache-semantics": { 1638 | "version": "4.1.0", 1639 | "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz", 1640 | "integrity": "sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ==" 1641 | }, 1642 | "http-errors": { 1643 | "version": "1.8.0", 1644 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.8.0.tgz", 1645 | "integrity": "sha512-4I8r0C5JDhT5VkvI47QktDW75rNlGVsUf/8hzjCC/wkWI/jdTRmBb9aI7erSG82r1bjKY3F6k28WnsVxB1C73A==", 1646 | "requires": { 1647 | "depd": "~1.1.2", 1648 | "inherits": "2.0.4", 1649 | "setprototypeof": "1.2.0", 1650 | "statuses": ">= 1.5.0 < 2", 1651 | "toidentifier": "1.0.0" 1652 | } 1653 | }, 1654 | "http-proxy-agent": { 1655 | "version": "4.0.1", 1656 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1657 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1658 | "requires": { 1659 | "@tootallnate/once": "1", 1660 | "agent-base": "6", 1661 | "debug": "4" 1662 | } 1663 | }, 1664 | "https-proxy-agent": { 1665 | "version": "5.0.0", 1666 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 1667 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 1668 | "requires": { 1669 | "agent-base": "6", 1670 | "debug": "4" 1671 | } 1672 | }, 1673 | "humanize-ms": { 1674 | "version": "1.2.1", 1675 | "resolved": "https://registry.npmjs.org/humanize-ms/-/humanize-ms-1.2.1.tgz", 1676 | "integrity": "sha1-xG4xWaKT9riW2ikxbYtv6Lt5u+0=", 1677 | "requires": { 1678 | "ms": "^2.0.0" 1679 | } 1680 | }, 1681 | "iconv-lite": { 1682 | "version": "0.6.2", 1683 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.2.tgz", 1684 | "integrity": "sha512-2y91h5OpQlolefMPmUlivelittSWy0rP+oYVpn6A7GwVHNE8AWzoYOBNmlwks3LobaJxgHCYZAnyNo2GgpNRNQ==", 1685 | "optional": true, 1686 | "requires": { 1687 | "safer-buffer": ">= 2.1.2 < 3.0.0" 1688 | } 1689 | }, 1690 | "imurmurhash": { 1691 | "version": "0.1.4", 1692 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1693 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" 1694 | }, 1695 | "indent-string": { 1696 | "version": "4.0.0", 1697 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 1698 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==" 1699 | }, 1700 | "infer-owner": { 1701 | "version": "1.0.4", 1702 | "resolved": "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz", 1703 | "integrity": "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==" 1704 | }, 1705 | "inflight": { 1706 | "version": "1.0.6", 1707 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1708 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1709 | "requires": { 1710 | "once": "^1.3.0", 1711 | "wrappy": "1" 1712 | } 1713 | }, 1714 | "inherits": { 1715 | "version": "2.0.4", 1716 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1717 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 1718 | }, 1719 | "ip": { 1720 | "version": "1.1.5", 1721 | "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", 1722 | "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" 1723 | }, 1724 | "ipaddr.js": { 1725 | "version": "1.9.1", 1726 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 1727 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" 1728 | }, 1729 | "is-callable": { 1730 | "version": "1.2.0", 1731 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.0.tgz", 1732 | "integrity": "sha512-pyVD9AaGLxtg6srb2Ng6ynWJqkHU9bEM087AKck0w8QwDarTfNcpIYoU8x8Hv2Icm8u6kFJM18Dag8lyqGkviw==" 1733 | }, 1734 | "is-date-object": { 1735 | "version": "1.0.2", 1736 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", 1737 | "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==" 1738 | }, 1739 | "is-lambda": { 1740 | "version": "1.0.1", 1741 | "resolved": "https://registry.npmjs.org/is-lambda/-/is-lambda-1.0.1.tgz", 1742 | "integrity": "sha1-PZh3iZ5qU+/AFgUEzeFfgubwYdU=" 1743 | }, 1744 | "is-regex": { 1745 | "version": "1.1.1", 1746 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.1.tgz", 1747 | "integrity": "sha512-1+QkEcxiLlB7VEyFtyBg94e08OAsvq7FUBgApTq/w2ymCLyKJgDPsybBENVtA7XCQEgEXxKPonG+mvYRxh/LIg==", 1748 | "requires": { 1749 | "has-symbols": "^1.0.1" 1750 | } 1751 | }, 1752 | "is-symbol": { 1753 | "version": "1.0.3", 1754 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", 1755 | "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", 1756 | "requires": { 1757 | "has-symbols": "^1.0.1" 1758 | } 1759 | }, 1760 | "iterall": { 1761 | "version": "1.3.0", 1762 | "resolved": "https://registry.npmjs.org/iterall/-/iterall-1.3.0.tgz", 1763 | "integrity": "sha512-QZ9qOMdF+QLHxy1QIpUHUU1D5pS2CG2P69LF6L6CPjPYA/XMOmKV3PZpawHoAjHNyB0swdVTRxdYT4tbBbxqwg==" 1764 | }, 1765 | "lodash.sortby": { 1766 | "version": "4.7.0", 1767 | "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", 1768 | "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=" 1769 | }, 1770 | "lodash.xorby": { 1771 | "version": "4.7.0", 1772 | "resolved": "https://registry.npmjs.org/lodash.xorby/-/lodash.xorby-4.7.0.tgz", 1773 | "integrity": "sha1-nBmm+fBjputT3QPBtocXmYAUY9c=" 1774 | }, 1775 | "loglevel": { 1776 | "version": "1.6.8", 1777 | "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.6.8.tgz", 1778 | "integrity": "sha512-bsU7+gc9AJ2SqpzxwU3+1fedl8zAntbtC5XYlt3s2j1hJcn2PsXSmgN8TaLG/J1/2mod4+cE/3vNL70/c1RNCA==" 1779 | }, 1780 | "long": { 1781 | "version": "4.0.0", 1782 | "resolved": "https://registry.npmjs.org/long/-/long-4.0.0.tgz", 1783 | "integrity": "sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==" 1784 | }, 1785 | "lru-cache": { 1786 | "version": "5.1.1", 1787 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", 1788 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", 1789 | "requires": { 1790 | "yallist": "^3.0.2" 1791 | } 1792 | }, 1793 | "make-fetch-happen": { 1794 | "version": "8.0.9", 1795 | "resolved": "https://registry.npmjs.org/make-fetch-happen/-/make-fetch-happen-8.0.9.tgz", 1796 | "integrity": "sha512-uHa4gv/NIdm9cUvfOhYb57nxrCY08iyMRXru0jbpaH57Q3NCge/ypY7fOvgCr8tPyucKrGbVndKhjXE0IX0VfQ==", 1797 | "requires": { 1798 | "agentkeepalive": "^4.1.0", 1799 | "cacache": "^15.0.0", 1800 | "http-cache-semantics": "^4.0.4", 1801 | "http-proxy-agent": "^4.0.1", 1802 | "https-proxy-agent": "^5.0.0", 1803 | "is-lambda": "^1.0.1", 1804 | "lru-cache": "^6.0.0", 1805 | "minipass": "^3.1.3", 1806 | "minipass-collect": "^1.0.2", 1807 | "minipass-fetch": "^1.3.0", 1808 | "minipass-flush": "^1.0.5", 1809 | "minipass-pipeline": "^1.2.2", 1810 | "promise-retry": "^1.1.1", 1811 | "socks-proxy-agent": "^5.0.0", 1812 | "ssri": "^8.0.0" 1813 | }, 1814 | "dependencies": { 1815 | "lru-cache": { 1816 | "version": "6.0.0", 1817 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 1818 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 1819 | "requires": { 1820 | "yallist": "^4.0.0" 1821 | } 1822 | }, 1823 | "yallist": { 1824 | "version": "4.0.0", 1825 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1826 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1827 | } 1828 | } 1829 | }, 1830 | "media-typer": { 1831 | "version": "0.3.0", 1832 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1833 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" 1834 | }, 1835 | "merge-descriptors": { 1836 | "version": "1.0.1", 1837 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1838 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" 1839 | }, 1840 | "methods": { 1841 | "version": "1.1.2", 1842 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1843 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" 1844 | }, 1845 | "mime": { 1846 | "version": "1.6.0", 1847 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1848 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" 1849 | }, 1850 | "mime-db": { 1851 | "version": "1.44.0", 1852 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz", 1853 | "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==" 1854 | }, 1855 | "mime-types": { 1856 | "version": "2.1.27", 1857 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz", 1858 | "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==", 1859 | "requires": { 1860 | "mime-db": "1.44.0" 1861 | } 1862 | }, 1863 | "minimatch": { 1864 | "version": "3.0.4", 1865 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1866 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1867 | "requires": { 1868 | "brace-expansion": "^1.1.7" 1869 | } 1870 | }, 1871 | "minipass": { 1872 | "version": "3.1.3", 1873 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.3.tgz", 1874 | "integrity": "sha512-Mgd2GdMVzY+x3IJ+oHnVM+KG3lA5c8tnabyJKmHSaG2kAGpudxuOf8ToDkhumF7UzME7DecbQE9uOZhNm7PuJg==", 1875 | "requires": { 1876 | "yallist": "^4.0.0" 1877 | }, 1878 | "dependencies": { 1879 | "yallist": { 1880 | "version": "4.0.0", 1881 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1882 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1883 | } 1884 | } 1885 | }, 1886 | "minipass-collect": { 1887 | "version": "1.0.2", 1888 | "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz", 1889 | "integrity": "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==", 1890 | "requires": { 1891 | "minipass": "^3.0.0" 1892 | } 1893 | }, 1894 | "minipass-fetch": { 1895 | "version": "1.3.0", 1896 | "resolved": "https://registry.npmjs.org/minipass-fetch/-/minipass-fetch-1.3.0.tgz", 1897 | "integrity": "sha512-Yb23ESZZ/8QxiBvSpJ4atbVMVDx2CXrerzrtQzQ67eLqKg+zFIkYFTagk3xh6fdo+e/FvDtVuCD4QcuYDRR3hw==", 1898 | "requires": { 1899 | "encoding": "^0.1.12", 1900 | "minipass": "^3.1.0", 1901 | "minipass-sized": "^1.0.3", 1902 | "minizlib": "^2.0.0" 1903 | } 1904 | }, 1905 | "minipass-flush": { 1906 | "version": "1.0.5", 1907 | "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", 1908 | "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==", 1909 | "requires": { 1910 | "minipass": "^3.0.0" 1911 | } 1912 | }, 1913 | "minipass-pipeline": { 1914 | "version": "1.2.4", 1915 | "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.4.tgz", 1916 | "integrity": "sha512-xuIq7cIOt09RPRJ19gdi4b+RiNvDFYe5JH+ggNvBqGqpQXcru3PcRmOZuHBKWK1Txf9+cQ+HMVN4d6z46LZP7A==", 1917 | "requires": { 1918 | "minipass": "^3.0.0" 1919 | } 1920 | }, 1921 | "minipass-sized": { 1922 | "version": "1.0.3", 1923 | "resolved": "https://registry.npmjs.org/minipass-sized/-/minipass-sized-1.0.3.tgz", 1924 | "integrity": "sha512-MbkQQ2CTiBMlA2Dm/5cY+9SWFEN8pzzOXi6rlM5Xxq0Yqbda5ZQy9sU75a673FE9ZK0Zsbr6Y5iP6u9nktfg2g==", 1925 | "requires": { 1926 | "minipass": "^3.0.0" 1927 | } 1928 | }, 1929 | "minizlib": { 1930 | "version": "2.1.2", 1931 | "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-2.1.2.tgz", 1932 | "integrity": "sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==", 1933 | "requires": { 1934 | "minipass": "^3.0.0", 1935 | "yallist": "^4.0.0" 1936 | }, 1937 | "dependencies": { 1938 | "yallist": { 1939 | "version": "4.0.0", 1940 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 1941 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 1942 | } 1943 | } 1944 | }, 1945 | "mkdirp": { 1946 | "version": "1.0.4", 1947 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", 1948 | "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==" 1949 | }, 1950 | "ms": { 1951 | "version": "2.1.2", 1952 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1953 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 1954 | }, 1955 | "negotiator": { 1956 | "version": "0.6.2", 1957 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1958 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" 1959 | }, 1960 | "node-fetch": { 1961 | "version": "2.6.1", 1962 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.1.tgz", 1963 | "integrity": "sha512-V4aYg89jEoVRxRb2fJdAg8FHvI7cEyYdVAh94HH0UIK8oJxUfkjlDQN9RbMx+bEjP7+ggMiFRprSti032Oipxw==" 1964 | }, 1965 | "object-assign": { 1966 | "version": "4.1.1", 1967 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1968 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 1969 | }, 1970 | "object-inspect": { 1971 | "version": "1.8.0", 1972 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.8.0.tgz", 1973 | "integrity": "sha512-jLdtEOB112fORuypAyl/50VRVIBIdVQOSUUGQHzJ4xBSbit81zRarz7GThkEFZy1RceYrWYcPcBFPQwHyAc1gA==" 1974 | }, 1975 | "object-keys": { 1976 | "version": "1.1.1", 1977 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1978 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" 1979 | }, 1980 | "object-path": { 1981 | "version": "0.11.8", 1982 | "resolved": "https://registry.npmjs.org/object-path/-/object-path-0.11.8.tgz", 1983 | "integrity": "sha512-YJjNZrlXJFM42wTBn6zgOJVar9KFJvzx6sTWDte8sWZF//cnjl0BxHNpfZx+ZffXX63A9q0b1zsFiBX4g4X5KA==" 1984 | }, 1985 | "object.assign": { 1986 | "version": "4.1.0", 1987 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1988 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1989 | "requires": { 1990 | "define-properties": "^1.1.2", 1991 | "function-bind": "^1.1.1", 1992 | "has-symbols": "^1.0.0", 1993 | "object-keys": "^1.0.11" 1994 | } 1995 | }, 1996 | "object.getownpropertydescriptors": { 1997 | "version": "2.1.0", 1998 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", 1999 | "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", 2000 | "requires": { 2001 | "define-properties": "^1.1.3", 2002 | "es-abstract": "^1.17.0-next.1" 2003 | } 2004 | }, 2005 | "on-finished": { 2006 | "version": "2.3.0", 2007 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 2008 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 2009 | "requires": { 2010 | "ee-first": "1.1.1" 2011 | } 2012 | }, 2013 | "once": { 2014 | "version": "1.4.0", 2015 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2016 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2017 | "requires": { 2018 | "wrappy": "1" 2019 | } 2020 | }, 2021 | "p-map": { 2022 | "version": "4.0.0", 2023 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 2024 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 2025 | "requires": { 2026 | "aggregate-error": "^3.0.0" 2027 | } 2028 | }, 2029 | "parseurl": { 2030 | "version": "1.3.3", 2031 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 2032 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" 2033 | }, 2034 | "path-is-absolute": { 2035 | "version": "1.0.1", 2036 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2037 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 2038 | }, 2039 | "path-to-regexp": { 2040 | "version": "0.1.7", 2041 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 2042 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" 2043 | }, 2044 | "pretty-format": { 2045 | "version": "26.4.2", 2046 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.4.2.tgz", 2047 | "integrity": "sha512-zK6Gd8zDsEiVydOCGLkoBoZuqv8VTiHyAbKznXe/gaph/DAeZOmit9yMfgIz5adIgAMMs5XfoYSwAX3jcCO1tA==", 2048 | "requires": { 2049 | "@jest/types": "^26.3.0", 2050 | "ansi-regex": "^5.0.0", 2051 | "ansi-styles": "^4.0.0", 2052 | "react-is": "^16.12.0" 2053 | } 2054 | }, 2055 | "promise-inflight": { 2056 | "version": "1.0.1", 2057 | "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", 2058 | "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=" 2059 | }, 2060 | "promise-retry": { 2061 | "version": "1.1.1", 2062 | "resolved": "https://registry.npmjs.org/promise-retry/-/promise-retry-1.1.1.tgz", 2063 | "integrity": "sha1-ZznpaOMFHaIM5kl/srUPaRHfPW0=", 2064 | "requires": { 2065 | "err-code": "^1.0.0", 2066 | "retry": "^0.10.0" 2067 | }, 2068 | "dependencies": { 2069 | "retry": { 2070 | "version": "0.10.1", 2071 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.10.1.tgz", 2072 | "integrity": "sha1-52OI0heZLCUnUCQdPTlW/tmNj/Q=" 2073 | } 2074 | } 2075 | }, 2076 | "proxy-addr": { 2077 | "version": "2.0.7", 2078 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 2079 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 2080 | "requires": { 2081 | "forwarded": "0.2.0", 2082 | "ipaddr.js": "1.9.1" 2083 | } 2084 | }, 2085 | "qs": { 2086 | "version": "6.7.0", 2087 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 2088 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" 2089 | }, 2090 | "range-parser": { 2091 | "version": "1.2.1", 2092 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 2093 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" 2094 | }, 2095 | "raw-body": { 2096 | "version": "2.4.0", 2097 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 2098 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 2099 | "requires": { 2100 | "bytes": "3.1.0", 2101 | "http-errors": "1.7.2", 2102 | "iconv-lite": "0.4.24", 2103 | "unpipe": "1.0.0" 2104 | }, 2105 | "dependencies": { 2106 | "http-errors": { 2107 | "version": "1.7.2", 2108 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 2109 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 2110 | "requires": { 2111 | "depd": "~1.1.2", 2112 | "inherits": "2.0.3", 2113 | "setprototypeof": "1.1.1", 2114 | "statuses": ">= 1.5.0 < 2", 2115 | "toidentifier": "1.0.0" 2116 | } 2117 | }, 2118 | "iconv-lite": { 2119 | "version": "0.4.24", 2120 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 2121 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 2122 | "requires": { 2123 | "safer-buffer": ">= 2.1.2 < 3" 2124 | } 2125 | }, 2126 | "inherits": { 2127 | "version": "2.0.3", 2128 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2129 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" 2130 | }, 2131 | "setprototypeof": { 2132 | "version": "1.1.1", 2133 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2134 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2135 | } 2136 | } 2137 | }, 2138 | "react-is": { 2139 | "version": "16.13.1", 2140 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", 2141 | "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" 2142 | }, 2143 | "retry": { 2144 | "version": "0.12.0", 2145 | "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", 2146 | "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=" 2147 | }, 2148 | "rimraf": { 2149 | "version": "3.0.2", 2150 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2151 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2152 | "requires": { 2153 | "glob": "^7.1.3" 2154 | } 2155 | }, 2156 | "safe-buffer": { 2157 | "version": "5.2.1", 2158 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 2159 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==" 2160 | }, 2161 | "safer-buffer": { 2162 | "version": "2.1.2", 2163 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2164 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 2165 | }, 2166 | "send": { 2167 | "version": "0.17.1", 2168 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 2169 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 2170 | "requires": { 2171 | "debug": "2.6.9", 2172 | "depd": "~1.1.2", 2173 | "destroy": "~1.0.4", 2174 | "encodeurl": "~1.0.2", 2175 | "escape-html": "~1.0.3", 2176 | "etag": "~1.8.1", 2177 | "fresh": "0.5.2", 2178 | "http-errors": "~1.7.2", 2179 | "mime": "1.6.0", 2180 | "ms": "2.1.1", 2181 | "on-finished": "~2.3.0", 2182 | "range-parser": "~1.2.1", 2183 | "statuses": "~1.5.0" 2184 | }, 2185 | "dependencies": { 2186 | "debug": { 2187 | "version": "2.6.9", 2188 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 2189 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 2190 | "requires": { 2191 | "ms": "2.0.0" 2192 | }, 2193 | "dependencies": { 2194 | "ms": { 2195 | "version": "2.0.0", 2196 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2197 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 2198 | } 2199 | } 2200 | }, 2201 | "http-errors": { 2202 | "version": "1.7.3", 2203 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.3.tgz", 2204 | "integrity": "sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw==", 2205 | "requires": { 2206 | "depd": "~1.1.2", 2207 | "inherits": "2.0.4", 2208 | "setprototypeof": "1.1.1", 2209 | "statuses": ">= 1.5.0 < 2", 2210 | "toidentifier": "1.0.0" 2211 | } 2212 | }, 2213 | "ms": { 2214 | "version": "2.1.1", 2215 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 2216 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" 2217 | }, 2218 | "setprototypeof": { 2219 | "version": "1.1.1", 2220 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 2221 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" 2222 | } 2223 | } 2224 | }, 2225 | "serve-static": { 2226 | "version": "1.14.1", 2227 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 2228 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 2229 | "requires": { 2230 | "encodeurl": "~1.0.2", 2231 | "escape-html": "~1.0.3", 2232 | "parseurl": "~1.3.3", 2233 | "send": "0.17.1" 2234 | } 2235 | }, 2236 | "setprototypeof": { 2237 | "version": "1.2.0", 2238 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", 2239 | "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" 2240 | }, 2241 | "sha.js": { 2242 | "version": "2.4.11", 2243 | "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", 2244 | "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", 2245 | "requires": { 2246 | "inherits": "^2.0.1", 2247 | "safe-buffer": "^5.0.1" 2248 | } 2249 | }, 2250 | "smart-buffer": { 2251 | "version": "4.1.0", 2252 | "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.1.0.tgz", 2253 | "integrity": "sha512-iVICrxOzCynf/SNaBQCw34eM9jROU/s5rzIhpOvzhzuYHfJR/DhZfDkXiZSgKXfgv26HT3Yni3AV/DGw0cGnnw==" 2254 | }, 2255 | "socks": { 2256 | "version": "2.4.1", 2257 | "resolved": "https://registry.npmjs.org/socks/-/socks-2.4.1.tgz", 2258 | "integrity": "sha512-8mWHeYC1OA0500qzb+sqwm0Hzi8oBpeuI1JugoBVMEJtJvxSgco8xFSK+NRnZcHeeWjTbF82KUDo5sXH22TY5A==", 2259 | "requires": { 2260 | "ip": "1.1.5", 2261 | "smart-buffer": "^4.1.0" 2262 | } 2263 | }, 2264 | "socks-proxy-agent": { 2265 | "version": "5.0.0", 2266 | "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-5.0.0.tgz", 2267 | "integrity": "sha512-lEpa1zsWCChxiynk+lCycKuC502RxDWLKJZoIhnxrWNjLSDGYRFflHA1/228VkRcnv9TIb8w98derGbpKxJRgA==", 2268 | "requires": { 2269 | "agent-base": "6", 2270 | "debug": "4", 2271 | "socks": "^2.3.3" 2272 | } 2273 | }, 2274 | "ssri": { 2275 | "version": "8.0.1", 2276 | "resolved": "https://registry.npmjs.org/ssri/-/ssri-8.0.1.tgz", 2277 | "integrity": "sha512-97qShzy1AiyxvPNIkLWoGua7xoQzzPjQ0HAH4B0rWKo7SZ6USuPcrUiAFrws0UH8RrbWmgq3LMTObhPIHbbBeQ==", 2278 | "requires": { 2279 | "minipass": "^3.1.1" 2280 | } 2281 | }, 2282 | "statuses": { 2283 | "version": "1.5.0", 2284 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 2285 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" 2286 | }, 2287 | "stoppable": { 2288 | "version": "1.1.0", 2289 | "resolved": "https://registry.npmjs.org/stoppable/-/stoppable-1.1.0.tgz", 2290 | "integrity": "sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==" 2291 | }, 2292 | "streamsearch": { 2293 | "version": "0.1.2", 2294 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-0.1.2.tgz", 2295 | "integrity": "sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo=" 2296 | }, 2297 | "string.prototype.trimend": { 2298 | "version": "1.0.1", 2299 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.1.tgz", 2300 | "integrity": "sha512-LRPxFUaTtpqYsTeNKaFOw3R4bxIzWOnbQ837QfBylo8jIxtcbK/A/sMV7Q+OAV/vWo+7s25pOE10KYSjaSO06g==", 2301 | "requires": { 2302 | "define-properties": "^1.1.3", 2303 | "es-abstract": "^1.17.5" 2304 | } 2305 | }, 2306 | "string.prototype.trimstart": { 2307 | "version": "1.0.1", 2308 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.1.tgz", 2309 | "integrity": "sha512-XxZn+QpvrBI1FOcg6dIpxUPgWCPuNXvMD72aaRaUQv1eD4e/Qy8i/hFTe0BUmD60p/QA6bh1avmuPTfNjqVWRw==", 2310 | "requires": { 2311 | "define-properties": "^1.1.3", 2312 | "es-abstract": "^1.17.5" 2313 | } 2314 | }, 2315 | "subscriptions-transport-ws": { 2316 | "version": "0.9.18", 2317 | "resolved": "https://registry.npmjs.org/subscriptions-transport-ws/-/subscriptions-transport-ws-0.9.18.tgz", 2318 | "integrity": "sha512-tztzcBTNoEbuErsVQpTN2xUNN/efAZXyCyL5m3x4t6SKrEiTL2N8SaKWBFWM4u56pL79ULif3zjyeq+oV+nOaA==", 2319 | "requires": { 2320 | "backo2": "^1.0.2", 2321 | "eventemitter3": "^3.1.0", 2322 | "iterall": "^1.2.1", 2323 | "symbol-observable": "^1.0.4", 2324 | "ws": "^5.2.0" 2325 | }, 2326 | "dependencies": { 2327 | "ws": { 2328 | "version": "5.2.3", 2329 | "resolved": "https://registry.npmjs.org/ws/-/ws-5.2.3.tgz", 2330 | "integrity": "sha512-jZArVERrMsKUatIdnLzqvcfydI85dvd/Fp1u/VOpfdDWQ4c9qWXe+VIeAbQ5FrDwciAkr+lzofXLz3Kuf26AOA==", 2331 | "requires": { 2332 | "async-limiter": "~1.0.0" 2333 | } 2334 | } 2335 | } 2336 | }, 2337 | "supports-color": { 2338 | "version": "7.1.0", 2339 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 2340 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 2341 | "requires": { 2342 | "has-flag": "^4.0.0" 2343 | } 2344 | }, 2345 | "symbol-observable": { 2346 | "version": "1.2.0", 2347 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.2.0.tgz", 2348 | "integrity": "sha512-e900nM8RRtGhlV36KGEU9k65K3mPb1WV70OdjfxlG2EAuM1noi/E/BaW/uMhL7bPEssK8QV57vN3esixjUvcXQ==" 2349 | }, 2350 | "tar": { 2351 | "version": "6.1.11", 2352 | "resolved": "https://registry.npmjs.org/tar/-/tar-6.1.11.tgz", 2353 | "integrity": "sha512-an/KZQzQUkZCkuoAA64hM92X0Urb6VpRhAFllDzz44U2mcD5scmT3zBc4VgVpkugF580+DQn8eAFSyoQt0tznA==", 2354 | "requires": { 2355 | "chownr": "^2.0.0", 2356 | "fs-minipass": "^2.0.0", 2357 | "minipass": "^3.0.0", 2358 | "minizlib": "^2.1.1", 2359 | "mkdirp": "^1.0.3", 2360 | "yallist": "^4.0.0" 2361 | }, 2362 | "dependencies": { 2363 | "yallist": { 2364 | "version": "4.0.0", 2365 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 2366 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" 2367 | } 2368 | } 2369 | }, 2370 | "toidentifier": { 2371 | "version": "1.0.0", 2372 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 2373 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" 2374 | }, 2375 | "ts-invariant": { 2376 | "version": "0.4.4", 2377 | "resolved": "https://registry.npmjs.org/ts-invariant/-/ts-invariant-0.4.4.tgz", 2378 | "integrity": "sha512-uEtWkFM/sdZvRNNDL3Ehu4WVpwaulhwQszV8mrtcdeE8nN00BV9mAmQ88RkrBhFgl9gMgvjJLAQcZbnPXI9mlA==", 2379 | "requires": { 2380 | "tslib": "^1.9.3" 2381 | } 2382 | }, 2383 | "tslib": { 2384 | "version": "1.13.0", 2385 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.13.0.tgz", 2386 | "integrity": "sha512-i/6DQjL8Xf3be4K/E6Wgpekn5Qasl1usyw++dAA35Ue5orEn65VIxOA+YvNNl9HV3qv70T7CNwjODHZrLwvd1Q==" 2387 | }, 2388 | "type-is": { 2389 | "version": "1.6.18", 2390 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 2391 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 2392 | "requires": { 2393 | "media-typer": "0.3.0", 2394 | "mime-types": "~2.1.24" 2395 | } 2396 | }, 2397 | "unique-filename": { 2398 | "version": "1.1.1", 2399 | "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", 2400 | "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", 2401 | "requires": { 2402 | "unique-slug": "^2.0.0" 2403 | } 2404 | }, 2405 | "unique-slug": { 2406 | "version": "2.0.2", 2407 | "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", 2408 | "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", 2409 | "requires": { 2410 | "imurmurhash": "^0.1.4" 2411 | } 2412 | }, 2413 | "unpipe": { 2414 | "version": "1.0.0", 2415 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 2416 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" 2417 | }, 2418 | "util.promisify": { 2419 | "version": "1.0.1", 2420 | "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.1.tgz", 2421 | "integrity": "sha512-g9JpC/3He3bm38zsLupWryXHoEcS22YHthuPQSJdMy6KNrzIRzWqcsHzD/WUnqe45whVou4VIsPew37DoXWNrA==", 2422 | "requires": { 2423 | "define-properties": "^1.1.3", 2424 | "es-abstract": "^1.17.2", 2425 | "has-symbols": "^1.0.1", 2426 | "object.getownpropertydescriptors": "^2.1.0" 2427 | } 2428 | }, 2429 | "utils-merge": { 2430 | "version": "1.0.1", 2431 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 2432 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" 2433 | }, 2434 | "uuid": { 2435 | "version": "8.3.0", 2436 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.0.tgz", 2437 | "integrity": "sha512-fX6Z5o4m6XsXBdli9g7DtWgAx+osMsRRZFKma1mIUsLCz6vRvv+pz5VNbyu9UEDzpMWulZfvpgb/cmDXVulYFQ==" 2438 | }, 2439 | "vary": { 2440 | "version": "1.1.2", 2441 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 2442 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" 2443 | }, 2444 | "wrappy": { 2445 | "version": "1.0.2", 2446 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2447 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 2448 | }, 2449 | "ws": { 2450 | "version": "6.2.2", 2451 | "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.2.tgz", 2452 | "integrity": "sha512-zmhltoSR8u1cnDsD43TX59mzoMZsLKqUweyYBAIvTngR3shc0W6aOZylZmq/7hqyVxPdi+5Ud2QInblgyE72fw==", 2453 | "requires": { 2454 | "async-limiter": "~1.0.0" 2455 | } 2456 | }, 2457 | "xss": { 2458 | "version": "1.0.8", 2459 | "resolved": "https://registry.npmjs.org/xss/-/xss-1.0.8.tgz", 2460 | "integrity": "sha512-3MgPdaXV8rfQ/pNn16Eio6VXYPTkqwa0vc7GkiymmY/DqR1SE/7VPAAVZz1GJsJFrllMYO3RHfEaiUGjab6TNw==", 2461 | "requires": { 2462 | "commander": "^2.20.3", 2463 | "cssfilter": "0.0.10" 2464 | } 2465 | }, 2466 | "yallist": { 2467 | "version": "3.1.1", 2468 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", 2469 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" 2470 | }, 2471 | "zen-observable": { 2472 | "version": "0.8.15", 2473 | "resolved": "https://registry.npmjs.org/zen-observable/-/zen-observable-0.8.15.tgz", 2474 | "integrity": "sha512-PQ2PC7R9rslx84ndNBZB/Dkv8V8fZEpk83RLgXtYd0fwUgEjseMn1Dgajh2x6S8QbZAFa9p2qVCEuYZNgve0dQ==" 2475 | }, 2476 | "zen-observable-ts": { 2477 | "version": "0.8.21", 2478 | "resolved": "https://registry.npmjs.org/zen-observable-ts/-/zen-observable-ts-0.8.21.tgz", 2479 | "integrity": "sha512-Yj3yXweRc8LdRMrCC8nIc4kkjWecPAUVh0TI0OUrWXx6aX790vLcDlWca6I4vsyCGH3LpWxq0dJRcMOFoVqmeg==", 2480 | "requires": { 2481 | "tslib": "^1.9.3", 2482 | "zen-observable": "^0.8.0" 2483 | } 2484 | } 2485 | } 2486 | } 2487 | -------------------------------------------------------------------------------- /examples/federation/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "federation", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "gateway.js", 6 | "scripts": { 7 | "test": "echo \"Error: no test specified\" && exit 1" 8 | }, 9 | "author": "", 10 | "license": "ISC", 11 | "dependencies": { 12 | "@apollo/gateway": "^0.19.1", 13 | "apollo-server": "^2.16.1" 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /examples/federation/product.py: -------------------------------------------------------------------------------- 1 | import uvicorn 2 | from gql import gql, query, reference_resolver 3 | 4 | from stargql import GraphQL 5 | 6 | from helper import get_production_by_upc, products 7 | 8 | type_defs = gql( 9 | """ 10 | type Query { 11 | topProducts(first: Int = 5): [Product] 12 | } 13 | type Product @key(fields: "upc") { 14 | upc: String! 15 | name: String 16 | price: Int 17 | weight: Int 18 | } 19 | """ 20 | ) 21 | 22 | 23 | @reference_resolver('Product') 24 | def user_reference(_, info, representation): 25 | return get_production_by_upc(representation['upc']) 26 | 27 | 28 | @query('topProducts') 29 | def top_products(_, info, first: int = 5): 30 | return products[:first] 31 | 32 | 33 | app = GraphQL(type_defs=type_defs, federation=True) 34 | 35 | if __name__ == '__main__': 36 | uvicorn.run(app, port=8081) 37 | -------------------------------------------------------------------------------- /examples/federation/review.py: -------------------------------------------------------------------------------- 1 | import uvicorn 2 | 3 | from gql import gql, reference_resolver, field_resolver, query 4 | from stargql import GraphQL 5 | 6 | from helper import get_review_by_id, get_user_reviews, get_product_reviews, reviews 7 | 8 | type_defs = gql( 9 | ''' 10 | type Query { 11 | reviews(first: Int = 5): [Review] 12 | } 13 | 14 | type Review @key(fields: "id") { 15 | id: ID! 16 | body: String 17 | author: User @provides(fields: "username") 18 | product: Product @provides(fields: "upc") 19 | } 20 | 21 | type User @key(fields: "id") @extends { 22 | id: ID! @external 23 | username: String @external 24 | reviews: [Review] 25 | } 26 | 27 | type Product @key(fields: "upc") @extends { 28 | upc: String! @external 29 | reviews: [Review] 30 | } 31 | ''' 32 | ) 33 | 34 | 35 | @query('reviews') 36 | def list_reviews(_, info, first: int = 5): 37 | return reviews[:first] 38 | 39 | 40 | @reference_resolver('Review') 41 | def resolve_reviews_reference(_, info, representation): 42 | return get_review_by_id(representation['id']) 43 | 44 | 45 | @field_resolver('Review', 'author') 46 | def resolve_review_author(review, *_): 47 | return {'id': review['authorID']} 48 | 49 | 50 | @field_resolver('Review', 'product') 51 | def resolve_review_product(review, *_): 52 | return {'upc': review['product']['upc']} 53 | 54 | 55 | @field_resolver('User', 'reviews') 56 | def resolve_user_reviews(representation, *_): 57 | return get_user_reviews(representation['id']) 58 | 59 | 60 | @field_resolver('Product', 'reviews') 61 | def resolve_product_reviews(representation, *_): 62 | return get_product_reviews(representation['upc']) 63 | 64 | 65 | app = GraphQL(type_defs=type_defs, federation=True) 66 | 67 | if __name__ == '__main__': 68 | uvicorn.run(app, port=8083) 69 | -------------------------------------------------------------------------------- /examples/fileupload/app.py: -------------------------------------------------------------------------------- 1 | import uvicorn 2 | 3 | from gql import gql, mutate 4 | from stargql import GraphQL 5 | 6 | type_defs = gql( 7 | """ 8 | scalar Upload 9 | 10 | type File { 11 | filename: String! 12 | } 13 | 14 | type Query { 15 | uploads: [File] 16 | } 17 | 18 | type Mutation { 19 | singleUpload(file: Upload!): File! 20 | multiUpload(files: [Upload!]!): [File!]! 21 | } 22 | """ 23 | ) 24 | 25 | 26 | @mutate 27 | def single_upload(parent, info, file): 28 | return file 29 | 30 | 31 | @mutate 32 | def multi_upload(parent, info, files): 33 | return files 34 | 35 | 36 | app = GraphQL(type_defs=type_defs) 37 | 38 | 39 | if __name__ == '__main__': 40 | uvicorn.run(app, port=8080) 41 | -------------------------------------------------------------------------------- /examples/fileupload/multi.sh: -------------------------------------------------------------------------------- 1 | curl localhost:8080/graphql/ \ 2 | -F operations='{ "query": "mutation ($files: [Upload!]!) { multiUpload(files: $files) { filename } }", "variables": { "files": [null, null] } }' \ 3 | -F map='{ "0": ["variables.files.0"], "1": ["variables.files.1"] }' \ 4 | -F 0=@single.sh \ 5 | -F 1=@multi.sh | jq -------------------------------------------------------------------------------- /examples/fileupload/single.sh: -------------------------------------------------------------------------------- 1 | curl localhost:8080/graphql/ \ 2 | -F operations='{ "query": "mutation ($file: Upload!) { singleUpload(file: $file) { filename } }", "variables": { "file": null } }' \ 3 | -F map='{ "0": ["variables.file"] }' \ 4 | -F 0=@single.sh | jq -------------------------------------------------------------------------------- /examples/hello/app.py: -------------------------------------------------------------------------------- 1 | import uvicorn 2 | 3 | from gql import query 4 | from stargql import GraphQL 5 | 6 | 7 | @query 8 | async def hello(parent, info, name: str) -> str: 9 | return name 10 | 11 | 12 | app = GraphQL(schema_file='schema.gql') 13 | 14 | if __name__ == '__main__': 15 | uvicorn.run(app, port=8080) 16 | -------------------------------------------------------------------------------- /examples/hello/schema.gql: -------------------------------------------------------------------------------- 1 | type Query { 2 | hello(name: String!): String! 3 | } 4 | -------------------------------------------------------------------------------- /examples/subscribe/app.py: -------------------------------------------------------------------------------- 1 | from functools import wraps 2 | from typing import Callable, Awaitable, AsyncIterator, Any, Dict 3 | 4 | import uvicorn 5 | from gql import gql, subscribe, mutate 6 | from gql_subscriptions.pubsubs.redis import RedisPubSub 7 | from stargql import GraphQL 8 | 9 | # from gql.pubsub import PubSub 10 | 11 | type_defs = gql( 12 | """ 13 | type Subscription { 14 | postAdded(author: String): Post 15 | } 16 | 17 | type Query { 18 | posts: [Post] 19 | } 20 | 21 | type Mutation { 22 | addPost(author: String, comment: String): Post 23 | } 24 | 25 | type Post { 26 | author: String 27 | comment: String 28 | } 29 | """ 30 | ) 31 | 32 | pubsub = RedisPubSub('redis://localhost:6379') 33 | 34 | ResolverFn = Callable[[Any, Any, Dict[str, Any]], Awaitable[AsyncIterator]] 35 | FilterFn = Callable[[Any, Any, Dict[str, Any]], bool] 36 | 37 | 38 | def with_filter(filter_fn: FilterFn,) -> Callable[[ResolverFn], ResolverFn]: 39 | def wrap(func: ResolverFn) -> ResolverFn: 40 | @wraps(func) 41 | async def _wrap(parent: Any, info: Any, **kwargs: Any) -> Awaitable[AsyncIterator]: 42 | iterator = await func(parent, info, **kwargs) 43 | async for result in iterator: 44 | if filter_fn(result, info, **kwargs): 45 | yield result 46 | 47 | return _wrap 48 | 49 | return wrap 50 | 51 | 52 | def filter_post(payload, info, **kwargs): 53 | if 'author' not in kwargs: 54 | return False 55 | return payload['postAdded'].get('author') == kwargs['author'] 56 | 57 | 58 | @subscribe 59 | # @with_filter(filter_post) 60 | async def post_added(parent, info, **kwargs): 61 | return pubsub.async_iterator('POST_ADDED') 62 | 63 | 64 | @mutate 65 | async def add_post(parent, info, **kwargs): 66 | await pubsub.publish('POST_ADDED', {'postAdded': kwargs}) 67 | return kwargs 68 | 69 | 70 | async def shutdown(): 71 | await pubsub.disconnect() 72 | 73 | 74 | app = GraphQL(type_defs=type_defs, on_shutdown=[shutdown]) 75 | 76 | 77 | if __name__ == '__main__': 78 | uvicorn.run(app, port=8080, debug=True) 79 | -------------------------------------------------------------------------------- /poetry.lock: -------------------------------------------------------------------------------- 1 | [[package]] 2 | category = "main" 3 | description = "GraphQL implementation for Python, a port of GraphQL.js, the JavaScript reference implementation for GraphQL." 4 | name = "graphql-core" 5 | optional = false 6 | python-versions = ">=3.6,<4" 7 | version = "3.1.0" 8 | 9 | [[package]] 10 | category = "main" 11 | description = "Python schema-first and auto-generate class graphql server" 12 | name = "python-gql" 13 | optional = false 14 | python-versions = ">=3.7,<4.0" 15 | version = "0.0.8" 16 | 17 | [package.dependencies] 18 | graphql-core = ">=3,<4" 19 | 20 | [package.dependencies.typing_extensions] 21 | python = "<3.8" 22 | version = ">=3.7.4,<4.0.0" 23 | 24 | [[package]] 25 | category = "main" 26 | description = "The little ASGI library that shines." 27 | name = "starlette" 28 | optional = false 29 | python-versions = ">=3.6" 30 | version = "0.13.3" 31 | 32 | [package.extras] 33 | full = ["aiofiles", "graphene", "itsdangerous", "jinja2", "python-multipart", "pyyaml", "requests", "ujson"] 34 | 35 | [[package]] 36 | category = "main" 37 | description = "Backported and Experimental Type Hints for Python 3.5+" 38 | marker = "python_version < \"3.8\"" 39 | name = "typing-extensions" 40 | optional = false 41 | python-versions = "*" 42 | version = "3.7.4.2" 43 | 44 | [metadata] 45 | content-hash = "5abb146c0a4193e7cc195cabdb82779cdb60d8f695f39c2ce4394cb26e17f956" 46 | python-versions = "^3.7" 47 | 48 | [metadata.files] 49 | graphql-core = [ 50 | {file = "graphql-core-3.1.0.tar.gz", hash = "sha256:d43cf1f149772c7014656d4bc4c512278a16722e80e4be2daf99894ffef871db"}, 51 | {file = "graphql_core-3.1.0-py3-none-any.whl", hash = "sha256:b654666330c46d6a98405a542e9fde0a499916428cbc11da51eb82be37ef1e05"}, 52 | ] 53 | python-gql = [ 54 | {file = "python-gql-0.0.8.tar.gz", hash = "sha256:f86774e41ad747d09651e94cd834a831a8256f0f68addab0f1ed18d2c8dd0e41"}, 55 | {file = "python_gql-0.0.8-py3-none-any.whl", hash = "sha256:3a44c557c42c0fb0fcd6c9d427295bca181f0b6bf576c4c680dad26c18b190b1"}, 56 | ] 57 | starlette = [ 58 | {file = "starlette-0.13.3-py3-none-any.whl", hash = "sha256:b316d53119813d12fa1d02ae80ef11a71ff603ff10abb143bd4aaadb59d03dd9"}, 59 | {file = "starlette-0.13.3.tar.gz", hash = "sha256:e15689e130a358c5cb220b9aad1e7bcb8052504c321235dab431f065c77f010d"}, 60 | ] 61 | typing-extensions = [ 62 | {file = "typing_extensions-3.7.4.2-py2-none-any.whl", hash = "sha256:f8d2bd89d25bc39dabe7d23df520442fa1d8969b82544370e03d88b5a591c392"}, 63 | {file = "typing_extensions-3.7.4.2-py3-none-any.whl", hash = "sha256:6e95524d8a547a91e08f404ae485bbb71962de46967e1b71a0cb89af24e761c5"}, 64 | {file = "typing_extensions-3.7.4.2.tar.gz", hash = "sha256:79ee589a3caca649a9bfd2a8de4709837400dfa00b6cc81962a1e6a1815969ae"}, 65 | ] 66 | -------------------------------------------------------------------------------- /pyproject.toml: -------------------------------------------------------------------------------- 1 | [tool.poetry] 2 | name = "starlette-graphql" 3 | version = "0.2.1" 4 | description = "The starlette GraphQL implement, which support query, mutate and subscription." 5 | authors = ["syfun "] 6 | license = "MIT" 7 | readme = "README.md" 8 | homepage = "https://github.com/syfun/starlette-graphql" 9 | 10 | packages = [ 11 | { include = "stargql" } 12 | ] 13 | 14 | [tool.poetry.dependencies] 15 | python = ">=3.7" 16 | python-gql = ">=0.2" 17 | starlette = ">0.13" 18 | 19 | [tool.poetry.dev-dependencies] 20 | 21 | [build-system] 22 | requires = ["poetry>=0.12"] 23 | build-backend = "poetry.masonry.api" 24 | -------------------------------------------------------------------------------- /stargql/__init__.py: -------------------------------------------------------------------------------- 1 | from .applications import GraphQL # noqa 2 | 3 | __version__ = '0.2.1' 4 | -------------------------------------------------------------------------------- /stargql/applications.py: -------------------------------------------------------------------------------- 1 | import json 2 | import traceback 3 | import typing 4 | 5 | from gql import make_schema, make_schema_from_file, MiddlewareManager, ExecutionContext 6 | from gql.playground import PLAYGROUND_HTML 7 | from gql.resolver import default_field_resolver 8 | from gql.utils import place_files_in_operations 9 | from graphql import GraphQLError, GraphQLSchema, graphql 10 | from starlette import status 11 | from starlette.applications import Starlette 12 | from starlette.background import BackgroundTasks 13 | from starlette.requests import Request 14 | from starlette.responses import HTMLResponse, JSONResponse, PlainTextResponse, Response 15 | from starlette.routing import BaseRoute, Route, WebSocketRoute 16 | from starlette.types import Receive, Scope, Send 17 | 18 | from .subscription import Subscription 19 | 20 | ERROR_FORMATER = typing.Callable[[GraphQLError], typing.Dict[str, typing.Any]] 21 | 22 | 23 | class GraphQL(Starlette): 24 | def __init__( 25 | self, 26 | 27 | schema: GraphQLSchema = None, 28 | *, 29 | type_defs: str = None, 30 | schema_file: str = None, 31 | federation: bool = False, 32 | playground: bool = True, 33 | debug: bool = False, 34 | routes: typing.List[BaseRoute] = None, 35 | path: str = '/', 36 | subscription_path: str = '/', 37 | subscription_authenticate: typing.Awaitable = None, 38 | error_formater: ERROR_FORMATER = None, 39 | graphql_middleware: typing.Union[tuple, list, typing.Dict[str, list]] = None, 40 | graphql_middleware_exclude: typing.List[str] = None, 41 | context_builder: typing.Callable = None, 42 | **kwargs, 43 | ): 44 | routes = routes or [] 45 | if schema: 46 | self.schema = schema 47 | elif type_defs: 48 | self.schema = make_schema(type_defs, federation=federation) 49 | elif schema_file: 50 | self.schema = make_schema_from_file(schema_file, federation=federation) 51 | else: 52 | raise Exception('Must provide type def string or file.') 53 | 54 | routes.extend( 55 | [ 56 | Route( 57 | path, 58 | ASGIApp( 59 | self.schema, 60 | debug=debug, 61 | playground=playground, 62 | error_formater=error_formater, 63 | graphql_middleware=graphql_middleware, 64 | graphql_middleware_exclude=graphql_middleware_exclude, 65 | context_builder=context_builder, 66 | ), 67 | ), 68 | WebSocketRoute( 69 | subscription_path, 70 | Subscription(self.schema, authenticate=subscription_authenticate), 71 | ), 72 | ] 73 | ) 74 | super().__init__(debug=debug, routes=routes, **kwargs) 75 | 76 | 77 | class ASGIApp: 78 | def __init__( 79 | self, 80 | schema: GraphQLSchema, 81 | debug: bool = False, 82 | playground: bool = True, 83 | error_formater: ERROR_FORMATER = None, 84 | graphql_middleware: typing.Union[tuple, list, typing.Dict[str, list]] = None, 85 | graphql_middleware_exclude: typing.List[str] = None, 86 | context_builder: typing.Callable = None, 87 | ) -> None: 88 | self.schema = schema 89 | self.playground = playground 90 | self.error_formater = error_formater or self.format_error 91 | self.debug = debug 92 | if not graphql_middleware: 93 | self.middleware_manager = None 94 | elif isinstance(graphql_middleware, (tuple, list)): 95 | self.middleware_manager = MiddlewareManager( 96 | { 97 | 'Query': graphql_middleware, 98 | 'Mutation': graphql_middleware, 99 | 'Subscription': graphql_middleware, 100 | }, 101 | graphql_middleware_exclude, 102 | ) 103 | elif isinstance(graphql_middleware, dict): 104 | self.middleware_manager = MiddlewareManager(graphql_middleware, graphql_middleware_exclude) 105 | else: 106 | raise TypeError( 107 | 'GraphQL ASGIApp only accept graphql_middleware: tuple, list, dict,' f'not {type(graphql_middleware)}' 108 | ) 109 | 110 | self.context_builder = context_builder 111 | 112 | async def __call__(self, scope: Scope, receive: Receive, send: Send) -> None: 113 | request = Request(scope, receive=receive, send=send) 114 | response = await self.handle_graphql(request) 115 | await response(scope, receive, send) 116 | 117 | def format_error(self, error: GraphQLError) -> typing.Dict[str, typing.Any]: 118 | if not error: 119 | raise ValueError("Received null or undefined error.") 120 | formatted = dict( # noqa: E701 (pycqa/flake8#394) 121 | message=error.message or "An unknown error occurred.", 122 | locations=[l._asdict() for l in error.locations] if error.locations else None, 123 | path=error.path, 124 | ) 125 | if self.debug and error.original_error: 126 | original_error = error.original_error 127 | exception = error.extensions.get('exception', {}) 128 | exception['traceback'] = traceback.format_exception( 129 | type(original_error), original_error, original_error.__traceback__ 130 | ) 131 | error.extensions['exception'] = exception 132 | if error.extensions: 133 | formatted.update(extensions=error.extensions) 134 | return formatted 135 | 136 | async def handle_graphql(self, request: Request) -> Response: 137 | if request.method in ('GET', 'HEAD'): 138 | if 'text/html' in request.headers.get('Accept', ''): 139 | if not self.playground: 140 | return PlainTextResponse('Not Found', status_code=status.HTTP_404_NOT_FOUND) 141 | return HTMLResponse(PLAYGROUND_HTML) 142 | 143 | data = request.query_params # type: typing.Mapping[str, typing.Any] 144 | 145 | elif request.method == 'POST': 146 | content_type = request.headers.get('Content-Type', '') 147 | 148 | if 'application/json' in content_type: 149 | data = await request.json() 150 | elif 'application/graphql' in content_type: 151 | body = await request.body() 152 | data = {'query': body.decode()} 153 | elif 'query' in request.query_params: 154 | data = request.query_params 155 | elif 'multipart/form-data' in content_type: 156 | form = await request.form() 157 | try: 158 | operations = json.loads(form.get('operations', '{}')) 159 | files_map = json.loads(form.get('map', '{}')) 160 | except (TypeError, ValueError): 161 | return PlainTextResponse( 162 | 'operations or map sent invalid JSON', 163 | status_code=status.HTTP_400_BAD_REQUEST, 164 | ) 165 | data = place_files_in_operations(operations, files_map, form) 166 | else: 167 | return PlainTextResponse( 168 | 'Unsupported Media Type', 169 | status_code=status.HTTP_415_UNSUPPORTED_MEDIA_TYPE, 170 | ) 171 | else: 172 | return PlainTextResponse('Method Not Allowed', status_code=status.HTTP_405_METHOD_NOT_ALLOWED) 173 | 174 | try: 175 | query = data['query'] 176 | variables = data.get('variables') 177 | operation_name = data.get('operationName') 178 | except KeyError: 179 | return PlainTextResponse( 180 | 'No GraphQL query found in the request', 181 | status_code=status.HTTP_400_BAD_REQUEST, 182 | ) 183 | 184 | background = BackgroundTasks() 185 | context = self.context_builder() if self.context_builder else {} 186 | context.update(request=request, background=background) 187 | 188 | result = await graphql( 189 | self.schema, 190 | query, 191 | variable_values=variables, 192 | operation_name=operation_name, 193 | context_value=context, 194 | field_resolver=default_field_resolver, 195 | middleware=self.middleware_manager, 196 | execution_context_class=ExecutionContext, 197 | ) 198 | error_data = [self.error_formater(err) for err in result.errors] if result.errors else None 199 | response_data = {'data': result.data, 'errors': error_data} 200 | # status_code = status.HTTP_400_BAD_REQUEST if result.errors else status.HTTP_200_OK 201 | 202 | return JSONResponse(response_data, status_code=status.HTTP_200_OK, background=background) 203 | -------------------------------------------------------------------------------- /stargql/subscription.py: -------------------------------------------------------------------------------- 1 | import asyncio 2 | import inspect 3 | import json 4 | from dataclasses import dataclass 5 | from typing import Any, AsyncIterator, Awaitable, Dict, Sequence 6 | 7 | from gql.subscription import PROTOCOL, MessageType, OperationMessage 8 | from graphql import ExecutionResult, GraphQLError, GraphQLSchema, format_error, parse, subscribe 9 | from starlette import status 10 | from starlette.authentication import BaseUser 11 | from starlette.types import Receive, Scope, Send 12 | from starlette.websockets import Message, WebSocket 13 | 14 | 15 | def create_async_iterator(seq: Sequence[Any]): 16 | async def inner(): 17 | for i in seq: 18 | yield i 19 | 20 | return inner 21 | 22 | 23 | @dataclass 24 | class ConnectionContext: 25 | socket: WebSocket 26 | operations: Dict[str, AsyncIterator[ExecutionResult]] 27 | user: BaseUser = None 28 | 29 | 30 | class Subscription: 31 | schema: GraphQLSchema 32 | keep_alive: bool 33 | authenticate: Awaitable 34 | 35 | def __init__(self, schema: GraphQLSchema, keep_alive: bool = False, authenticate: Awaitable = None) -> None: 36 | self.schema = schema 37 | self.keep_alive = keep_alive 38 | self.authenticate = authenticate 39 | 40 | async def __call__(self, scope: Scope, receive: Receive, send: Send) -> None: 41 | socket = WebSocket(scope, receive=receive, send=send) 42 | await self.on_connect(socket) 43 | 44 | context = ConnectionContext(socket=socket, operations={}) 45 | await self.on_message(context) 46 | 47 | async def on_connect(self, socket: WebSocket) -> None: 48 | await socket.accept(PROTOCOL) 49 | 50 | async def on_disconnect(self, socket: WebSocket, close_code: int) -> None: 51 | await socket.close(close_code) 52 | 53 | async def on_message(self, context: ConnectionContext) -> None: 54 | close_code = status.WS_1000_NORMAL_CLOSURE 55 | try: 56 | while True: 57 | message = await context.socket.receive() 58 | if message["type"] == "websocket.receive": 59 | await self.dispatch(context, message) 60 | elif message["type"] == "websocket.disconnect": 61 | close_code = int(message.get("code", status.WS_1000_NORMAL_CLOSURE)) 62 | # To fix shutdown server 1006 error. 63 | if close_code == 1006: 64 | close_code = status.WS_1000_NORMAL_CLOSURE 65 | break 66 | except Exception as exc: 67 | close_code = status.WS_1011_INTERNAL_ERROR 68 | raise exc from None 69 | finally: 70 | await self.on_disconnect(context.socket, close_code) 71 | 72 | async def unsubscribe(self, context: ConnectionContext, op_id: str) -> None: 73 | if op_id not in context.operations: 74 | return 75 | 76 | op = context.operations[op_id] 77 | close_func = getattr(op, 'aclose') 78 | if inspect.isfunction(close_func): 79 | close_func() 80 | elif inspect.iscoroutinefunction(close_func): 81 | await close_func() 82 | 83 | context.operations.pop(op_id) 84 | 85 | async def unsubscribe_all(self, context: ConnectionContext) -> None: 86 | for op_id in context.operations: 87 | await self.unsubscribe(context, op_id) 88 | 89 | async def dispatch(self, context: ConnectionContext, data: Message) -> None: 90 | message = await self.decode(context, data) 91 | op_id = message.id 92 | if message.type == MessageType.GQL_CONNECTION_INIT: 93 | await self.init(context, message) 94 | elif message.type == MessageType.GQL_CONNECTION_TERMINATE: 95 | await context.socket.close(code=status.WS_1000_NORMAL_CLOSURE) 96 | elif message.type == MessageType.GQL_START: 97 | try: 98 | await self.start(context, message) 99 | except Exception as exc: 100 | await self.send_error(context, op_id, {'message': str(exc)}) 101 | await self.unsubscribe(context, op_id) 102 | elif message.type == MessageType.GQL_STOP: 103 | await self.unsubscribe(context, op_id) 104 | else: 105 | await self.send_error(context, op_id, {'message': 'Invalid message type!'}) 106 | 107 | async def init(self, context: ConnectionContext, message: OperationMessage) -> None: 108 | if self.authenticate: 109 | context.user = user = await self.authenticate(message.payload) 110 | if not user.is_authenticated: 111 | await self.send_error( 112 | context, 113 | message.id, 114 | {'message': 'Invalid auth credentials.'}, 115 | error_type=MessageType.GQL_CONNECTION_ERROR, 116 | ) 117 | return 118 | 119 | await self.send_message(context, MessageType.GQL_CONNECTION_ACK) 120 | # TODO: to support keep_alive 121 | 122 | async def start(self, context: ConnectionContext, message: OperationMessage) -> None: 123 | if context.user and not context.user.is_authenticated: 124 | await self.send_error(context, message.id, {'message': 'Invalid auth credentials.'}) 125 | return 126 | 127 | op_id = message.id 128 | # if we already have a subscription with this id, unsubscribe from it first 129 | if op_id in context.operations: 130 | await self.unsubscribe(context, op_id) 131 | 132 | payload = message.payload 133 | try: 134 | doc = parse(payload.query) 135 | except Exception as exc: 136 | if isinstance(exc, GraphQLError): 137 | await self.send_execution_result(context, op_id, ExecutionResult(data=None, errors=[exc])) 138 | else: 139 | await self.send_error(context, op_id, {'message': str(exc)}) 140 | return 141 | 142 | result_or_iterator = await subscribe( 143 | self.schema, 144 | doc, 145 | variable_values=payload.variables, 146 | context_value=context, 147 | operation_name=payload.operation_name, 148 | ) 149 | if isinstance(result_or_iterator, ExecutionResult): 150 | result_or_iterator = create_async_iterator([result_or_iterator]) 151 | 152 | context.operations[op_id] = result_or_iterator 153 | 154 | async def iter_result(): 155 | async for result in result_or_iterator: 156 | await self.send_execution_result(context, op_id, result) 157 | 158 | await self.send_message(context, MessageType.GQL_COMPLETE, op_id=op_id) 159 | 160 | asyncio.create_task(iter_result()) 161 | 162 | async def send_execution_result(self, context: ConnectionContext, op_id: str, result: ExecutionResult) -> None: 163 | payload = { 164 | 'data': result.data, 165 | 'errors': [format_error(error) for error in result.errors] if result.errors else None, 166 | } 167 | await self.send_message( 168 | context, MessageType.GQL_DATA, op_id=op_id, payload=payload, 169 | ) 170 | 171 | async def send_message( 172 | self, context: ConnectionContext, message_type: MessageType, op_id: str = None, payload: dict = None, 173 | ) -> None: 174 | data = {'type': message_type.value} 175 | if op_id: 176 | data['id'] = op_id 177 | if payload: 178 | data['payload'] = payload 179 | await context.socket.send_json(data) 180 | 181 | async def send_error( 182 | self, 183 | context: ConnectionContext, 184 | op_id: str = None, 185 | playload: dict = None, 186 | error_type: MessageType = MessageType.GQL_ERROR, 187 | ): 188 | assert error_type in [MessageType.GQL_ERROR, MessageType.GQL_CONNECTION_ERROR] 189 | await self.send_message(context, error_type, op_id, payload=playload) 190 | 191 | async def send_keep_alive(self, context: ConnectionContext) -> None: 192 | await self.send_message(context, MessageType.GQL_CONNECTION_KEEP_ALIVE) 193 | 194 | async def decode(self, context: ConnectionContext, message: Message) -> OperationMessage: 195 | if message.get("text") is not None: 196 | text = message["text"] 197 | else: 198 | text = message["bytes"].decode("utf-8") 199 | 200 | try: 201 | return OperationMessage.build(json.loads(text)) 202 | except json.decoder.JSONDecodeError as exc: 203 | await self.send_error(context, None, {'message': str(exc)}, MessageType.GQL_CONNECTION_ERROR) 204 | --------------------------------------------------------------------------------