石墨烯-SqlAlchemy-抽象属性

时间:2018-09-14 08:51:17

标签: python sqlalchemy graphql flask-sqlalchemy graphene-python

我要迁移来停靠一个稍旧的python应用程序,该应用程序未维护。...我制作了pip freeze,以查看将要生产的产品。 我面临一个难以解决的问题。我有这个错误: 所以我想知道这是否与一个不被尊重的版本有关。该项目在python 3.6.2。上运行。

您知道我如何解决该问题吗?

stacktrace

raphql_1  |   File "/usr/local/bin/gunicorn", line 11, in <module>
graphql_1  |     sys.exit(run())
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/wsgiapp.py", line 74, in run
graphql_1  |     WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/base.py", line 203, in run
graphql_1  |     super(Application, self).run()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/base.py", line 72, in run
graphql_1  |     Arbiter(self).run()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/arbiter.py", line 60, in __init__
graphql_1  |     self.setup(app)
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/arbiter.py", line 120, in setup
graphql_1  |     self.app.wsgi()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/base.py", line 67, in wsgi
graphql_1  |     self.callable = self.load()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/wsgiapp.py", line 65, in load
graphql_1  |     return self.load_wsgiapp()
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/app/wsgiapp.py", line 52, in load_wsgiapp
graphql_1  |     return util.import_app(self.app_uri)
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/gunicorn/util.py", line 352, in import_app
graphql_1  |     __import__(module)
graphql_1  |   File "/workspace/src/server/main.py", line 15, in <module>
graphql_1  |     from api import root
graphql_1  |   File "/workspace/src/api/root.py", line 6, in <module>
graphql_1  |     from api import mutation, query
graphql_1  |   File "/workspace/src/api/mutation.py", line 4, in <module>
graphql_1  |     from api.object_types import (availability, home, home_feature,
graphql_1  |   File "/workspace/src/api/object_types/availability.py", line 6, in <module>
graphql_1  |     from api.helpers.objecttype import QueryProvidingObjectType
graphql_1  |   File "/workspace/src/api/helpers/objecttype.py", line 49, in <module>
graphql_1  |     class QueryProvidingObjectType(SQLAlchemyObjectType):
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/graphene_sqlalchemy/types.py", line 85, in __new__
graphql_1  |     registry=None
graphql_1  |   File "/usr/local/lib/python3.6/site-packages/graphene/types/options.py", line 29, in __init__
graphql_1  |     ', '.join(sorted(meta_attrs.keys()))
graphql_1  | TypeError: Invalid attributes: abstract

requirement.txt

alembic==0.9.7
backports.csv==1.0.5
certifi==2017.11.5
chardet==3.0.4
cli-helpers==0.2.2
click==6.7
configobj==5.0.6
decorator==4.2.1
fin==2.1.8
flake8==3.4.1
Flask==0.12.2
Flask-Cors==3.0.3
Flask-GraphQL==1.4.1
Flask-SSLify==0.1.5
graphene==1.4.1
graphene-sqlalchemy==1.1.1
graphql-core==1.1
graphql-relay==0.4.5
graypy==0.2.14
gunicorn==19.7.1
httplib2==0.10.3
humanize==0.5.1
idna==2.6
ipython==6.2.1
ipython-genutils==0.2.0
iso8601==0.1.12
itsdangerous==0.24
jedi==0.11.1
Jinja2==2.9.6
Mako==1.0.7
MarkupSafe==1.0
mccabe==0.6.1
mock==2.0.0
oauth2client==4.1.2
parso==0.1.1
pbr==3.1.1
pexpect==4.3.1
pgcli==1.7.0
pgspecial==1.8.0
pickleshare==0.7.4
promise==2.1
prompt-toolkit==1.0.15
psycopg2==2.7.1
ptyprocess==0.5.2
py==1.4.34
pyasn1==0.4.2
pyasn1-modules==0.2.1
pycodestyle==2.3.1
pyflakes==1.5.0
Pygments==2.2.0
pytest==3.1.3
python-dateutil==2.6.1
python-editor==1.0.3
PyYAML==3.12
requests==2.18.4
rsa==3.4.2
setproctitle==1.1.10
simplegeneric==0.8.1
singledispatch==3.4.0.3
six==1.10.0
SQLAlchemy==1.1.12
sqlalchemy-citext==1.3.post0
SQLAlchemy-Utils==0.32.14
sqlparse==0.2.4
terminaltables==3.1.0
testfixtures==5.3.1
traitlets==4.3.2
typing==3.6.2
typing-inspect==0.1.1
Unidecode==0.4.21
urllib3==1.22
wcwidth==0.1.7
Werkzeug==0.12.2

与错误相关的相关类:

class QueryProvidingObjectType(SQLAlchemyObjectType):
    class Meta:
        abstract = True

    # TODO: copy-pasta duplication here:
    @classmethod
    def QueryOne(cls, filter_fields):
        def resolver(self, args, context, info):
            query = cls.get_query(context)
            query = apply_filter(query, cls._meta.model, args)
            return query.first()
        all_fields = cls._meta.fields
        fields = {name: field_to_argument(cls, name, all_fields[name])
                  for name in filter_fields}
        return graphene.Field(
            cls,
            resolver=resolver,
            args=fields,
            description=f"Return the first {cls} that matches the filters"
            )

    @classmethod
    def QueryList(cls, filter_fields=(), sort_by=None):
        def resolver(self, args, context, info):
            query = cls.get_query(context)
            if sort_by:
                query = apply_sort(query, cls._meta.model, sort_by)
            query = apply_filter(query, cls._meta.model, args)
            return query.all()

        all_fields = cls._meta.fields
        model_fields = {name: field_to_argument(cls, name, all_fields[name])
                        for name in filter_fields}
        model_fields.update({
            "first": graphene.Int(),
            "after": graphene.Int()
        })
        description = f"Query for all {cls}s"
        if filter_fields:
            description += " (optionally filtered using provided arguments)"
        return graphene.List(
            cls,
            resolver=resolver,
            args=model_fields,
            description=description)

    @classmethod
    def FuzzySearch(cls, match_field):
        mapper = MapperFactory.get_mapper(FuzzySearchResult[cls])
        result_type = mapper.graphene_output_type()

        def resolver(self, args, context, info):
            first = args.pop('first', 5)
            attr_name, search_query = list(args.items())[0]

            query = cls.get_query(context).all()
            return fuzzy_search(search_query, query, key=attrgetter(attr_name), limit=first)

        all_fields = cls._meta.fields
        fields = {
            match_field: field_to_argument(cls, match_field, all_fields[match_field]),
            'first': graphene.Argument(
                graphene.Int,
                description="[optional] limit the number of results"
            ),
        }
        return graphene.List(result_type, resolver=resolver, args=fields)

0 个答案:

没有答案