2016-03-10 03:33:31 +08:00
|
|
|
# This file is in coffeescript just to use the existential operator!
|
|
|
|
{AccountStore, EdgehillAPI} = require 'nylas-exports'
|
|
|
|
|
2016-03-12 05:27:04 +08:00
|
|
|
MAX_RETRY = 10
|
|
|
|
|
2016-03-10 03:33:31 +08:00
|
|
|
module.exports = class ClearbitDataSource
|
|
|
|
clearbitAPI: ->
|
|
|
|
return "https://person.clearbit.com/v2/combined"
|
|
|
|
|
2016-03-12 05:27:04 +08:00
|
|
|
find: ({email, tryCount}) ->
|
|
|
|
if (tryCount ? 0) >= MAX_RETRY
|
|
|
|
return Promise.resolve(null)
|
2016-03-10 10:11:53 +08:00
|
|
|
tok = AccountStore.tokenForAccountId(AccountStore.accounts()[0].id)
|
2016-03-10 03:33:31 +08:00
|
|
|
new Promise (resolve, reject) =>
|
2016-05-28 05:05:27 +08:00
|
|
|
EdgehillAPI.makeRequest
|
2016-03-11 03:06:33 +08:00
|
|
|
auth:
|
|
|
|
user: tok
|
|
|
|
pass: ""
|
|
|
|
path: "/proxy/clearbit/#{@clearbitAPI()}/find?email=#{email}",
|
2016-03-11 07:16:32 +08:00
|
|
|
success: (body, response) =>
|
2016-03-12 05:27:04 +08:00
|
|
|
@parseResponse(body, response, email, tryCount).then(resolve).catch(reject)
|
2016-03-10 03:33:31 +08:00
|
|
|
error: reject
|
|
|
|
|
|
|
|
# The clearbit -> Nylas adapater
|
2016-03-12 05:27:04 +08:00
|
|
|
parseResponse: (body={}, response, requestedEmail, tryCount=0) =>
|
|
|
|
new Promise (resolve, reject) =>
|
|
|
|
# This means it's in the process of fetching. Return null so we don't
|
|
|
|
# cache and try again.
|
|
|
|
if response.statusCode is 202
|
|
|
|
setTimeout =>
|
|
|
|
@find({email: requestedEmail, tryCount: tryCount+1}).then(resolve).catch(reject)
|
|
|
|
, 1000
|
|
|
|
return
|
|
|
|
else if response.statusCode isnt 200
|
|
|
|
resolve(null)
|
|
|
|
return
|
|
|
|
|
|
|
|
person = body.person
|
|
|
|
|
|
|
|
# This means there was no data about the person available. Return a
|
|
|
|
# valid, but empty object for us to cache. This can happen when we
|
|
|
|
# have company data, but no personal data.
|
|
|
|
if not person
|
|
|
|
person = {email: requestedEmail}
|
|
|
|
|
|
|
|
resolve({
|
|
|
|
cacheDate: Date.now()
|
|
|
|
email: requestedEmail # Used as checksum
|
|
|
|
bio: person.bio ? person.twitter?.bio ? person.aboutme?.bio,
|
|
|
|
location: person.location ? person.geo?.city
|
|
|
|
currentTitle: person.employment?.title,
|
|
|
|
currentEmployer: person.employment?.name,
|
|
|
|
profilePhotoUrl: person.avatar,
|
|
|
|
socialProfiles: @_socialProfiles(person)
|
|
|
|
})
|
2016-03-10 03:33:31 +08:00
|
|
|
|
|
|
|
_socialProfiles: (person={}) ->
|
|
|
|
profiles = {}
|
2016-03-11 07:32:22 +08:00
|
|
|
if (person.twitter?.handle ? "").length > 0
|
2016-03-10 03:33:31 +08:00
|
|
|
profiles.twitter =
|
|
|
|
handle: person.twitter.handle
|
|
|
|
url: "https://twitter.com/#{person.twitter.handle}"
|
2016-03-11 07:32:22 +08:00
|
|
|
if (person.facebook?.handle ? "").length > 0
|
2016-03-10 03:33:31 +08:00
|
|
|
profiles.facebook =
|
|
|
|
handle: person.facebook.handle
|
|
|
|
url: "https://facebook.com/#{person.facebook.handle}"
|
2016-03-11 07:32:22 +08:00
|
|
|
if (person.linkedin?.handle ? "").length > 0
|
2016-03-10 03:33:31 +08:00
|
|
|
profiles.linkedin =
|
|
|
|
handle: person.linkedin.handle
|
|
|
|
url: "https://linkedin.com/#{person.linkedin.handle}"
|
|
|
|
|
|
|
|
return profiles
|