将字段添加到Graphcool电子邮件密码模板变异

时间:2018-06-07 16:19:19

标签: reactjs graphql graphcool

我使用电子邮件密码模板通过用户身份验证设置我的graphcool服务器。我想在注册新用户时为“name”添加属性。我将名称添加到User模型并更新了signup.graphql和signup.ts代码,如下所示。

运行createUser变种时出现“未定义名称”的错误。我不确定问题是什么。非常感谢任何帮助!

signup.graphql

extend type Mutation {
  signupUser(email: String!, password: String!, name: String): SignupUserPayload
}

signup.ts

interface EventData {
  email: string
  password: string
  name: string
}

const SALT_ROUNDS = 10

export default async (event: FunctionEvent<EventData>) => {
  console.log(event)

  try {
    const graphcool = fromEvent(event)
    const api = graphcool.api('simple/v1')

    const { email, password } = event.data

    if (!validator.isEmail(email)) {
      return { error: 'Not a valid email' }
    }

    // check if user exists already
    const userExists: boolean = await getUser(api, email)
      .then(r => r.User !== null)
    if (userExists) {
      return { error: 'Email already in use' }
    }

    // create password hash
    const salt = bcrypt.genSaltSync(SALT_ROUNDS)
    const hash = await bcrypt.hash(password, salt)

    // create new user
    const userId = await createGraphcoolUser(api, email, hash, name)

    // generate node token for new User node
    const token = await graphcool.generateNodeToken(userId, 'User')

    return { data: { id: userId, token } }
  } catch (e) {
    console.log(e)
    return { error: 'An unexpected error occured during signup.' }
  }
}

async function getUser(api: GraphQLClient, email: string): Promise<{ User }> {
  const query = `
    query getUser($email: String!) {
      User(email: $email) {
        id
      }
    }
  `

  const variables = {
    email,
  }

  return api.request<{ User }>(query, variables)
}

async function createGraphcoolUser(api: GraphQLClient, email: string, password: string, name: string): Promise<string> {
  const mutation = `
    mutation createGraphcoolUser($email: String!, $password: String!, $name: String) {
      createUser(
        email: $email,
        password: $password,
        name: $name
      ) {
        id
      }
    }
  `

  const variables = {
    email,
    password: password,
    name: name
  }

  return api.request<{ createUser: User }>(mutation, variables)
    .then(r => r.createUser.id)

1 个答案:

答案 0 :(得分:0)

找到答案。我在这条线上缺少名字..

const { email, password } = event.data

改变这就解决了它

const { email, password, name } = event.data