https://github.com/dgraph-io/flock
Twitter on Dgraph
https://github.com/dgraph-io/flock
Last synced: 4 months ago
JSON representation
Twitter on Dgraph
- Host: GitHub
- URL: https://github.com/dgraph-io/flock
- Owner: dgraph-io
- License: apache-2.0
- Archived: true
- Created: 2019-03-09T01:45:00.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2022-12-10T09:28:25.000Z (about 2 years ago)
- Last Synced: 2024-07-09T00:09:18.549Z (8 months ago)
- Language: Go
- Size: 4.48 MB
- Stars: 31
- Watchers: 24
- Forks: 6
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Flock
Flock loads real Twitter streams into Dgraph to make use of graph travesals.
**Use [Discuss Issues](https://discuss.dgraph.io/tags/c/issues/35/flock) for reporting issues about this repository.**
Flock has two parts,
- *Tweet loader* - Connects to [realtime Tweets][tweetsapi] via the Twitter Developer API and
loads a graph model of Twitter into Dgraph via mutations.
- *Query client* - Runs interesting graph queries on the Tweets data stored in Dgraph.Here is the graph schema of Flock:
data:image/s3,"s3://crabby-images/aac4a/aac4a86342fcd99edd9b06507fbfdde63fc3b8d7" alt="Schema"
[tweetsapi]: https://developer.twitter.com/en/docs/tweets/sample-realtime/overview/GET_statuses_sample
# Running Flock
## Obtaining Twitter credentials
We need to create a Twitter developer account and an app to be able to fetch stream of Tweets using
their APIs. Let's start with how to create a Twitter developer account.- Apply for a Twitter developer account [here](https://developer.twitter.com/en/apply/user) and
follow the instructions. The series of steps would end with your email verification.
- Create a Twitter app from [this link](https://developer.twitter.com/en/apps/create).
All fields are `not` required.
- You'll be redirected to the App details tab after creating the app. Go to the `Keys and tokens` tab
and create new access and secret tokens.
data:image/s3,"s3://crabby-images/04010/040100a9c1998f8c08aaad972d70d6f392e04cd4" alt="Twitter Developer account"
- Create a copy of the credentials template.
```sh
cp credentials-template.json credentials.json
```
- Open the `crendentials.json` file and replace the placeholders with the keys from the
Twitter app's `Keys and token` tab.---
## Setup- Clone the repository.
```sh
$ git clone https://github.com/dgraph-io/flock.git
$ cd flock
```- Export the persistent data directory. Since Dgraph is run using Docker containers, it is nice
to mount a directory on the host machine to persist the data across multiple runs.
```sh
$ mkdir ./data
$ export DATA_DIR=$(pwd)/data
```- If you're running Linux, you can add the current user to the `docker` group to use Docker as a non-root user.
`newgrp` creates a new terminal session. It is necessary after the user modification to see the effects.```sh
$ sudo usermod -aG docker $USER
$ newgrp docker
```- Start the Dgraph servers and Ratel with Docker Compose. Visit http://localhost:8000 on your
browser to view the UI.
```sh
$ docker-compose up
```## Running Flock
Currently, we have Flock implemention for Go and JavaScript.
Go to the specific Flock documentation for instructions:
- [Go](./go)
- [JavaScript](./js)---