Есть ли способ исправить ошибку: Ошибка получения метаданных из плагина с ошибкой: invalid_grant: неверный JWT - PullRequest
0 голосов
/ 10 июня 2019

Я настроил функции облачной базы Firebase для использования Express, а также для авторизации использую свойство firebase SDK auth. Я заметил, что мой администратор, который использует firebase-admin для создания нового пользовательского документа в firestore, не запускается после развертывания.

Используя почтальон, я попытался зарегистрировать нового пользователя и получить эту ошибку из firebase:

Error: Getting metadata from plugin failed with error: invalid_grant: Invalid JWT: Token must be a short-lived token (60 minutes) and in a reasonable timeframe. Check your iat and exp values and use a clock with skew to account for clock differences between systems.

Как я могу это исправить?

Я создал маршрут входа в систему, который отлично работает и возвращает токен, поскольку он вызывает только свойство аутентификации firebase SDK для входа в систему

Вот мой код проекта:

инициализация firebase-admin


const admin = require("firebase-admin");

const serviceAccount = require("./would-you-rather-app-c5895-firebase-adminsdk-lndjl-f7793c362b.json");

admin.initializeApp({
  credential: admin.credential.cert(serviceAccount),
  databaseURL: `https://${serviceAccount.project_id}.firebaseio.com`
});

const db = admin.firestore(); 
module.exports = { admin, db };

экспресс-настройка


const functions = require('firebase-functions');
const app = require("express")();

// const cors = require("cors");
// app.use(cors());

const { signup, login } = require("./handlers/users");

// users routes
app.post("/signup", signup);
app.post("/login", login);

app.get("/", (request, response) => {
  response.send("Hello from Firebase!");
});

exports.api = functions.https.onRequest(app);

регистрация пользователя и обработчик входа в систему


const { admin, db } = require("../util/admin");
const config = require("../util/config");

const client = require("firebase");
client.initializeApp(config);

// Sign user up
exports.signup = (req, res) => {
  const newUser = {
    email: req.body.email,
    password: req.body.password,
    confirmPassword: req.body.confirmPassword,
    firstName: req.body.firstName,
    lastName: req.body.lastName,
    fullname: `${req.body.firstName} ${req.body.lastName}`
  };

  // TODO: validation

  const noImg = "no-img.png";
  let userId, token;

  client
    .auth()
    .createUserWithEmailAndPassword(newUser.email, newUser.password)
    .then(data => {
      userId = data.user.uid;
      return data.user.getIdToken();
    })
    .then(idToken => {
      token = idToken;
       const userCredentials = {
        fullname: newUser.fullname,
        createdAt: new Date().toISOString(),
        imageUrl: `https://firebasestorage.googleapis.com/v0/b/${
      config.storageBucket
    }/o/${noImg}?alt=media`,
        score: 0,
        questions: [],
        votes: [],
        userId: userId
      };
      return admin
        .firestore()
        .doc(`users/${userId}`)
        .set(userCredentials);
     })
    .then(() => {
      return res.status(201).json({ token });
    })
    .catch(err => {
      console.log("Signup error: ", err);
      if (err.code === "auth/email-already-in-use") {
        return res.status(400).json({ email: "Email already in use" });
      } else {
        return res
          .status(500)
          .json({ general: "Something went wrong, please try agin" });
      }
    });
};

// Log user in
exports.login = (req, res) => {
  const user = {
    email: req.body.email,
    password: req.body.password
  };

  client
    .auth()
    .signInWithEmailAndPassword(user.email, user.password)
    .then(data => {
      return data.user.getIdToken();
    })
    .then(token => {
      return res.json({ token });
    })
    .catch(err => {
      return res
        .status(403)
        .json({ general: "Wrong credentials, please try again" });
    });
};

Запущенная регистрация возвращает ошибку при успешном завершении аутентификации, но учетные данные пользователя не добавлены в хранилище ...

Firebase-отладка журнал


[info] i  functions: Beginning execution of "api"
[debug] [2019-06-10T17:40:33.997Z] Disabled runtime features: {"functions_config_helper":true,"network_filtering":true,"timeout":true,"memory_limiting":true,"protect_env":true,"admin_stubs":true}
[debug] [2019-06-10T17:40:35.600Z] firebase-admin has been stubbed.
[info] i  Your code has been provided a "firebase-admin" instance.
[debug] [2019-06-10T17:40:36.599Z] Trigger "api" has been found, beginning invocation!
[debug] [2019-06-10T17:40:36.600Z] 
[debug] [2019-06-10T17:40:36.600Z] Running api in mode HTTPS
[debug] [2019-06-10T17:40:36.612Z] {"socketPath":"\\\\?\\pipe\\C:\\Users\\ismail\\Documents\\Archive\\tutorial-codes\\NanoRD\\proj3\\proj3\\functions\\9796"}
[debug] [2019-06-10T17:40:36.617Z] [functions] Runtime ready! Sending request! {"socketPath":"\\\\?\\pipe\\C:\\Users\\ismail\\Documents\\Archive\\tutorial-codes\\NanoRD\\proj3\\proj3\\functions\\9796"}
[debug] [2019-06-10T17:40:36.660Z] Ephemeral server used!
[debug] [2019-06-10T17:40:36.717Z] Ephemeral server survived.
[info] >  Signup error:  Error: Getting metadata from plugin failed with error: invalid_grant: Invalid JWT: Token must be a short-lived token (60 minutes) and in a reasonable timeframe. Check your iat and exp values and use a clock with skew to account for clock differences between systems.
[info] >      at Http2CallStream.<anonymous> (C:\Users\ismail\Documents\Archive\tutorial-codes\NanoRD\proj3\proj3\functions\node_modules\@grpc\grpc-js\build\src\client.js:101:45)
[info] >      at Http2CallStream.emit (events.js:201:15)
[info] >      at C:\Users\ismail\Documents\Archive\tutorial-codes\NanoRD\proj3\proj3\functions\node_modules\@grpc\grpc-js\build\src\call-stream.js:71:22
[info] >      at processTicksAndRejections (internal/process/task_queues.js:81:9) {
[info] >    code: '400',
[info] >    details: 'Getting metadata from plugin failed with error: invalid_grant: ' +
[info] >      'Invalid JWT: Token must be a short-lived token (60 minutes) and ' +
[info] >      'in a reasonable timeframe. Check your iat and exp values and use ' +
[info] >      'a clock with skew to account for clock differences between ' +
[info] >      'systems.',
[info] >    metadata: Metadata { options: undefined, internalRepr: Map {} }
[info] >  }
[info] i  functions: Finished "api" in ~2s

Я ожидал токен возврата при регистрации и новые учетные данные пользователя, хранящиеся в firestore

1 Ответ

0 голосов
/ 11 июня 2019

Я наконец нашел способ синхронизировать часы моего компьютера. Эта статья была полезна: 4 способа автоматической синхронизации часов компьютера при запуске Windows

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...