docs/TECHNICAL.md
GitHub releases contain default API keys of the project that make all weather sources work by default (until API limits are reached).
If you want to self-build, you can add your own API keys in local.properties for sources to be configured by default in the build:
breezy.accu.portal=developer
breezy.accu.key=myapikey
breezy.accu.days=15
breezy.accu.hours=120
breezy.atmoaura.key=myapikey
breezy.atmofrance.key=myapikey
breezy.atmograndest.key=myapikey
breezy.atmohdf.key=myapikey
breezy.atmosud.key=myapikey
breezy.baiduip.key=myapikey
breezy.eccc.key=myapikey
breezy.geonames.key=myapikey
breezy.here.key=myapikey
breezy.mf.jwtKey=myapikey
breezy.mf.key=myapikey
breezy.openweather.key=myapikey
breezy.pirateweather.key=myapikey
You can omit any of the following properties to let the user configure their own API key in the settings, or only use API-key-less sources (such as Open-Meteo).
By default, the app is compiled unbranded and you will have to complete a few properties located in gradle.properties.
If you have no plans to distribute releases and you only build the app for yourself ONLY, you can just pass the parameter breezy to the command line. Example:
./gradlew assembleBasicDebug -Pbreezy
In Android Studio, this can be set up in the configuration of the app module, in the Before launch section, remove existing and add a Gradle task: choose app module, add assembleBasicDebug or assembleFreenetDebug as command, and -Pbreezy as Arguments.
Instructions for members of the organization.
./gradlew testBasicDebugUnitTest and ./gradlew testDebugUnitTest../gradlew assembleBasicRelease -Pbreezy. /!\ Only the Breezy Weather organization can distribute releases with the breezy parameter. Forks must not include this parameter when building, and use their own branding.app/build.gradle.CHANGELOG.md.v (example: git tag v6.1.4 -m "Version 6.1.4").git push --tags.github/ to show the new latest version.If anything goes bad (such as reproducibility issue), you can remove the tag using git push origin :v6.x.y && git tag --delete v6.x.y and trigger a new build.
APKs are generated by a GitHub action from the public source code, guaranteeing they are always generated in the same conditions.
As of 2025-11-11, the environment used is Ubuntu 24.04 (x64), with 4 CPU cores and 16 GB RAM.
If you have more than 4 CPU cores, you may need to run the following to ensure the CPU cores match with the GitHub runner, or you may end up with differences in the baseline.prof file:
export CPUS_MAX=16 # Replace with your number of CPU cores
export CPUS=4
for (( c=$CPUS; c<$CPUS_MAX; c++ )) ; do echo 0 > /sys/devices/system/cpu/cpu$c/online; done
After merging a new source, the following things need to be done:
CHANGELOG.mddocs/SOURCES.mddocs/COVERAGE.mdfastlane/metadata/android/{*}/full_description.txt (bulk replace in all languages)stacktrace.txt and remove things like 2023-08-14 21:28:58.229 12804-12804 View org.breezyweather.debug if they are present.mapping.txt.~/Android/Sdk/cmdline-tools/latest/bin/retrace mapping.txt stacktrace.txtWhen translations are updated from Weblate, if there are new contributors, add them in app/src/main/java/org/breezyweather/settings/activities/AboutActivity.kt.
When a translation is added, add the CLDR data for this locale in the weather-unit library.
Gradle must always be updated that way (replace with new version number):
./gradlew wrapper --gradle-version=9.5.0 --gradle-distribution-sha256-sum=553c78f50dafcd54d65b9a444649057857469edf836431389695608536d6b746
You can find the newer checksum of the binary-only (-bin) ZIP on https://gradle.org/release-checksums/
org.breezyweather.background.updater.AppUpdateChecker, uncomment the relevant lines to trigger a notification on the unsupported Android versionsorg.breezyweather.background.weather.WeatherUpdateJob, uncomment the relevant lines to always enable “check for update” on these unsupported Android versions, to ensure that freenet users and users who disabled update check correctly receive the notification. No actual update check will be performed, so it’s safe to force it enabled.You can find many Material Symbols and Icons here.
Weather sources API can change: some versions may become deprecated, new endpoints may be added, new countries may be supported (when documented, we filter countries in app to avoid unnecessary calls on unsupported countries).
This section keep track of endpoints and when they were last checked.
Last checked: 2024-04-16
| Endpoint | Version | Notes |
|---|---|---|
| Geocoding — Search | v1 | Partial support for Postal code, see open-meteo/geocoding-api#8, missing admin codes, see open-meteo/open-meteo#355 |
| Weather — Forecast | v1 | |
| Air quality | v1 |
Future additional endpoints/improvements for existing endpoints:
Last checked: 2024-04-16
https://apidev.accuweather.com/developers/
| Endpoint | Version | Notes |
|---|---|---|
| Location — Translate | v1 | |
| Location — Geoposition | v1 | |
| Current conditions | v1 | |
| Daily | v1 | Up to 45 days, but useless |
| Hourly | v1 | Up to 240 hours |
| Minutely | v1 | 1 minute precision |
| Alerts by geoposition | v1 | |
| Alerts by location | v1 | |
| Air quality | v2 | Up to 96 hours. TODO: Observational endpoint for SK and CN |
| Climo | v1 |
Last checked: 2024-04-16
| Endpoint | Version | Notes |
|---|---|---|
| Location forecast | 2.0 | |
| Sunrise | 3.0 | It is technically feasible to retrieve data for future days, but requires two calls for each, so we avoid |
| Nowcast | 2.0 | Norway, Sweden, Finland and Denmark only |
| Air quality | 0.1 | Norway only |
Not yet implemented in app:
| Endpoint | Version | Notes |
|---|---|---|
| MET alerts | 1.1 | Norway only by country code, wait for v2.0 in May to get alerts by lat,lon |
No location search endpoint exists, it uses Open-Meteo instead.
Last checked: 2024-04-16
https://openweathermap.org/api
| Endpoint | Version |
|---|---|
| Current | 2.5 |
| 5 Day / 3 Hour Forecast | 2.5 |
| Air Pollution | 2.5 |
Last checked: 2025-10-30
https://github.com/Pirate-Weather/pirateweather
| Endpoint | Version | Notes |
|---|---|---|
| Forecast | v2.7.11 | V2.8 is in pre-release |
We should check regularly for additional fields we could use. Latest version checked is written above, everything more recent requires to check changelog.
Last checked: 2024-02-13
| Endpoint | Version |
|---|---|
| Forecast | v2 |
| Observation | v2 |
| Nowcast | v3 |
| Ephemeris | None |
| Warning | v3 |
Not used:
| Endpoint | Version | Notes |
|---|---|---|
| Places | V2 | Doesn’t have mandatory timezone field, miss many data on countries other than France |
Uses Open-Meteo for location search.
To be documented
Legacy source, undocumented
To be documented
To be documented
Last checked: 2024-04-16
| Endpoint | Version |
|---|---|
| Weather | v2.1 |
| Current weather | v2.1 |
| Alerts | v2.1 |
Last checked: 2024-01-26
| Endpoint | Version |
|---|---|
| Location | v2 |
To be documented
Last checked: 2024-01-26
| Endpoint | Version |
|---|---|
| Weather | 2 |
To be documented