как на самом деле использовать данные, запрошенные с помощью раздора oauth2 - PullRequest
0 голосов
/ 27 января 2019

Я не совсем уверен, как поступить с использованием / доступом к данным, запрашиваемым с помощью аутентификации discord oauth2.Я запросил доступ к гильдиям, в которых находится пользователь, а также к имени пользователя и аватару пользователя.Я получил успешную аутентификацию, но у меня вопрос, как мне использовать и получить доступ к этим данным?В настоящее время это мой код:

server.js

const express = require('express');
const path = require('path');

const app = express();

app.use('/static', express.static(path.join(__dirname, 'static')));

app.get('/', (req, res) => {
  res.status(200).sendFile(path.join(__dirname, 'index.html'));
});

app.listen(50451, () => {
  console.info('Running on port 50451');
});

app.use('/api/discord', require('./api/discord'));

app.use((err, req, res, next) => {
  switch (err.message) {
    case 'NoCodeProvided':
      return res.status(400).send({
        status: 'ERROR',
        error: err.message,
      });
    default:
      return res.status(500).send({
        status: 'ERROR',
        error: err.message,
      });
  }
});

discord.js

const express = require('express');
const dotenv = require('dotenv').config()
const fetch = require('node-fetch');
const btoa = require('btoa');
const { catchAsync } = require('../utils');

const router = express.Router();
const scopes = ['identify', 'guilds'];

const CLIENT_ID = process.env.CLIENT_ID;
const CLIENT_SECRET = process.env.CLIENT_SECRET;
const redirect =       
encodeURIComponent('http://localhost:50451/api/discord/callback');

router.get('/login', (req, res) => {
  res.redirect(`https://discordapp.com/api/oauth2/authorize?client_id=${CLIENT_ID}&redirect_uri=${redirect}&response_type=code&scope=identify%20guilds`);
});

router.get('/callback', catchAsync(async (req, res) => {
  if (!req.query.code) throw new Error('NoCodeProvided');
  const code = req.query.code;
  const creds = btoa(`${CLIENT_ID}:${CLIENT_SECRET}`);
  const response = await fetch(`https://discordapp.com/api/oauth2/token?grant_type=authorization_code&code=${code}&redirect_uri=${redirect}`,
    {
  method: 'POST',
  headers: {
    Authorization: `Basic ${creds}`,
  },
});
  const json = await response.json();
  res.redirect(`/success/?token=${json.access_token}`);
}));

module.exports = router;

Любая помощь будет принята с благодарностью.Спасибо!

1 Ответ

0 голосов
/ 13 марта 2019

Это почти так же, как вы используете req.query.code для получения access_token.

const fetchDiscordUserInfo = await fetch('http://discordapp.com/api/users/@me', {
  headers: {
    Authorization: `Bearer ${json.access_token}`,
  }
});
const userInfo = await fetchDiscordUserInfo.json();

yourUserId = `${userInfo.id}`;
yourUserName = `${userInfo.username}`;

// or simply...
console.log(userInfo);
...