Я хотел бы начать с написания среды, которую, к сожалению, мне пришлось использовать
windows 10 / 64 bit's
Visual-Studio-Code
Я новичок в технологии GraphQL, поэтому у меня есть такие вопросы.
Я не понимаю, почему, когда все функции резолверов находятся в одном файле, весь проект отлично работает ..
к сожалению, когда он начинает больше заботиться о структуре, все начинает делать новую ошибку
Как показано ниже, у меня возникает этот тип ошибки, когда я пытаюсь запустить сервер узла.
(function (exports, require, module, __filename, __dirname) { ��c
^
SyntaxError: Invalid or unexpected token
at createScript (vm.js:80:10)
at Object.runInThisContext (vm.js:139:10)
at Module._compile (module.js:616:28)
at Object.Module._extensions..js (module.js:663:10)
at Module.load (module.js:565:32)
at tryModuleLoad (module.js:505:12)
at Function.Module._load (module.js:497:3)
at Module.require (module.js:596:17)
at require (internal/module.js:11:18)
at Object.<anonymous> (C:\Users\Weronika\Documents\michal\first-graphgl-server\src\index.js:5:18)Здесь я размещаю структуру проекта
--database/
--src/
----generated/
----resolvers/
------Mutation.js
------AuthPayload.js
----index.js
--package.json
--.graphqlconfig.yml
schema.graphql
utils.js
Кроме того, я публикую свои зависимости ниже:
{
"name": "first-graphql-server",
"version": "1.0.0",
"main": "index.js",
"license": "MIT",
"dependencies": {
"bcryptjs": "^2.4.3",
"graphql-yoga": "^1.14.12",
"jsonwebtoken": "^8.3.0",
"prisma-binding": "^2.1.1"
}
}
И, ниже, файл Mutation.js, в котором проблема
const bcrypt = require('bcryptjs')
const jwt = require('jsonwebtoken')
const { APP_SECRET, getUserId } = require('../utils')
async function signup(parent, args, context, info) {
const password = await bcrypt.hash(args.password, 10)
const user = await context.db.mutation.createUser({
data: {...args, password},
}, `{ id }`)
const token = jwt.sign({ userId: user.id }, APP_SECRET)
return {
token,
user,
}
}
async function login(parent, args, context, info) {
const user = await context.db.query.user({ where: { email: args.email } }, `{ id password }`)
if (!user) {
throw new Error('No such user found')
}
const valid = await bcrypt.compare(args.password, user.password)
if (!valid) throw new Error('Invalid password')
const token = jwt.sign({ userId: user.id }, APP_SECRET)
return {
token,
user,
}
}
function post(parent, args, context, info) {
const userId = getUserId(context)
return context.db.mutation.createLink(
{
data: {
url: args.url,
description: args.description,
postedBy: { connect: { id: userId } },
},
},
info,
)
}
module.exports = {
signup,
login,
post,
}
И последний файл, который я должен скопировать в сообщение, но самый важный, файл index.js.
const { GraphQLServer } = require('graphql-yoga');
const { Prisma } = require('prisma-binding');
const Mutation = require('./resolvers/Mutation')
const AuthPayload = require('./resolvers/AuthPayload')
function feed(parent, args, context, info) {
return context.db.query.links({}, info)
}
const Query = {
feed,
}
const resolvers = {
Query,
Mutation,
AuthPayload
}
const server = new GraphQLServer({
typeDefs: './src/schema.graphql',
resolvers,
context: req => ({
...req,
db: new Prisma({
typeDefs: 'src/generated/prisma.graphql',
endpoint: 'https://eu1.prisma.sh/mjaracz-b561d8/example/dev',
secret: 'mysecret123',
debug: true,
}),
}),
})
server.start(() => console.info(`Server is running on the https://localhost:4000`))
Пожалуйста, дайте мне знать, есть ли у кого-нибудь из вас такая же проблема?
Сохранять спокойствие... и заботиться о хорошем качестве кода,
Надеюсь, эта фраза верна мне и обучающему проекту, всем доброго времени суток :)



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Я предполагаю, что у вас неправильная кодировка в файле Mutation.js или какие-то белые пробелы вирд.
Ваша ошибка не имеет ничего общего с самой реализацией. В одном из ваших файлов есть недопустимый символ:
(function (exports, require, module, __filename, __dirname) { ��c
Обратите внимание на символы ��.
Удалите их, чтобы решить эту проблему.
Спасибо за ответ. Как вы думаете, это может быть из-за того, что я использую async-await? Задаёт вопрос, потому что я до сих пор не могу понять, что можно использовать с запрещенным символом ... к сожалению, до того, как я поставил вопрос в стек, у меня была точно такая же ошибка с файлом запросов, который преобразователь теперь переместил в индекс. js хорошего дня и береги себя :)
но к сожалению я не даю ответов на свою проблему