Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 4d2ee85cbe | |||
| d6364fc975 | |||
| 7ff39ea252 | |||
| b61de80e8a | |||
| c53f6a3f77 | |||
| 7fe92790d7 | |||
| 3b9d5bc984 | |||
| a73f171102 |
91
.github/workflows/build.yml
vendored
91
.github/workflows/build.yml
vendored
@@ -3,7 +3,7 @@ name: Build and Deploy
|
|||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master # Change to your default branch if different
|
- master
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
inputs:
|
inputs:
|
||||||
environment:
|
environment:
|
||||||
@@ -28,7 +28,7 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: self-hosted # Ensure your self-hosted runner is configured
|
runs-on: self-hosted
|
||||||
environment: ${{ github.event.inputs.environment || 'prod' }}
|
environment: ${{ github.event.inputs.environment || 'prod' }}
|
||||||
steps:
|
steps:
|
||||||
- name: Get Current User
|
- name: Get Current User
|
||||||
@@ -43,7 +43,7 @@ jobs:
|
|||||||
- name: Set up .NET
|
- name: Set up .NET
|
||||||
uses: actions/setup-dotnet@v2
|
uses: actions/setup-dotnet@v2
|
||||||
with:
|
with:
|
||||||
dotnet-version: '9.0' # Change to your required .NET version
|
dotnet-version: '9.0'
|
||||||
|
|
||||||
- name: Restore .NET Dependencies
|
- name: Restore .NET Dependencies
|
||||||
run: dotnet restore ./HomeApi.sln
|
run: dotnet restore ./HomeApi.sln
|
||||||
@@ -74,6 +74,24 @@ jobs:
|
|||||||
} else {
|
} else {
|
||||||
Write-Host "ChromeHeadlessShell not found in published output"
|
Write-Host "ChromeHeadlessShell not found in published output"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Check wwwroot and manually copy if missing
|
||||||
|
- name: Ensure wwwroot is Included
|
||||||
|
run: |
|
||||||
|
if (-not (Test-Path -Path "./output/dotnet/wwwroot")) {
|
||||||
|
Write-Host "wwwroot folder not found in published output, manually copying..."
|
||||||
|
|
||||||
|
# Check if wwwroot exists in project directory
|
||||||
|
$sourceWwwroot = "./HomeApi/wwwroot"
|
||||||
|
|
||||||
|
if (Test-Path -Path $sourceWwwroot) {
|
||||||
|
Write-Host "Found wwwroot directory in source, copying..."
|
||||||
|
New-Item -ItemType Directory -Path "./output/dotnet/wwwroot" -Force
|
||||||
|
Copy-Item -Path "$sourceWwwroot/*" -Destination "./output/dotnet/wwwroot" -Recurse -Force
|
||||||
|
} else {
|
||||||
|
Write-Host "WARNING: Could not find wwwroot in source directory!"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
- name: Generate SemVer version
|
- name: Generate SemVer version
|
||||||
if: ${{ github.event.inputs.create_release != 'false' }}
|
if: ${{ github.event.inputs.create_release != 'false' }}
|
||||||
@@ -81,13 +99,12 @@ jobs:
|
|||||||
uses: ietf-tools/semver-action@v1
|
uses: ietf-tools/semver-action@v1
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
branch: master # ← change to "main" if that's your default
|
branch: master
|
||||||
patchAll: true
|
patchAll: true
|
||||||
# fallbackTag: v0.0.1 # ← optionally bootstrap from an existing tag
|
|
||||||
|
|
||||||
- name: Create GitHub Release
|
- name: Create GitHub Release
|
||||||
if: ${{ github.event.inputs.create_release != 'false' }}
|
if: ${{ github.event.inputs.create_release != 'false' }}
|
||||||
id: create_release # ← this is required
|
id: create_release
|
||||||
uses: actions/create-release@v1
|
uses: actions/create-release@v1
|
||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
@@ -96,6 +113,46 @@ jobs:
|
|||||||
release_name: Release ${{ steps.semver.outputs.next }}
|
release_name: Release ${{ steps.semver.outputs.next }}
|
||||||
draft: false
|
draft: false
|
||||||
prerelease: false
|
prerelease: false
|
||||||
|
|
||||||
|
- name: Create placeholder appsettings for release
|
||||||
|
if: ${{ github.event.inputs.create_release != 'false' }}
|
||||||
|
run: |
|
||||||
|
$appSettings = @{
|
||||||
|
Logging = @{
|
||||||
|
LogLevel = @{
|
||||||
|
Default = "Information"
|
||||||
|
"Microsoft.AspNetCore" = "Warning"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ApiConfiguration = @{
|
||||||
|
EspConfiguration = @{
|
||||||
|
InformationBoardImageUrl = "http://server_ip:port/home/default.jpg"
|
||||||
|
UpdateIntervalMinutes = [int]"${{ vars.ESP_UPDATE_INTERVAL }}"
|
||||||
|
BlackTextThreshold = [int]"${{ vars.ESP_BLACK_TEXT_THRESHOLD }}"
|
||||||
|
EnableDithering = [System.Convert]::ToBoolean("${{ vars.ESP_ENABLE_DITHERING }}")
|
||||||
|
DitheringStrength = [int]"${{ vars.ESP_DITHERING_STRENGTH }}"
|
||||||
|
EnhanceContrast = [System.Convert]::ToBoolean("${{ vars.ESP_ENHANCE_CONTRAST }}")
|
||||||
|
ContrastStrength = [int]"${{ vars.ESP_CONTRAST_STRENGTH }}"
|
||||||
|
IsHighContrastMode = [System.Convert]::ToBoolean("${{ vars.ESP_HIGH_CONTRAST_MODE }}")
|
||||||
|
}
|
||||||
|
Keys = @{
|
||||||
|
Weather = "SET THIS TO YOUR KEY"
|
||||||
|
ResRobot = "SET THIS TO YOUR KEY"
|
||||||
|
}
|
||||||
|
BaseUrls = @{
|
||||||
|
Nominatim = "${{ vars.NOMINATIM_URL }}"
|
||||||
|
Aurora = "${{ vars.AURORA_URL }}"
|
||||||
|
Weather = "${{ vars.WEATHER_URL }}"
|
||||||
|
ResRobot = "${{ vars.RES_ROBOT_URL }}"
|
||||||
|
}
|
||||||
|
DefaultCity = "CITY ADDRESS"
|
||||||
|
DefaultStation = "YOUR STATION"
|
||||||
|
}
|
||||||
|
AllowedHosts = "*"
|
||||||
|
}
|
||||||
|
|
||||||
|
$appSettings | ConvertTo-Json -Depth 10 | Set-Content -Path "./output/dotnet/appsettings.json"
|
||||||
|
Write-Host "Created placeholder appsettings.json successfully"
|
||||||
|
|
||||||
- name: Zip the build for github release
|
- name: Zip the build for github release
|
||||||
if: ${{ github.event.inputs.create_release != 'false' }}
|
if: ${{ github.event.inputs.create_release != 'false' }}
|
||||||
@@ -107,7 +164,7 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
with:
|
with:
|
||||||
upload_url: ${{ steps.create_release.outputs.upload_url }} # ← now available
|
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
||||||
asset_path: ./output/HomeScreen_Build_${{ steps.semver.outputs.next }}.zip
|
asset_path: ./output/HomeScreen_Build_${{ steps.semver.outputs.next }}.zip
|
||||||
asset_name: HomeScreen_Build_${{ steps.semver.outputs.next }}.zip
|
asset_name: HomeScreen_Build_${{ steps.semver.outputs.next }}.zip
|
||||||
asset_content_type: application/zip
|
asset_content_type: application/zip
|
||||||
@@ -151,24 +208,6 @@ jobs:
|
|||||||
$appSettings | ConvertTo-Json -Depth 10 | Set-Content -Path "./output/dotnet/appsettings.json"
|
$appSettings | ConvertTo-Json -Depth 10 | Set-Content -Path "./output/dotnet/appsettings.json"
|
||||||
Write-Host "Generated appsettings.json successfully"
|
Write-Host "Generated appsettings.json successfully"
|
||||||
|
|
||||||
# Check wwwroot and manually copy if missing
|
|
||||||
- name: Ensure wwwroot is Included
|
|
||||||
run: |
|
|
||||||
if (-not (Test-Path -Path "./output/dotnet/wwwroot")) {
|
|
||||||
Write-Host "wwwroot folder not found in published output, manually copying..."
|
|
||||||
|
|
||||||
# Check if wwwroot exists in project directory
|
|
||||||
$sourceWwwroot = "./HomeApi/wwwroot"
|
|
||||||
|
|
||||||
if (Test-Path -Path $sourceWwwroot) {
|
|
||||||
Write-Host "Found wwwroot directory in source, copying..."
|
|
||||||
New-Item -ItemType Directory -Path "./output/dotnet/wwwroot" -Force
|
|
||||||
Copy-Item -Path "$sourceWwwroot/*" -Destination "./output/dotnet/wwwroot" -Recurse -Force
|
|
||||||
} else {
|
|
||||||
Write-Host "WARNING: Could not find wwwroot in source directory!"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- name: Upload Artifacts
|
- name: Upload Artifacts
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
with:
|
with:
|
||||||
@@ -176,7 +215,7 @@ jobs:
|
|||||||
path: ./output/dotnet
|
path: ./output/dotnet
|
||||||
|
|
||||||
deploy:
|
deploy:
|
||||||
runs-on: self-hosted # Ensure your self-hosted runner is configured
|
runs-on: self-hosted
|
||||||
needs: build
|
needs: build
|
||||||
environment: ${{ github.event.inputs.environment || 'prod' }}
|
environment: ${{ github.event.inputs.environment || 'prod' }}
|
||||||
|
|
||||||
|
|||||||
34
README.md
34
README.md
@@ -1,15 +1,29 @@
|
|||||||
[](https://github.com/myxelium/homescreen "Go to GitHub repo")
|
[](https://github.com/myxelium/Wireless_Eink_HomeScreen "Go to GitHub repo")
|
||||||
[](https://github.com/myxelium/homescreen)
|
[](https://github.com/myxelium/Wireless_Eink_HomeScreen)
|
||||||
[](https://github.com/myxelium/homescreen)
|
[](https://github.com/myxelium/Wireless_Eink_HomeScreen)
|
||||||
[](https://github.com/myxelium/homescreen/releases/)
|
[](https://github.com/myxelium/Wireless_Eink_HomeScreen/releases/)
|
||||||
[](https://www.gnu.org/licenses/gpl-3.0.en.html)
|
[](https://www.gnu.org/licenses/gpl-3.0.en.html)
|
||||||
[](https://github.com/myxelium/homescreen/issues)
|
[](https://github.com/myxelium/Wireless_Eink_HomeScreen/issues)
|
||||||
[](https://github.com/Myxelium/HomeScreen/actions/workflows/build.yml)
|
[](https://github.com/Myxelium/Wireless_Eink_HomeScreen/actions/workflows/build.yml)
|
||||||
# This
|
# What why how
|
||||||
Core api and [Esp32 (Microcontroller)](https://en.wikipedia.org/wiki/ESP32) code for displaying weather data and public transport information on a e-ink display.
|
This is a project I created that pulls weather data from the internet, transforms it into custom images, and displays them on an e-ink screen powered by an ESP32.
|
||||||
|
|
||||||
|
## What This Project Does
|
||||||
|
|
||||||
|
I wanted a low-power way to see weather information at a glance, so I built this system that:
|
||||||
|
|
||||||
|
- Fetches real-time weather data from online APIs
|
||||||
|
- Processes and converts the data into visual images (temperature graphs, forecast icons, etc.)
|
||||||
|
- Sends these images wirelessly to an ESP32 microcontroller
|
||||||
|
- Displays the information on an energy-efficient e-ink screen
|
||||||
|
- Updates periodically while consuming minimal power
|
||||||
|
|
||||||
<img width="800" height="480" alt="image" src="https://github.com/user-attachments/assets/ef5af0c6-ea3a-494d-b2af-3de6e70b3e6a" />
|
<img width="800" height="480" alt="image" src="https://github.com/user-attachments/assets/ef5af0c6-ea3a-494d-b2af-3de6e70b3e6a" />
|
||||||
|
|
||||||
|
# How do I get to use this without programming knowledge?
|
||||||
|
Check in the wiki for the guide how to get everything working!
|
||||||
|
### 😺 [Wiki Get Started Guide](https://github.com/Myxelium/Wireless_Eink_HomeScreen/wiki/Guide:-Landing-page)
|
||||||
|
|
||||||
## Git Notes
|
## Git Notes
|
||||||
All commits has to follow this [Conventional Commits style](https://www.conventionalcommits.org/) to pass the pipeline.
|
All commits has to follow this [Conventional Commits style](https://www.conventionalcommits.org/) to pass the pipeline.
|
||||||
## Features 😺
|
## Features 😺
|
||||||
@@ -120,7 +134,7 @@ end
|
|||||||
# ESP32 configuration and building
|
# ESP32 configuration and building
|
||||||
<img width="4096" height="1842" alt="image" src="https://github.com/user-attachments/assets/5acf1b3b-f9bb-48bd-b310-a2852544eaba" />
|
<img width="4096" height="1842" alt="image" src="https://github.com/user-attachments/assets/5acf1b3b-f9bb-48bd-b310-a2852544eaba" />
|
||||||
|
|
||||||
Best way of getting the ESP32 ready for code upload is to follow this guide [https://web.archive.org/web/20250706150325/https://www.waveshare.com/wiki/E-Paper_ESP32_Driver_Board] (WAVESHARE ESP32 GUIDE).
|
Best way of getting the ESP32 ready for code upload is to follow this guide [WAVESHARE ESP32 GUIDE](https://web.archive.org/web/20250706150325/https://www.waveshare.com/wiki/E-Paper_ESP32_Driver_Board).
|
||||||
Once you have it ready so you can upload code to it copy my code in: Esp32_Code/INFOSCREEN_WITH_INTERVAL from this repo.
|
Once you have it ready so you can upload code to it copy my code in: Esp32_Code/INFOSCREEN_WITH_INTERVAL from this repo.
|
||||||
|
|
||||||
Install following libraries (if more is needed search for them and install them too):
|
Install following libraries (if more is needed search for them and install them too):
|
||||||
@@ -128,4 +142,4 @@ Install following libraries (if more is needed search for them and install them
|
|||||||
* GUI_Paint
|
* GUI_Paint
|
||||||
* JPEGDEC
|
* JPEGDEC
|
||||||
|
|
||||||
You need the Waveshare examples installed since it uses code from them. See above link to find the download.
|
You need the Waveshare examples installed since it uses code from them download them here [Download](https://files.waveshare.com/upload/5/50/E-Paper_ESP32_Driver_Board_Code.7z) or check above link.
|
||||||
|
|||||||
Reference in New Issue
Block a user