Ошибка разрешения в функции Firebase Cloud - PullRequest
0 голосов
/ 29 мая 2020

Я хочу реализовать аутентификацию Slack с помощью Passport. js + Функция Firebase Cloud. Но когда я перенаправляю URL-адрес, возникает запрещенная ошибка.

Ошибка:

У вашего клиента нет разрешения на получение URL / api / auth / slack? Uid = XXXXXXXXXXX & redirectTo = http://localhost: 3000 с этого сервера.

Код React:

const slackAuthorizeURL = (uid) =>
  `https://us-central1-xxxxxxxxx.cloudfunctions.net/api/auth/slack?uid=${uid}&redirectTo=${window.location.href}`

<a href={slackAuthorizeURL}>Sign in with Slack</a>

Код сервера:

const express = require('express')
const session = require('express-session')
const app = express()
const allowedOrigins = [
  'http://localhost:3000',
]
const allowCrossDomain = (req, res, next) => {
  const origin = req.headers.origin
  if (allowedOrigins.includes(origin)) {
    res.header('Access-Control-Allow-Origin', origin)
  }
  res.header('Access-Control-Allow-Methods', 'GET,POST')
  res.header('Access-Control-Allow-Headers', 'Content-Type')
  next()
}
app.use(allowCrossDomain)

app.use(session({ secret: config.session.secret }))

const passport = require('passport')

app.use(passport.initialize())
app.use(passport.session())
app.get('/auth/slack', (req, res, next) => {
  req.session.uid = req.query.uid
  req.session.redirectTo = req.query.redirectTo
  passport.authenticate('slack')(req, res, next)
})

I уже настроили allUsers на Cloud Functions Admin на API в Google Cloud Platform.

1 Ответ

1 голос
/ 29 мая 2020

Я пропустил правильную настройку allUsers to Cloud Functions Admin на api в Google Cloud Platform.

https://cloud.google.com/functions/docs/securing/managing-access#allowing_unauthenticated_function_invocation

...