Refactor Slack signin codE
This commit is contained in:
@ -107,7 +107,7 @@ type Props = {
|
|||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { auth, documents, collections, history, ui } = this.props;
|
const { auth, documents, collections, history, ui } = this.props;
|
||||||
const { user } = auth;
|
const { user, team } = auth;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Container column auto>
|
<Container column auto>
|
||||||
@ -128,10 +128,12 @@ type Props = {
|
|||||||
<Flex auto>
|
<Flex auto>
|
||||||
{auth.authenticated &&
|
{auth.authenticated &&
|
||||||
user &&
|
user &&
|
||||||
|
team &&
|
||||||
<Sidebar column editMode={ui.editMode}>
|
<Sidebar column editMode={ui.editMode}>
|
||||||
<Header justify="space-between">
|
<Header justify="space-between">
|
||||||
<Flex align="center">
|
<Flex align="center">
|
||||||
<LogoLink to="/">Atlas</LogoLink>
|
<LogoLink to="/">{team.name}</LogoLink>
|
||||||
|
{user.username}
|
||||||
</Flex>
|
</Flex>
|
||||||
<DropdownMenu label={<Avatar src={user.avatarUrl} />}>
|
<DropdownMenu label={<Avatar src={user.avatarUrl} />}>
|
||||||
<DropdownMenuItem onClick={this.handleOpenSettings}>
|
<DropdownMenuItem onClick={this.handleOpenSettings}>
|
||||||
|
@ -1,11 +1,9 @@
|
|||||||
// @flow
|
// @flow
|
||||||
import Router from 'koa-router';
|
import Router from 'koa-router';
|
||||||
import apiError, { httpErrors } from '../errors';
|
import apiError from '../errors';
|
||||||
import fetch from 'isomorphic-fetch';
|
|
||||||
import querystring from 'querystring';
|
|
||||||
|
|
||||||
import { presentUser, presentTeam } from '../presenters';
|
import { presentUser, presentTeam } from '../presenters';
|
||||||
import { User, Team } from '../models';
|
import { User, Team } from '../models';
|
||||||
|
import * as Slack from '../slack';
|
||||||
|
|
||||||
const router = new Router();
|
const router = new Router();
|
||||||
|
|
||||||
@ -88,24 +86,7 @@ router.post('auth.slack', async ctx => {
|
|||||||
const { code } = ctx.body;
|
const { code } = ctx.body;
|
||||||
ctx.assertPresent(code, 'code is required');
|
ctx.assertPresent(code, 'code is required');
|
||||||
|
|
||||||
const body = {
|
const data = await Slack.oauthAccess(code);
|
||||||
client_id: process.env.SLACK_KEY,
|
|
||||||
client_secret: process.env.SLACK_SECRET,
|
|
||||||
redirect_uri: `${process.env.URL || ''}/auth/slack`,
|
|
||||||
code,
|
|
||||||
};
|
|
||||||
|
|
||||||
let data;
|
|
||||||
try {
|
|
||||||
const response = await fetch(
|
|
||||||
`https://slack.com/api/oauth.access?${querystring.stringify(body)}`
|
|
||||||
);
|
|
||||||
data = await response.json();
|
|
||||||
} catch (e) {
|
|
||||||
throw httpErrors.BadRequest();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data.ok) throw httpErrors.BadRequest(data.error);
|
|
||||||
|
|
||||||
// Temp to block
|
// Temp to block
|
||||||
const allowedSlackDomains = (process.env.ALLOWED_SLACK_DOMAINS || '')
|
const allowedSlackDomains = (process.env.ALLOWED_SLACK_DOMAINS || '')
|
||||||
@ -118,22 +99,20 @@ router.post('auth.slack', async ctx => {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
// User
|
|
||||||
let user = await User.findOne({ where: { slackId: data.user.id } });
|
let user = await User.findOne({ where: { slackId: data.user.id } });
|
||||||
|
|
||||||
// Team
|
|
||||||
let team = await Team.findOne({ where: { slackId: data.team.id } });
|
let team = await Team.findOne({ where: { slackId: data.team.id } });
|
||||||
const teamExisted = !!team;
|
const teamExisted = !!team;
|
||||||
if (!team) {
|
|
||||||
|
if (team) {
|
||||||
|
team.name = data.team.name;
|
||||||
|
team.slackData = data.team;
|
||||||
|
await team.save();
|
||||||
|
} else {
|
||||||
team = await Team.create({
|
team = await Team.create({
|
||||||
name: data.team.name,
|
name: data.team.name,
|
||||||
slackId: data.team.id,
|
slackId: data.team.id,
|
||||||
slackData: data.team,
|
slackData: data.team,
|
||||||
});
|
});
|
||||||
} else {
|
|
||||||
team.name = data.team.name;
|
|
||||||
team.slackData = data.team;
|
|
||||||
team = await team.save();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (user) {
|
if (user) {
|
||||||
@ -143,7 +122,6 @@ router.post('auth.slack', async ctx => {
|
|||||||
} else {
|
} else {
|
||||||
user = await User.create({
|
user = await User.create({
|
||||||
slackId: data.user.id,
|
slackId: data.user.id,
|
||||||
username: data.user.name,
|
|
||||||
name: data.user.name,
|
name: data.user.name,
|
||||||
email: data.user.email,
|
email: data.user.email,
|
||||||
teamId: team.id,
|
teamId: team.id,
|
||||||
@ -169,24 +147,7 @@ router.post('auth.slackCommands', async ctx => {
|
|||||||
const { code } = ctx.body;
|
const { code } = ctx.body;
|
||||||
ctx.assertPresent(code, 'code is required');
|
ctx.assertPresent(code, 'code is required');
|
||||||
|
|
||||||
const body = {
|
await Slack.oauthAccess(code, `${process.env.URL || ''}/auth/slack/commands`);
|
||||||
client_id: process.env.SLACK_KEY,
|
|
||||||
client_secret: process.env.SLACK_SECRET,
|
|
||||||
redirect_uri: `${process.env.URL || ''}/auth/slack/commands`,
|
|
||||||
code,
|
|
||||||
};
|
|
||||||
|
|
||||||
let data;
|
|
||||||
try {
|
|
||||||
const response = await fetch(
|
|
||||||
`https://slack.com/api/oauth.access?${querystring.stringify(body)}`
|
|
||||||
);
|
|
||||||
data = await response.json();
|
|
||||||
} catch (e) {
|
|
||||||
throw httpErrors.BadRequest();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data.ok) throw httpErrors.BadRequest(data.error);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
export default router;
|
export default router;
|
||||||
|
34
server/slack.js
Normal file
34
server/slack.js
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
// @flow
|
||||||
|
import fetch from 'isomorphic-fetch';
|
||||||
|
import querystring from 'querystring';
|
||||||
|
import { httpErrors } from './errors';
|
||||||
|
|
||||||
|
const SLACK_API_URL = 'https://slack.com/api';
|
||||||
|
|
||||||
|
export async function request(endpoint: string, body: Object) {
|
||||||
|
let data;
|
||||||
|
try {
|
||||||
|
const response = await fetch(
|
||||||
|
`${SLACK_API_URL}/${endpoint}?${querystring.stringify(body)}`
|
||||||
|
);
|
||||||
|
data = await response.json();
|
||||||
|
} catch (e) {
|
||||||
|
throw httpErrors.BadRequest();
|
||||||
|
}
|
||||||
|
console.log('DATA', data);
|
||||||
|
if (!data.ok) throw httpErrors.BadRequest(data.error);
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function oauthAccess(
|
||||||
|
code: string,
|
||||||
|
redirect_uri: string = `${process.env.URL || ''}/auth/slack`
|
||||||
|
) {
|
||||||
|
return request('oauth.access', {
|
||||||
|
client_id: process.env.SLACK_KEY,
|
||||||
|
client_secret: process.env.SLACK_SECRET,
|
||||||
|
redirect_uri: `${process.env.URL || ''}/auth/slack`,
|
||||||
|
code,
|
||||||
|
});
|
||||||
|
}
|
Reference in New Issue
Block a user