當前位置: 首頁>>代碼示例>>Python>>正文


Python graphql.ResolveInfo方法代碼示例

本文整理匯總了Python中graphql.ResolveInfo方法的典型用法代碼示例。如果您正苦於以下問題:Python graphql.ResolveInfo方法的具體用法?Python graphql.ResolveInfo怎麽用?Python graphql.ResolveInfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在graphql的用法示例。


在下文中一共展示了graphql.ResolveInfo方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: MenusQueryMixin

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def MenusQueryMixin():
    class Mixin:
        main_menu = graphene.List(Menu)
        secondary_menu = graphene.Field(SecondaryMenu,
                                        handle=graphene.String(required=True))
        secondary_menus = graphene.List(SecondaryMenu)

        def resolve_main_menu(self, _info: ResolveInfo) -> List[MainMenu]:
            return MainMenu.objects.all()

        def resolve_secondary_menus(self, _info: ResolveInfo) -> List[FlatMenu]:
            return FlatMenu.objects.all()

        def resolve_secondary_menu(self, _info, handle: ResolveInfo) -> FlatMenu:
            return FlatMenu.objects.filter(handle=handle).first()
    return Mixin 
開發者ID:tr11,項目名稱:wagtail-graphql,代碼行數:18,代碼來源:menus.py

示例2: resolve_submissionList

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def resolve_submissionList(self: None, info: ResolveInfo, page: int, **kwargs):
        pk = kwargs.get('pk')
        user = kwargs.get('user')
        problem = kwargs.get('problem')
        judge_status = kwargs.get('judge_status')
        language = kwargs.get('language')
        status_list = Submission.objects.all().order_by('-pk')
        # Only consider base class
        status_list = status_list.filter(submission_type=0)
        if not info.context.user.has_perm('problem.view'):
            status_list = status_list.filter(problem__disable=False)
        if not info.context.user.has_perm('user.view') or not info.context.user.has_perm('submission.view'):
            status_list = status_list.filter(user__is_staff=False)
        if pk:
            status_list = status_list.filter(pk=pk)
        if user:
            status_list = status_list.filter(user__username=user)
        if problem:
            status_list = status_list.filter(problem__slug=problem)
        if judge_status:
            status_list = status_list.filter(result___result=judge_status)
        if language:
            status_list = status_list.filter(_language=language)
        paginator = Paginator(status_list, PER_PAGE_COUNT)
        return SubmissionListType(max_page=paginator.num_pages, submission_list=paginator.get_page(page)) 
開發者ID:lutece-awesome,項目名稱:lutece-backend,代碼行數:27,代碼來源:query.py

示例3: mutate

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def mutate(self, info: ResolveInfo, **kwargs):
        signup_form = UserSignupForm(kwargs)
        if signup_form.is_valid():
            values = signup_form.cleaned_data
            usr = User()
            attach_info = AttachInfo()
            assign(usr, **values)
            assign(attach_info, **values)
            usr.set_password(usr.password)
            attach_info.save()
            usr.attach_info = attach_info
            usr.save()
            token = get_token(usr)
            payload = get_payload(token, info.context)
            return UserRegister(payload=payload, token=token, permission=list(usr.get_all_permissions()), user=usr)
        else:
            raise RuntimeError(signup_form.errors.as_json()) 
開發者ID:lutece-awesome,項目名稱:lutece-backend,代碼行數:19,代碼來源:mutation.py

示例4: mutate

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def mutate(self, info: ResolveInfo, **kwargs):
        form = UpdateProblemForm(kwargs)
        if form.is_valid():
            values = form.cleaned_data
            samples = loads(values.get('samples'))
            prob = Problem.objects.get(slug=values.get('slug'))
            assign(prob, **values)
            assign(prob.limitation, **values)
            prob.limitation.save()
            prob.save()
            ProblemSample.objects.filter(problem=prob).delete()
            for each in samples:
                ProblemSample(
                    input_content=each.get('inputContent'),
                    output_content=each.get('outputContent'),
                    problem=prob
                ).save()
            # To avoid the slug change, re-fetch the problem object
            return UpdateProblem(slug=prob.slug)
        else:
            raise RuntimeError(form.errors.as_json()) 
開發者ID:lutece-awesome,項目名稱:lutece-backend,代碼行數:23,代碼來源:mutation.py

示例5: has_permission

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def has_permission(self, info: ResolveInfo):
        return self.op_func(
            self.op1.has_permission(info), self.op2.has_permission(info)
        ) 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:6,代碼來源:permissions.py

示例6: has_node_permission

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def has_node_permission(self, info: ResolveInfo, id: str) -> bool:
        return self.op_func(
            self.op1.has_node_permission(info, id),
            self.op2.has_node_permission(info, id),
        ) 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:7,代碼來源:permissions.py

示例7: has_mutation_permission

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def has_mutation_permission(
        self, root: Any, info: ResolveInfo, input: dict
    ) -> bool:
        return self.op_func(
            self.op1.has_mutation_permission(root, info, input),
            self.op2.has_mutation_permission(root, info, input),
        ) 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:9,代碼來源:permissions.py

示例8: has_filter_permission

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def has_filter_permission(self, info: ResolveInfo):
        return self.op_func(
            self.op1.has_filter_permission(info), self.op2.has_filter_permission(info)
        ) 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:6,代碼來源:permissions.py

示例9: get_node

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def get_node(cls, info: ResolveInfo, id: str) -> Optional[Model]:
        if all((perm.has_node_permission(info, id) for perm in cls.permission_classes)):
            try:
                object_instance = cls._meta.model.objects.get(pk=id)  # type: ignore
            except cls._meta.model.DoesNotExist:  # type: ignore
                object_instance = None
            return object_instance
        else:
            return None 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:11,代碼來源:mixins.py

示例10: has_permission

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def has_permission(cls, info: ResolveInfo) -> bool:
        return all(
            (perm.has_filter_permission(info) for perm in cls.permission_classes)
        ) 
開發者ID:redzej,項目名稱:graphene-permissions,代碼行數:6,代碼來源:mixins.py

示例11: _aliases_from_info

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def _aliases_from_info(
        cls, info: graphene.ResolveInfo
    ) -> 'Dict[str, _MapperEntity]':
        """
        Get cached aliases from graphene ResolveInfo object.

        Notes:
            Deprecated.

        Args:
            info: Graphene ResolveInfo object.

        Returns:
            Dictionary of model aliases.

        """
        context = info.context

        if isinstance(context, dict):
            filter_aliases = context[cls._filter_aliases]
        elif '__dict__' in context.__dir__():
            filter_aliases = getattr(context, cls._filter_aliases)
        else:
            raise RuntimeError(
                'Not supported with info.context type {}'.format(type(context))
            )

        return filter_aliases 
開發者ID:art1415926535,項目名稱:graphene-sqlalchemy-filter,代碼行數:30,代碼來源:filters.py

示例12: filter

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def filter(
        cls, info: ResolveInfo, query: Query, filters: 'FilterType'
    ) -> Query:
        """
        Return a new query instance with the args ANDed to the existing set.

        Args:
            info: GraphQL execution info.
            query: SQLAlchemy query.
            filters: Filters dictionary.

        Returns:
            Filtered query instance.

        """
        context = info.context

        if isinstance(context, dict):
            context[cls._filter_aliases] = {}
        elif '__dict__' in context.__dir__():
            setattr(context, cls._filter_aliases, {})
        else:
            msg = (
                'Graphene-SQLAlchemy-Filter: '
                'info.context has an unsupported type {}. '
                'Now cls.aliased(info, ...) is not supported. '
                'Allowed types: dict and object with __dict__ attribute.'
            ).format(type(context))
            warnings.warn(msg, RuntimeWarning)

        query, sqla_filters = cls._translate_many_filter(info, query, filters)
        if sqla_filters is not None:
            query = query.filter(*sqla_filters)

        return query 
開發者ID:art1415926535,項目名稱:graphene-sqlalchemy-filter,代碼行數:37,代碼來源:filters.py

示例13: info

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def info():
    db = create_engine('sqlite://')  # in-memory
    connection = db.engine.connect()
    transaction = connection.begin()
    Base.metadata.create_all(connection)

    session_factory = sessionmaker(bind=connection)
    session = scoped_session(session_factory)

    yield ResolveInfo(*[None] * 9, context={'session': session})

    transaction.rollback()
    connection.close()
    session.remove() 
開發者ID:art1415926535,項目名稱:graphene-sqlalchemy-filter,代碼行數:16,代碼來源:conftest.py

示例14: query

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def query(queryset, info, **options):
    """
    Automatically optimize queries.

    Arguments:
        - queryset (Django QuerySet object) - The queryset to be optimized
        - info (GraphQL ResolveInfo object) - This is passed by the graphene-django resolve methods
        - **options - optimization options/settings
            - disable_abort_only (boolean) - in case the objecttype contains any extra fields,
                                             then this will keep the "only" optimization enabled.
    """

    return QueryOptimizer(info, **options).optimize(queryset) 
開發者ID:tfoxy,項目名稱:graphene-django-optimizer,代碼行數:15,代碼來源:query.py

示例15: _create_resolve_info

# 需要導入模塊: import graphql [as 別名]
# 或者: from graphql import ResolveInfo [as 別名]
def _create_resolve_info(self, field_name, field_asts, return_type, parent_type):
        return ResolveInfo(
            field_name,
            field_asts,
            return_type,
            parent_type,
            schema=self.root_info.schema,
            fragments=self.root_info.fragments,
            root_value=self.root_info.root_value,
            operation=self.root_info.operation,
            variable_values=self.root_info.variable_values,
            context=self.root_info.context,
        ) 
開發者ID:tfoxy,項目名稱:graphene-django-optimizer,代碼行數:15,代碼來源:query.py


注:本文中的graphql.ResolveInfo方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。