从突变中返回结果

时间:2016-05-09 00:29:50

标签: graphql graphql-js

我的直接问题是,为什么不调用查询解析函数?

我怀疑变异解析函数的返回值是否存在问题(有效)。那么,返回值应该是什么样的呢?

更高级别的问题是:GraphQL中是否有标准方式来注册新用户并处理用户已存在的情况?

以下方法是在会话数据中包含有关用户的所有数据,并仅传回前端所需的数据。

/**
 * graphQL.js
 *
 * Created by jrootham on 18/04/16.
 *
 * Copyright © 2016 Jim Rootham
 */

import graphqlHTTP from "express-graphql";
import {
    graphql,
    GraphQLSchema,
    GraphQLObjectType,
    GraphQLString,
    GraphQLNonNull,
    GraphQLBoolean
} from 'graphql';
import {hash} from "bcrypt"
import {connect, User} from "../database/defineDB";

const GraphUser = new GraphQLObjectType({
    name: "GraphUser",
    description: "A user object",
    fields: () => {
        return {
            name: {
                type: GraphQLString,
                resolve: (_, __, session) => {
                    console.log("resolve name", session);
                    let name = "";
                    if (session.signedOn) {
                        return User.findById(session.userId).then (user => {
                            return user.name;
                        });
                    }

                    console.log("name", name);
                    return name;
                }
            },
            signedOn: {
                type: GraphQLBoolean,
                resolve: (_, __, session) => {
                    return session.signedOn;
                }
            },
            existed: {
                type: GraphQLBoolean,
                resolve: (_, __, session) => {
                    return session.existed;
                }
            }
        }
    }
});

const query = new GraphQLObjectType({
    name: 'Queries',
    fields: () => {
        return {
            graphUser: {
                type: GraphUser
            }
        }
    }
});

const mutation = new GraphQLObjectType({
    name: 'Mutations',
    description: "Modification actions",
    fields() {
        return {
            registerUser: {
                type: GraphUser,
                args: {
                    name: {
                        type: new GraphQLNonNull(GraphQLString)
                    },
                    password: {
                        type: new GraphQLNonNull(GraphQLString)
                    }
                },
                resolve(_, args, session) {
                    console.log("resolve", args);
                    User.findOne({where:{name:args.name}}).then(user => {
                        console.log("After find", user);
                        if (user === null) {
                            const getHash = new Promise(
                                resolve => {
                                    hash(args.password, 10, (err, hash) => {
                                        resolve(hash);
                                    });
                                }
                            );

                            const result = getHash.then(hash => {
                                connect.models.user.create({
                                    name: args.name,
                                    password: hash
                                }).then(user => {
                                    session.userId = user.id;
                                    session.signedOn = true;
                                    session.existed = false;

                                    console.log("session user", session.userId);
                                    return user;
                                });

                                console.log(result);
                                return result;
                            });
                        }
                        else {
                            session.userId = 0;
                            session.signedOn = false;
                            session.existed = true;
                            console.log("existed");
                            return GraphUser;
                        }
                    });
                }
            }
        }
    }
});

const schema = new GraphQLSchema({
    query: query,
    mutation: mutation
});

export const useGraphQL = app => {
    app.use('/graphql', graphqlHTTP(request =>({
        schema: schema,
        context: request.session,
        formatError: error => ({
            message: error.message,
            locations: error.locations,
            stack: error.stack
        }),
        graphiql:true
    })));
};

2 个答案:

答案 0 :(得分:2)

为什么不调用查询解析函数?

您的根查询字段graphUser无法解析。

const query = new GraphQLObjectType({
    name: 'Queries',
    fields: () => {
        return {
            graphUser: {
                type: GraphUser
                // TODO Add a resolve function here
            }
        }
    }
});

我怀疑变异解析函数的返回值是否存在问题(可行)。那么,返回值应该是什么样的呢?

如果你使用Promise,你的变异的resolve函数应该返回一个Promise(它现在不返回)并且应该使用resolve(result)而不是return result。如果用户已存在,则只返回现有用户对象,而不是类型 GraphUser

更高级别的问题是:GraphQL中是否有标准方式来注册新用户并处理用户已存在的情况?

GraphQL本身没有处理用户注册的标准方法。您只需要一个用户注册的变异。在变异的解析功能中,检查用户是否已存在。如果存在,则突变可以返回错误。否则,将注册用户并返回新创建的用户对象。

答案 1 :(得分:1)

需要返回创建的Promise,并且每个.then函数也需要返回其参数。事实证明这是一个处理Promises而不是GraphQL问题的问题。