CodingIsOurPassion Group
This is the mono repository for our group at University of Texas at San Antonio in the Applications Programming course (CS-3443).
Our group consists of the following members:
We chose to build an application named LakeWatch
for our project. The intent is for it to present data about Canyon
Lake in an Android application applying principles learned in our
Application Programming course.
Organization of this Repository
LakeWatchAPI
contains the backend service behind our Android applicationLakeWatch
contains the main Android application for our projectLakeWatchScraper
contains the scraper service that goes out to various sites and actually pulls the data we need for the API.Meetings
contains our meeting notes
How to run the Android application
As a note the Android Application requires *internet access as it is calling out to our self-hosted API we wrote for this project.
Open the LakeWatch
directory as a android application and run it on a Pixel Pro 6 API 28.
We are hosting the API and scraper on Price Hiller's server @ https://lakewatch.orion-technologies.io.
How the API and Scraper are Hosted
The LakeWatchScraper
and LakeWatchAPI
projects provie a flake.nix
file in their top levels which define
reproducible builds and configuration options for deployment on NixOS.
Both are hosted on my (Price's) Luna server over @ https://github.com/PriceHiller/dots/blob/Development/hosts/luna/modules/services/lakewatch.nix.
I (Price Hiller) will keep the API online on my server until the start of the next semester on the 26th (or longer if contacted).
Known Issues
-
If the initial data fetch within the Android application fails and there wasn't a cache file populated yet the given views will be empty. This is out of our control at that point. If a single successful data fetch occurs the cache does get populated and this is a lesser problem.
-
Android requires SSL secured endpoints for webrequests, this makes local development against the API without certificates quite difficult. Our development process included rolling the production API on a real endpoint while developing. Some improvement could be found here.
Self hosting the API and Scraper for yourself
Initialization
The preferred way of doing all of this is with https://nixos.org/, but if that's too experimental
a simple docker-compose.yml
and .envrc
are provided at the top level of the repository.
Simply source the .envrc
file and run docker compose up -d
to get started.
Running the API
The first thing you'll want to do is head over to the LakeWatchScraper
. You'll need a relatively recent version of the
rustc
toolchain, (Rust >=v1.78). Ensure the environment variables defined in the .envrc
are exported in your
environment, then you can run the API through two ways:
- Build the application via
cargo build --release
and run the created binary atLakeWatchAPI/target/release/lakewatch
Or, alternatively:
- Simply run the application in debug mode via
cargo run
A quick aside, if there are any issues with the table creations in the database you can install the sqlx
CLI via cargo install sqlx
and run sqlx databse reset --force
to refresh the API's database. Do note that this is a destructive
procedure.
Running the scraper (AKA, actually getting data loaded into the database)
Now head on over to the LakeWatchScraper
directory and ensure you have the following installed:
python 3.12
or later from any source or directly from https://www.python.org/- The
poetry
CLI for managing packages. It can be installed viapipx install poetry
. gcc
which is required for our Postgresql adapter to talk to the database
With those required tools installed (which, by the way, nix solves this problem entirely 😉) run poetry install && poetry shell
within the LakeWatchScraper
directory.
At this point ensure the database brought up via Docker earlier is still good and that the environment variables from
the .envrc
are still exported in your environment.
At this stage you can run python lakewatchscraper
when at the top level of the LakeWatchScraper
directory which will
start the scraper and push data into the database.
Checking out the API's swag(ger)
With the data now populated on the API, you can peruse it's endpoints on its swagger page by default hosted at localhost:8000.
Get In Contact
If you have any additional questions or are interested (especially in Nix), feel free to contact us.
- Price Hiller can be reached at price@orion-technologies.io
- Gavin Diab can be reached at gavin.diab97@gmail.com
- Salman Abid can be reached at salman54d@gmail.com
- Ethan Grams can be reached at ethangrams1997@gmail.com
Thanks for taking a look at our project 🙂