mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-01-20 19:29:55 -05:00
62 lines
2.9 KiB
CoffeeScript
62 lines
2.9 KiB
CoffeeScript
log = require 'winston'
|
|
errors = require '../commons/errors'
|
|
mongoose = require 'mongoose'
|
|
config = require('../../server_config')
|
|
request = require 'request'
|
|
User = require '../models/User'
|
|
|
|
module.exports.setup = (app) ->
|
|
app.get '/github/auth_callback', (req, res) ->
|
|
return errors.forbidden res unless req.user # need identity
|
|
response =
|
|
code: req.query.code
|
|
client_id: config.github.client_id
|
|
client_secret: config.github.client_secret
|
|
headers =
|
|
Accept: 'application/json'
|
|
request.post {uri: 'https://github.com/login/oauth/access_token', json: response, headers: headers}, (err, r, response) ->
|
|
log.error err if err?
|
|
if response.error or err? # If anything goes wrong just 404
|
|
res.send 404, response.error_description or err
|
|
else
|
|
{access_token, token_type, scope} = response
|
|
headers =
|
|
Accept: 'application/json'
|
|
Authorization: "token #{access_token}"
|
|
'User-Agent': if config.isProduction then 'CodeCombat' else 'CodeCombatDev'
|
|
request.get {uri: 'https://api.github.com/user', headers: headers}, (err, r, response) ->
|
|
return log.error err if err?
|
|
githubUser = JSON.parse response
|
|
log.info 'Got GitHub auth callback response', githubUser
|
|
|
|
request.get {uri: 'https://api.github.com/user/emails', headers: headers}, (err, r, response) ->
|
|
return log.error err if err?
|
|
githubUserEmails = JSON.parse response
|
|
log.info 'Got GitHub user emails', githubUserEmails
|
|
|
|
emailLower = _.find githubUserEmails, (email) -> email.primary is true
|
|
emailLower = emailLower.email.toLowerCase()
|
|
log.info 'Got primary Github email', emailLower
|
|
|
|
if not emailLower
|
|
return errors.serverError res, "Problem finding GitHub user with that identity."
|
|
|
|
# GitHub users can change emails
|
|
User.findOne {$or: [{emailLower: emailLower}, {githubID: githubUser.id}]}, (err, user) ->
|
|
return errors.serverError res, err if err?
|
|
wrapup = (err, user) ->
|
|
return errors.serverError res, err if err?
|
|
req.login (user), (err) ->
|
|
return errors.serverError res, err if err?
|
|
res.redirect '/'
|
|
unless user
|
|
req.user.set 'email', emailLower
|
|
req.user.set 'githubID', githubUser.id
|
|
req.user.save wrapup
|
|
else if user.get('githubID') isnt githubUser.id # Add or replace githubID to/with existing user
|
|
user.set 'githubID', githubUser.id
|
|
user.save wrapup
|
|
else if user.get('emailLower') isnt emailLower # Existing GitHub user with us changed email
|
|
user.update {email: emailLower}, (err) -> wrapup err, user
|
|
else # All good you've been here before
|
|
wrapup null, user
|