5

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

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

一个更高层次的问题是: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
    })));
};
4

2 回答 2

3

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

您的根查询字段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. 如果 user 已经存在,只需返回现有的 user对象而不是type GraphUser

一个更高层次的问题是:GraphQL 中是否有标准方法来注册新用户并处理用户已经存在的情况?

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

于 2016-05-09T04:26:25.797 回答
0

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

于 2016-06-13T17:17:30.203 回答