Skip to content

Latest commit

 

History

History
50 lines (34 loc) · 2.49 KB

README.md

File metadata and controls

50 lines (34 loc) · 2.49 KB

TweetTrends

This is event-driven implementation of Tweet Trends using Sentimental Analysis.

Tools/Frameworks Used

  1. NodeJS(via Lambda) - for serverless nodeJS code

  2. Twitter API - fetch live public tweet streams

  3. Sentiment Analysis - IBM Watson NLU API

  4. AWS:

    1. Lambda - Serverless implementation
    2. API Gateway - Route API req/res to/from Lambda/Client
    3. SQS - Message queue to pipe tweets asynchronously
    4. SNS - Kinda pub/sub implementation between client & back-end to notify of fetched tweets
    5. S3 - Hosting static landing page to interact with back-end
    6. ElasticSearch - Store tweets with Sentiment analysis
    7. API Gateway - To deploy API into a REST endpoint, this way the client can make REST calls to lambda functions
  5. Apex - To deploy AWS lambda functions through command line

Architecture diagram

[Insert Image here with markdown!!]

Checklist (sanity purposes :-) )

  • 1st Lambda function to fetch tweets from Twitter-streaming API & filter out tweets with no location & check for language to be english
  • send those stream of tweets onto SQS, SNS. SNS triggers 2nd Lambda (sqsToSa)
  • 2nd Lambda function to fetch tweets from SQS, Sentiment analyse(text) & send to second SNS topic which triggers 3rd lambda
  • 3rd lambda function to fetch tweets from SNS & & index the tweet as document onto ElasticSearch
  • Client listens onto new tweets through Static website hosted on S3

Getting Started

  1. For every functions in functions folder run npm install which will download all the required packages from NPM
  2. Setup apex for command line changes to lambda & deploy them to AWS
  3. Learn to setup environment variables, add required rules to run lambdas
    • Setup all the infrastructure
      • SQS - one queue
      • SNS - two sns topics
      • ElasticSearch - to document tweets
      • S3 - create a front-end and deploy it onto S3 for hosting
  4. apex deploy to delpoy all lambda(s) to AWS Lambda
  5. Call first lambda via API Gateway, it should fetch tweets and store them onto ElasticSearch