is-twitter

1.0.0 • Public • Published

is-twitter

NPM Version Build Status node Dependency Status JavaScript Style Guide

Verify that a request is from Twitter crawlers using Twitter's DNS verification steps

You may wish to verify that a web crawler accessing your server is Twitter and not spammers or other bots scraping your site while claiming to be Twitterbot. Since you cannot rely on the User-Agent header which is easily spoofed, you need to use DNS look up to verify that the IP address belongs to Twitter. Twitter is usually scanning URLs to detect metadata.

Install

npm install --save is-twitter

Example

const isTwitter = require('is-twitter')

let ip = '199.59.150.182'
isTwitter(ip).then((outcome) => {
  if (outcome) {
    // it's twitter.
  }
}).catch(console.error)

Example with express

app.enable('trust proxy')

app.use((req, res, next) => {
  let ip = req.ip || req.connection.remoteAddress
  isTwitter(ip).then(outcome => {
    if (outcome) {
      res.status(404).text('Nothing to scan') // block twitter crawler
    } else {
      next() // it's a user
    }
  })
})

Tests

npm test

License

MIT

Author

Rocco Musolino @roccomuso

Package Sidebar

Install

npm i is-twitter

Weekly Downloads

0

Version

1.0.0

License

MIT

Unpacked Size

4.71 kB

Total Files

6

Last publish

Collaborators

  • roccomuso