Skip to content

Building a real-time twitter graph of your friends

Notifications You must be signed in to change notification settings

bmpi-dev/twitter-graph

 
 

Repository files navigation

Requirements

  1. .NET Core 6.0
  2. Node.js LTS
  3. Postgres

Setting up

1. Setup the postgres database:

CREATE DATABASE furland;
CREATE USER furland WITH PASSWORD 'abc123';
ALTER DATABASE furland OWNER TO furland;
GRANT ALL PRIVILEGES ON DATABASE furland TO furland;

2. Setup node.js:

  1. Go inside the ClientApp directory
  2. Run npm install

3. Twitter App

  1. Go to Twitter Developer site
  2. Set the Redirect URI as "https://localhost:44417/validate/twitter"
  3. Save the "API key" and "API secret key"

Building Instructions

  1. Modify appsettings.json with the Twitter configuration and the database connection string.
  2. Use Visual Studio, or use dotnet run.

Note: Twitter only provides 15 API calls per 15 minutes per user authenticated on the website. If you are by yourself and your account has 500 friends, it would take 500 minutes (8 hours) to gather the follower of all your friends. It may be recommended to have your friends log-in into the website a well.

Releasing

#build 
dotnet publish -c Release
# copy files to server
scp -r * ely:~/furland
# run server
dotnet ./FurlandGraph.dll --urls http://0.0.0.0:80

Architecture

  1. User logs in with Twitter account on TwitterController.cs
  2. User requests for status update on GraphController.cs, which goes into StatusService.cs
  3. The status update checks what work items need to be created for the graph next
    1. Stage 1: Download the user's profile + friends
    2. Stage 2: Download the user's friends's profiles
    3. Stage 3: Download the user's friends's friends
    4. Stage 4: Calculate the proximity matrix
  4. The user profiles and user friend data is processed by the HarvestService.cs
  5. The matrix is calculated on MatrixService.cs
  6. User downloads the matrix into the browser

About

Building a real-time twitter graph of your friends

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 48.0%
  • TypeScript 38.5%
  • JavaScript 9.5%
  • HTML 3.1%
  • Other 0.9%