Skip to content

Latest commit

 

History

History
97 lines (78 loc) · 4.85 KB

README.md

File metadata and controls

97 lines (78 loc) · 4.85 KB

EventOnAirClient

Event-on-air is a social media wall that is primarily meant to encourage/show social media engagement during events, especially used to hype the crowd when waiting for events/talks to start. Although there are providers who already does this, they usually costly and you cannot control the update frequency if you're on the free plan.

A demo is available here

Features

Automatically pull twitter/instagram feeds with your event hashtag

  • ✅ New feeds will always appear in front of the list
  • ✅ Moderate posts automatically/manually on monderator screen before showing
  • ✅ Ability to adjust number of lanes on the fly, depending on screen resolution.
  • ✅ Adjust header and subtitle in real time.
  • ✅ Ability to configure hashtag on the fly
  • ✅ Ability to configure how fast/slow new posts appear on screen
  • ✅ Ability to configure how many posts can be queued before showing.

Pre-requisites

  1. A Firebase project. Sign into Firebase using your Google account, and create a new project in the Firebase console here
  2. Have completed the setup for backend. If you have not done so, please follow the Serverless on Firebase Cloud Functions here

Setting up the client

  1. Clone this project
  2. Install dependencies via npm or yarn
  3. Go to the src/environments/environment.ts and update your firebase configuration and Facebook App Id. Be sure to update the environment.prod.ts as well
export const environment = {
  production: false,
  firebase: {
    apiKey: "api-key",
    authDomain: "project-id.firebaseapp.com",
    databaseURL: "https://project-id.firebaseio.com",
    projectId: "project-id",
    storageBucket: "project-id.appspot.com",
    messagingSenderId: "sender-id",
  },
  facebookAppId: "facebookAppId"
};

  1. Start the project locally via npm run start
  2. Navigate to http://localhost:4200/moderate
  3. Login with your Google Account as specified in the email you have entered in Firestore admin collection.
  4. If you have setup your admin user correctly in this guide, you should see the following screen: moderate screen
  5. If you have facebook logged in, please log out and log in again.
  6. Check Firestore to ensure the userAccessToken is automatically filled in like the screen below: fb config screen

Deploy the client

  1. Set Firebase project
firebase use project-id
  1. Build for production
npm run build
  1. Deploy to Firebase Hosting
firebase deploy

Run a test!

We will need to trigger a call to get twitter posts.

  1. Go to https://console.cloud.google.com/cloudpubsub/topicList?project=PROJECT_ID. Make sure to change PROJECT_ID with your Firebase project. If you have setup your backend correctly you should see the 2 topics appearing in page. gcp

  2. Click on pull-twitter-api topic. Click publish message. Enter any description you like and click publish.

  3. If it is succesful you should see a collection called tweets or posts in Firestore. Refresh the page a few times after triggering a call, or visit your Firebase deployed webpage to see firestore web app

  4. Repeat step 2 with pull-instagram-api you should see them appearing too.

One last step.

Now that we know the code is working well, we now need to setup cron job on Cloud Scheduler to fetch data every x minutes

  1. Go to Cloud Scheduler https://console.cloud.google.com/cloudscheduler
  2. Create a job with details like the picture below: !cron](https://res.cloudinary.com/shangyilim/image/upload/v1555254378/cron.png)
  3. The cron expression */2 * * * * runs every 2 minutes. Change according to how frequent you want your cloud functions to pul data from twitter/instagram.
  4. REMEMBER to delete the job after the event or when you no longer want to run it! Otherwise the job keep running and may incur unecessary costs.

Its not working?!?!

Here's a few things that may help you fix issues you might face

  1. Make sure Firebase Blaze plan is turned on.
  2. Make sure the Twitter API key and its secret is saved in the functions/config of this repo
  3. Make sure the fbConfig values are all present as shown in step 9.
  4. Make sure the searchConfig hastag really has public post with the hashtag you specified.
  5. Check the Cloud Functions Logs to see if there are any hints there.
  6. If all else fails feel free to create an issue