- See all notices at one glance under a minimal beautiful interface.
- Once cached, notice titles can be read even if device is offline.
- Get notified via push notification when new notices are updated.
The app does not run in the background or consume any resources. The website changes are checked centrally through Google Cloud every 2 hours from 7am to 11pm. If new contents are found on the website, push notifications are delivered to all users.
graph LR
A[MainActivity] --> B[MainNoticeFragment] -- Home --> F[FetcherHome] --> H(jsoup) --> fetch(Homepage Data)
A[MainActivity] --> B -- All Notices --> G[FetcherAllNotice] --> I(jsoup) --> fetch2(Notices Page Data)
A --> B -- ...others --> M[...others]
graph LR
A[Cloud Scheduler] --> B[actions.py] --> C(sraper.py) --> fetch(Homepage Data) --> I(compare last saved data) --> J(messenger.py) --> K[send push notification]
M[bsoup API] --> C
N[cloud storage API] --> I
O[FCM API] --> K
First let's get the Android app compiled and running.
- Set up Android SDK and Android Studio as well.
- You need
google-services.json
file to link with your own firebase project. Follow the steps in Android Firebase Setup - This allows the app to register with Firebase push notifications.
The debug variant of build is slightly different from release variant. Apart from differentiation in name and package, debug variant subscribes to push notification topic test whereas release version subscribes to push notification topic release. This is intentionally done to prevent accidentally spamming normal users during testing.
Now that the app is running, we would like to have the backend working so that push notifications can start working.
- The code for cloud function is entirely under folder
nita_cloud_function
- Before we deploy the function, below pre-requisites need to be handled.
- Install Python on your system for local testing purposes.
- Install the Google Cloud SDK CLI to deploy the app later.
- Set up the Cloud Function on GCP for the same app that we used to create the Firebase Setup earlier.
- Make sure to enable Cloud Function, Cloud Run and Cloud Scheduler for the same project.
- Run
main_web.py
on your system. It will expose endpoints on localhost. - You need to put your own firebase-sdk private key json file for the app to be able to send push notifications to the project. Get your json file and put it in
secrets/something.json
. - If everything works, backend will update the files with new data. You can tinker with the existing data files to make it send push notification.
- Check the file
nita_cloud_function/set_project_properties.sh
and replace your project id. You can get the project id from GCP UI. - Deploy the app with command
sh deploy.sh
- Create the cloud scheduler job using command
sh schedule.sh
- You can trigger a cron job from Cloud Scheduler UI or wait till 2hrs, or whatever period of timing you've set.
- To maintain risks to minimum, default deployment does not expose endpoints publicly. You could tinker with the values in
deploy.sh
if you feel so.
Please note that some of the services might need you to enable billing. Please take care not to run into huge unwanted costs due to oversight. Google makes it quite difficult to track the usages for beginners. Please do your due diligence while using GCP. If you are running Cloud Functions version of the project, it can run on free tier as usage and resource consumption is minimum.
If you are using older and discontinued App Engine version of this project, there might be charges amounting to ₹5 to ₹10 while using Cloud Build during deploy. This is a bug with GCP App Engine mentioned here. I had also written a blog post on this
Please make sure you secure your endpoints and sensitive API keys so that they are not misused. Please follow the GCP security recommendations and do your due diligence while working with public cloud.
- Information on this app comes from the NIT Agartala Website.
- This app does not represent any government or political entity.
- The app is not affiliated to NIT Agartala.