Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
427 commits
Select commit Hold shift + click to select a range
0f6efac
clientonly and wayland, hotfix electron tests (#3677)
khassel Jan 3, 2025
8fdd865
electron tests: fixes for running under new github image ubuntu-24.04…
khassel Jan 5, 2025
5e337f8
fix #3267, CORRECTLY, add testcase, add testcase for #3279 (#3681)
sdetweil Jan 5, 2025
b1bc554
Update year (#3686)
KristjanESPERANTO Jan 6, 2025
553d2d4
electron tests (#3684)
khassel Jan 8, 2025
a7f814d
Optimize systeminformation calls and output string (#3689)
KristjanESPERANTO Jan 12, 2025
99dda82
Fix unknown (n/a) icon in openmeteo provider (#3691)
rejas Jan 13, 2025
2400e20
update dependencies and formatting (#3693)
khassel Jan 13, 2025
6e40c44
fix wrong port in log message when starting server only (#3697)
khassel Jan 14, 2025
77fe011
Use different issue templates (#3695)
KristjanESPERANTO Jan 17, 2025
53ac31d
Adapt `start:x11:dev` script (#3700)
KristjanESPERANTO Jan 19, 2025
af77b7b
fix #3701, calculation wrong, added testcase, ics, config (#3702)
sdetweil Jan 23, 2025
d6f2e71
Fix frozen Yr weather-module (#3706)
MagMar94 Jan 27, 2025
f34c8f2
update github workflows (#3709)
khassel Jan 31, 2025
e00a666
chore: update newsfeed.js (#3692)
eltociear Feb 1, 2025
aa20ead
Monthly update to dependencies (#3717)
rejas Feb 1, 2025
62c22d7
Arabic Translation (#3719)
Developer-Incoming Feb 6, 2025
28bcee7
Update ESLint and simplify config (#3724)
KristjanESPERANTO Feb 22, 2025
4a398f0
Fix empty part-of-day logic (#3726)
rejas Feb 27, 2025
66b8656
Fix icons, add hourly support, add other weatherflow changes (#3729)
n8many Mar 1, 2025
1fcc028
update dependencies incl. electron to v35 (#3733)
khassel Mar 5, 2025
2adf341
Add Esperanto translation (#3740)
KristjanESPERANTO Mar 13, 2025
0afc1ed
Updated Greek Translations (#3741)
mixasgr Mar 15, 2025
51d11bf
add support for digital clock time color (#3737)
sdetweil Mar 16, 2025
0cfe273
newsfeed: add specific ignoreOlderThan value (override) per feed (#3742)
khassel Mar 18, 2025
68ec696
Update ESLint and prettier (#3746)
KristjanESPERANTO Mar 18, 2025
46d64ab
update required node version and dependencies (#3747)
khassel Mar 21, 2025
791f771
fix stale job (#3751)
khassel Mar 22, 2025
2ddb785
Fix command to run spellcheck (#3753)
KristjanESPERANTO Mar 27, 2025
6d909d2
[weather] add humidity to hourly view, fix spacing error when using U…
OWL4C Mar 27, 2025
2e57d78
update dependencies (#3754)
khassel Mar 28, 2025
e546fed
updatenotification: add param to get modules from modules-dir instead…
khassel Mar 31, 2025
f80b1f1
Update deps before release (#3756)
rejas Apr 1, 2025
01fd41c
Prepare 2.31.0 release (#3757)
rejas Apr 1, 2025
a2c1daa
Merge branch 'mm_master' into mm_develop
Apr 1, 2025
7938c3a
Merge branch 'mm_master' into mm_develop
Apr 1, 2025
86934c8
Prepare v2.32.0-develop
Apr 1, 2025
e1a53ef
[refactor] Simplify module loading process (#3766)
KristjanESPERANTO Apr 23, 2025
ff66829
[feature] Introduce disableNextEvent to hide next sun event (#3769)
bughaver Apr 27, 2025
b9d63d7
Use "node --run" instead of "npm run" (#3764)
KristjanESPERANTO May 6, 2025
a5b85c4
[workflow] Use LTS node version and split "Run test" step (#3767)
KristjanESPERANTO May 7, 2025
7b4d363
[fix] Fix `start:dev` script (#3773)
KristjanESPERANTO May 7, 2025
2831ae9
[Feature Request] Allow to make an display order of module position i…
bugsounet May 8, 2025
53bff72
update dependencies (#3774)
khassel May 9, 2025
ed419ce
Bump pm2 from 5.4.3 to 6.0.5 (#3776)
dependabot[bot] May 9, 2025
2422e84
Fix calendar rrule until where event is fullday but rrule until has a…
sdetweil May 12, 2025
965e935
[linter] Review linter setup (#3783)
KristjanESPERANTO May 12, 2025
554bb0e
[feat] Add rule `no-undef` in config file validation (#3786)
KristjanESPERANTO May 14, 2025
2f9f4b6
[feature] implement short syntax for clock week (#3775)
bughaver May 16, 2025
d179051
fix `roboto.css` to avoid error message (#3787)
khassel May 20, 2025
d07912d
update dependencies incl. electron to v36 (#3788)
khassel May 23, 2025
4e3821c
[workflow] Replace Node.js version v23 with v24 (#3770)
KristjanESPERANTO May 23, 2025
85b4ece
[refactor] Replace deprecated constants (#3789)
KristjanESPERANTO May 23, 2025
e26aed9
[refactor] Replace `ansis` with built-in function `util.styleText` (#…
KristjanESPERANTO May 27, 2025
c8625ff
simplify install and maintaining dependencies (#3795)
khassel Jun 1, 2025
975ee9c
update dependencies (#3804)
khassel Jun 1, 2025
302b24c
[l10n] Complete translations (#3794)
KristjanESPERANTO Jun 5, 2025
052ec1c
remove existing folders fonts and vendor from local installations (#3…
khassel Jun 7, 2025
faf15ad
Refactored calendarfetcherutils to fix many of the timezone and DST r…
plebcity Jun 7, 2025
2194ffd
[tests] Fix and refactor e2e test "Same keys" in "translations_spec.j…
KristjanESPERANTO Jun 9, 2025
6501aab
[linter] Enable ESLint rule `no-console` (#3810)
KristjanESPERANTO Jun 9, 2025
ee87483
update deps and fix animateCSS_spec test (#3811)
khassel Jun 19, 2025
9a3f4f0
Update package type to `commonjs` (#3814)
bugsounet Jun 20, 2025
c7c0e67
review logger factory code part: use switch/case (#3812)
bugsounet Jun 20, 2025
2809ed1
[tests] Review and refactor translation tests (#3792)
KristjanESPERANTO Jun 20, 2025
d2d4d7b
update jest to v30 (#3815)
khassel Jun 21, 2025
1e11d28
fixes e2e tests (#3817)
khassel Jun 25, 2025
5e506ea
last dependency update before release (#3823)
khassel Jun 29, 2025
2680972
Prepare Release 2.32.0 (#3825)
khassel Jun 30, 2025
b506bbb
Merge remote-tracking branch 'origin/master' into develop
khassel Jun 30, 2025
106b505
Prepare 2.33.0-develop
khassel Jun 30, 2025
855b1d7
update dependencies incl. electron to v37, remove one failing unit te…
khassel Jul 1, 2025
3a2a52c
Add CSS to clock module to prevent line breaking of sunrise/sunset in…
dathbe Jul 2, 2025
d9e2e02
Fix calendar unit test so it uses 1 day more than a full year for yea…
plebcity Jul 2, 2025
e4ec8c3
Fix missing icons in clock module (#3834)
rejas Jul 5, 2025
e115475
feat: enhance system information logging format and include additiona…
KristjanESPERANTO Jul 10, 2025
a05eb23
refactor default modules: move scheduleTimer to one place (#3837)
khassel Jul 10, 2025
931fe55
refactor: optimize system information logging (#3843)
KristjanESPERANTO Jul 12, 2025
7f8935a
refactor: simplify jest config (#3844)
KristjanESPERANTO Jul 13, 2025
02e76da
refactor: extract constants for weather electron tests (#3845)
KristjanESPERANTO Jul 14, 2025
54752f1
replace `console` with `Log` in calendar `debug.js` (#3846)
khassel Jul 15, 2025
e7b669a
e2e: decrease stop app waitTime (#3847)
khassel Jul 16, 2025
3fa2b96
cleanup and try to stabilize weather e2e tests (#3848)
khassel Jul 20, 2025
e34ef0c
update dependencies (#3849)
khassel Jul 22, 2025
839d074
Update dependencies (#3857)
rejas Aug 11, 2025
0ca7d23
update github actions (#3858)
rejas Aug 12, 2025
1b31cf1
Thoroughly check for precipitationAmount values in weathergov provide…
rejas Aug 16, 2025
83d15aa
tests: add `setupDOMEnvironment` helper function to eliminate repetit…
KristjanESPERANTO Aug 19, 2025
76da0aa
Make `User-Agent` configurable (#3255)
m-idler Aug 27, 2025
787fbda
tests: update jest snapshot url (#3861)
khassel Aug 27, 2025
483d3cd
Fix limitdays regression (#3863)
sdetweil Aug 28, 2025
3387bf8
fix regression #3841 (#3865)
sdetweil Aug 28, 2025
eb71942
fix for #3380, socket.io timeout closure (#3862)
sdetweil Aug 28, 2025
4c0a468
[tests] refactor translation tests (#3866)
KristjanESPERANTO Aug 28, 2025
fad8bba
test: add alert module tests for different `welcome_message` configur…
KristjanESPERANTO Aug 28, 2025
f8679b6
[weather] use 'apparent_temperature' in openmeteos data for feelsLike…
rejas Aug 30, 2025
25efe42
Update feels_like temperature formula (#3869)
rejas Sep 1, 2025
6f4eab9
[core] bump dependencies into september (#3872)
rejas Sep 1, 2025
93d5df8
update electron to v38 (#3876)
khassel Sep 3, 2025
be957af
bump minimal node version to v22.18.0 (#3877)
khassel Sep 4, 2025
d277a27
Bump github actions and dependencies (#3882)
rejas Sep 8, 2025
31bafc3
update default icon for calendars (#3879)
rejas Sep 8, 2025
b1865d8
refactor: use global.root_path instead relative paths (#3883)
khassel Sep 9, 2025
2481bc6
revert changes breaking `node --run config:check` (#3885)
khassel Sep 10, 2025
3260b9d
add test for config:check (#3886)
khassel Sep 11, 2025
08d29c3
Add Prettier plugin for Nunjuck templates (#3887)
rejas Sep 11, 2025
d81386f
chore: use `prettier --write --ignore-unknown` in `lint-staged` to av…
KristjanESPERANTO Sep 11, 2025
aac85bb
improve config check tests (#3889)
khassel Sep 11, 2025
fb2aa43
feat: add clear log for occupied port at startup (#3890)
KristjanESPERANTO Sep 13, 2025
777b49c
chore: update dependencies (#3891)
KristjanESPERANTO Sep 15, 2025
a49fbed
[weather] better null value handling for weather type (#3892)
rejas Sep 16, 2025
e886821
Fix for envcanada Provider to use new Environment Canada weather data…
Crazylegstoo Sep 17, 2025
fbca0a0
[layout] update styles for weather and calendar (#3894)
rejas Sep 17, 2025
1f2d1b9
update jsdoc and other deps (#3896)
khassel Sep 23, 2025
593a4b9
Prepare Release 2.33.0 (#3902)
KristjanESPERANTO Sep 30, 2025
b1a189b
Prepare 2.34.0-develop
KristjanESPERANTO Sep 30, 2025
787cc6b
refactor: replace `module-alias` dependency with internal alias resol…
KristjanESPERANTO Sep 30, 2025
b09a27a
chore: bump dependencies into october (#3909)
rejas Oct 1, 2025
5f1f5bd
feat: add ESlint rule `no-sparse-arrays` for config check (#3911)
KristjanESPERANTO Oct 13, 2025
d39e686
remove eslint warnings, add npm publish process to Collaboration.md (…
khassel Oct 14, 2025
9ff716f
update deps, exclude node v23 (#3916)
khassel Oct 16, 2025
37d1a3a
refactor: replace `express-ipfilter` with lightweight custom middlewa…
KristjanESPERANTO Oct 18, 2025
96d3e87
[weather] feat: add configurable forecast date format option (#3918)
KristjanESPERANTO Oct 18, 2025
2a4a056
Fix for envcanada Provider to use updated Env Canada URL (#3919)
Crazylegstoo Oct 19, 2025
64f78ea
chore: update dependencies (#3921)
KristjanESPERANTO Oct 19, 2025
f1c0c38
[core] Update deps and pin jsdom to v27.0.0 (#3925)
rejas Oct 20, 2025
a1c1e95
[logger] Add prefixes to most Log messages (#3923)
rejas Oct 21, 2025
bc0d365
logger: add calling filename as prefix on server side (#3926)
khassel Oct 22, 2025
c9eecdd
[calendar] test: remove "Recurring event per timezone" test (#3929)
KristjanESPERANTO Oct 23, 2025
9ad5618
[check_config] refactor: improve error handling (#3927)
KristjanESPERANTO Oct 23, 2025
2e795f6
[calendar] chore: remove `requiresVersion: "2.1.0"` (#3932)
KristjanESPERANTO Oct 27, 2025
961b3c9
feat(core): add `server:watch` script with automatic restart on file …
jboucly Oct 28, 2025
1e5d127
fixes problems with daylight-saving-time in weather provider `openmet…
khassel Nov 1, 2025
b542f33
Update deps, unpin parse5 (#3934)
rejas Nov 1, 2025
462abf7
[tests] migrate from `jest` to `vitest` (#3940)
KristjanESPERANTO Nov 3, 2025
d7348ed
[tests] suppress debug logs in CI environment + improve calendar symb…
KristjanESPERANTO Nov 3, 2025
67fead7
[ci] Add concurrency to automated tests workflow to cancel outdated r…
KristjanESPERANTO Nov 4, 2025
9d713ff
[test] replace `node-libgpiod` with `serialport` in electron-rebuild …
KristjanESPERANTO Nov 4, 2025
034f3c4
[newsfeed] fix header layout issue (#3946)
rejas Nov 5, 2025
ab5f79a
remove deprecated ukmetoffice datapoint provider, cleanup .gitignore …
khassel Nov 7, 2025
3b79791
[calendar] Show `repeatingCountTitle` only if `yearDiff` > 0 (#3949)
jarnoml Nov 8, 2025
c1aaea5
[weather] add error handling to weather fetch functions, including co…
sdetweil Nov 8, 2025
8e9ee89
[gitignore] restoring the old Git behavior for the CSS directory (#3954)
KristjanESPERANTO Nov 8, 2025
2b08288
[core] configure cspell to check default modules only and fix typos (…
KristjanESPERANTO Nov 8, 2025
f29f424
[core] refactor: replace `XMLHttpRequest` with `fetch` and migrate e2…
KristjanESPERANTO Nov 8, 2025
38a4d23
[weather] fix wind-icon not showing in pirateweather (#3957)
rejas Nov 10, 2025
53df20f
[weatherprovider] update subclass language use override (#3914)
JHWelch Nov 13, 2025
3c4d69e
[calendar] refactor: migrate CalendarFetcher to ES6 class and improve…
KristjanESPERANTO Nov 14, 2025
1796400
Add new pt and pt-BR translations for Alert module and update global …
Blackspirits Nov 16, 2025
a52baa5
[compliments] fix: duplicate query param "?" in compliments module re…
xsorifc28 Nov 19, 2025
854c954
[gitignore] restore the old Git behavior for the default modules (#3968)
KristjanESPERANTO Nov 19, 2025
74b682f
fix: set compliments remote file minimum delay to 15 minutes (#3970)
xsorifc28 Nov 21, 2025
7934e7a
[compliments] refactor: optimize `loadComplimentFile` method and add …
KristjanESPERANTO Nov 23, 2025
a0f1a2c
Bump actions/checkout from 5 to 6 (#3972)
dependabot[bot] Nov 24, 2025
ca6e8b2
[core] chore: simplify Wayland start script (#3974)
KristjanESPERANTO Nov 29, 2025
fdac92d
[core] bump dependencies into december (#3982)
rejas Dec 1, 2025
c2ec6fc
[calendar] fix: prevent excessive fetching on client reload and refac…
KristjanESPERANTO Dec 8, 2025
4186cbf
[core] auto create release notes with every push on develop (#3985)
khassel Dec 10, 2025
e7ad361
[chore] update dependencies and min. node version (#3986)
khassel Dec 10, 2025
1998b62
testing: update "Enforce Pull-Request Rules" workflow (#3987)
khassel Dec 10, 2025
c64d3ef
[core] fix: restore `--ozone-platform=wayland` flag for reliable Wayl…
KristjanESPERANTO Dec 14, 2025
9c25b15
add checksum to test whether calendar event list changed (#3988)
sdetweil Dec 18, 2025
9d3b07d
[core] fix: allow browser globals in config files (#3992)
KristjanESPERANTO Dec 21, 2025
4962078
demo with gif (#3995)
khassel Dec 28, 2025
0fb6fcb
dependency update + adjust Playwright setup + fix linter issue (#3994)
khassel Dec 28, 2025
d5d1441
Prepare Release 2.34.0 (#3998)
sdetweil Jan 1, 2026
a4f29f7
Merge branch 'master' into develop
khassel Jan 1, 2026
950f551
set next release dev number (#4000)
sdetweil Jan 1, 2026
241921b
[core] run systeminformation in subprocess so the info is always disp…
khassel Jan 3, 2026
40301f2
fix(calendar): correct day-of-week for full-day recurring events acro…
KristjanESPERANTO Jan 4, 2026
9731ea2
refactor: unify favicon for index.html and Electron (#4006)
KristjanESPERANTO Jan 5, 2026
56fe067
chore: migrate CI workflows to ubuntu-slim for faster startup times (…
KristjanESPERANTO Jan 7, 2026
b847dd7
update Collaboration.md and dependencies (#4001)
khassel Jan 8, 2026
8e6701f
Update deps as requested by dependabot (#4008)
rejas Jan 8, 2026
471dbd8
Change default start scripts from X11 to Wayland (#4011)
KristjanESPERANTO Jan 10, 2026
3b793bf
Update node-ical and support it's rrule-temporal changes (#4010)
KristjanESPERANTO Jan 11, 2026
82e39a2
fix systeminformation not displaying electron version (#4012)
khassel Jan 11, 2026
2d3a557
fix(calendar): update to node-ical 0.23.1 and fix full-day recurrence…
KristjanESPERANTO Jan 12, 2026
37a8b11
chore(eslint): migrate from eslint-plugin-vitest to @vitest/eslint-pl…
KristjanESPERANTO Jan 12, 2026
23f0290
Switch to undici Agent for HTTPS requests (#4015)
in-voker Jan 17, 2026
34913bf
[core] refactor: extract and centralize HTTP fetcher (#4016)
KristjanESPERANTO Jan 22, 2026
5e0cd28
update electron to v40, update node versions in workflows (#4018)
khassel Jan 24, 2026
d44db6e
move default modules from /modules/default to /defaultmodules (#4019)
khassel Jan 27, 2026
43503e8
chore: update dependencies (#4021)
KristjanESPERANTO Jan 27, 2026
6324ec2
move custom.css from css to config (#4020)
khassel Jan 28, 2026
2b55b8e
refactor(clientonly): modernize code structure and add comprehensive …
KristjanESPERANTO Jan 28, 2026
5c1cc47
[newsfeed] refactor: migrate to centralized HTTPFetcher (#4023)
KristjanESPERANTO Jan 29, 2026
751c83b
Update node-ical and other deps (#4025)
rejas Jan 31, 2026
4311034
Add dark theme logo (#4026)
JHWelch Feb 1, 2026
f6d559e
remove kioskmode (#4027)
khassel Feb 5, 2026
f9f3461
calendar.js: remove useless hasCalendarURL function (#4028)
khassel Feb 5, 2026
9dd964e
change loading config.js, allow variables in config.js and try to pro…
khassel Feb 5, 2026
b9481d2
fix: correct secret redaction and optimize loadConfig (#4031)
khassel Feb 7, 2026
172ca18
fix cors proxy getting binary data (e.g. png, webp) (#4030)
khassel Feb 8, 2026
1dc3032
allow environment variables in cors urls (#4033)
khassel Feb 8, 2026
6cb3e24
replace template_spec test with config_variables test (#4034)
khassel Feb 9, 2026
80c4879
[weather] feat: add Weather API Provider (#4036)
angeldeejay Feb 21, 2026
8ce0cda
[weather] refactor: migrate to server-side providers with centralized…
KristjanESPERANTO Feb 23, 2026
729f7f0
[core] refactor: enable ESLint rule require-await and handle detected…
KristjanESPERANTO Feb 25, 2026
df8a882
fix(newsfeed): fix full article view and add framing check (#4039)
KristjanESPERANTO Feb 28, 2026
083953f
chore: update dependencies + add exports, files, and sideEffects fiel…
KristjanESPERANTO Mar 1, 2026
587bc25
chore: remove obsolete Jest config and unit test global setup (#4044)
KristjanESPERANTO Mar 1, 2026
06b1361
Use getDateString in openmeteo (#4046)
rejas Mar 1, 2026
ab3108f
[calendar] refactor: delegate event expansion to node-ical's expandRe…
KristjanESPERANTO Mar 2, 2026
3eb3745
Fix Node.js v25 logging prefix and modernize logger (#4049)
KristjanESPERANTO Mar 6, 2026
e7503a4
refactor: further logger clean-up (#4050)
KristjanESPERANTO Mar 6, 2026
cb61aeb
chore: update ESLint and plugins, simplify config, apply new rules (#…
KristjanESPERANTO Mar 7, 2026
35cd4d8
weather: add possibility to override njk's and css (#4051)
khassel Mar 8, 2026
0ca91f7
weather: fixes for templates (#4054)
khassel Mar 9, 2026
9fe7d1e
test(calendar): fix hardcoded date in event shape test (#4055)
KristjanESPERANTO Mar 11, 2026
21d1e74
refactor: simplify internal `require()` calls (#4056)
KristjanESPERANTO Mar 12, 2026
3ea3f0a
chore: upgrade ESLint to v10 and fix newly surfaced issues (#4057)
KristjanESPERANTO Mar 12, 2026
d072345
update dependencies incl. electron to v41 (#4058)
khassel Mar 12, 2026
e1c44a8
fix(calendar): make showEnd behavior more consistent across time form…
KristjanESPERANTO Mar 17, 2026
ee26193
fix(weather): fix weathergov forecast day labels off by one (#4065)
KristjanESPERANTO Mar 22, 2026
de78190
fix(weather): fix openmeteo forecast stuck in the past (#4064)
KristjanESPERANTO Mar 23, 2026
51f6927
update dependencies (#4068)
khassel Mar 31, 2026
946d322
docs: add security policy and vulnerability reporting guidelines (#4069)
KristjanESPERANTO Mar 31, 2026
9eaef41
Prepare Release 2.35.0 (#4071)
khassel Apr 1, 2026
b6f2876
Merge branch 'master' into develop
khassel Apr 1, 2026
751b97f
update version for develop
khassel Apr 1, 2026
d7c4ad1
fix(tests): correct import path for git_helper module in updatenotifi…
KristjanESPERANTO Apr 1, 2026
32aa5c8
chore: add permissions section to enforce pull-request rules workflow…
KristjanESPERANTO Apr 1, 2026
8e1630e
refactor: enable ESLint rule "no-unused-vars" and handle related issu…
KristjanESPERANTO Apr 2, 2026
d2304af
SMHI: migrate to SNOW1gv1 API (replace deprecated PMP3gv2) (#4082)
cgillinger Apr 3, 2026
19c6489
fix(newsfeed): prevent duplicate parse error callback when using pipe…
KristjanESPERANTO Apr 3, 2026
dce2df6
refactor: replace implicit global config with explicit global.config …
KristjanESPERANTO Apr 3, 2026
03f2689
fix: prevent SSRF via /cors endpoint by blocking private/reserved IPs…
KristjanESPERANTO Apr 3, 2026
abf6989
add option to disable or restrict cors endpoint (#4087)
khassel Apr 4, 2026
512e746
chore: update dependencies (#4088)
KristjanESPERANTO Apr 4, 2026
f079324
ci(codeql): also scan develop branch on push and PR (#4086)
KristjanESPERANTO Apr 4, 2026
96c18ec
fix(cors): prevent SSRF via DNS rebinding (#4090)
KristjanESPERANTO Apr 4, 2026
0da343b
fix(weather): use stable instanceId to prevent duplicate fetchers (#4…
KristjanESPERANTO Apr 5, 2026
9b97add
fix cors function for alpine linux (#4091)
khassel Apr 5, 2026
d8c29d5
fix: prevent crash when config is undefined in socket handler (#4096)
KristjanESPERANTO Apr 7, 2026
2e97e29
fix(http_fetcher): use undici.fetch when dispatcher is present (#4097)
KristjanESPERANTO Apr 8, 2026
22a58d4
fix(weather): restore OpenWeatherMap v2.5 support (#4101)
KristjanESPERANTO Apr 10, 2026
39578d6
restrict replaceSecretPlaceholder to cors with allowWhitelist (#4102)
khassel Apr 10, 2026
61870ae
fix replaceSecretPlaceholder (#4104)
khassel Apr 11, 2026
d3a3ad9
config endpoint must handle functions in module configs (#4106)
khassel Apr 12, 2026
de3f57f
weather: fix UV index display and add WeatherFlow precipitation (#4108)
KristjanESPERANTO Apr 19, 2026
3f2a030
ci(actions): set explicit token permissions (#4114)
KristjanESPERANTO Apr 19, 2026
7e12862
fix(http-fetcher): fall back to reloadInterval after retries exhauste…
KristjanESPERANTO Apr 27, 2026
9dc4b7a
fix(updatenotification): harden git command execution + simplify chec…
KristjanESPERANTO Apr 27, 2026
b8548f2
Allow HTTPFetcher to pass through 304 responses (#4120)
sonnyb9 Apr 27, 2026
4c2a373
fix(weather): avoid loading state after reconnect (#4121)
KristjanESPERANTO Apr 27, 2026
8af3d02
fix(weather): use nearest openmeteo hourly data (#4123)
KristjanESPERANTO Apr 28, 2026
5a82c9d
update dependencies (#4124)
khassel Apr 29, 2026
8dbee62
Prepare Release 2.36.0 (#4126)
khassel Apr 30, 2026
99a37ad
Merge remote-tracking branch 'origin/master' into develop
khassel Apr 30, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 37 additions & 0 deletions .github/workflows/codeql.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
name: CodeQL

on:
push:
branches: [develop, master]
pull_request:
branches: [develop]
schedule:
- cron: "0 4 * * 1"

jobs:
analyze:
name: Analyze (${{ matrix.language }})
runs-on: ubuntu-latest
permissions:
actions: read
contents: read
security-events: write

strategy:
fail-fast: false
matrix:
language: [actions, javascript-typescript]

steps:
- uses: actions/checkout@v6

- uses: github/codeql-action/init@v4
with:
languages: ${{ matrix.language }}
queries: security-and-quality

- uses: github/codeql-action/autobuild@v4

- uses: github/codeql-action/analyze@v4
with:
category: "/language:${{ matrix.language }}"
3 changes: 3 additions & 0 deletions .github/workflows/electron-rebuild.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
name: "Electron Rebuild Testing"

permissions:
contents: read

on: [pull_request]

jobs:
Expand Down
3 changes: 3 additions & 0 deletions .github/workflows/enforce-pullrequest-rules.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,9 @@

name: "Enforce Pull-Request Rules"

permissions:
contents: read

on:
pull_request:
push:
Expand Down
19 changes: 19 additions & 0 deletions cspell.config.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,12 @@
"armv",
"ashishtank",
"autoplay",
"avghumidity",
"avgtemp",
"Autorestart",
"beada",
"Behaviour",
"Beschreibung",
"Binney",
"bluemanos",
"bnitkin",
Expand Down Expand Up @@ -111,6 +114,7 @@
"flopp",
"fontawesome",
"fontface",
"forecastday",
"forecastweather",
"fortawesome",
"frameguard",
Expand Down Expand Up @@ -186,14 +190,18 @@
"luxon",
"lxsession",
"magicmirror",
"mapbox",
"martingron",
"marvai",
"mastermerge",
"matchtype",
"maxentries",
"maxtemp",
"maxwind",
"Meteo",
"michaelteeuw",
"michmich",
"mintemp",
"Midori",
"mirontoli",
"MISSINGLANG",
Expand All @@ -212,7 +220,9 @@
"NEWSFEED",
"newsfeedfetcher",
"newsfetcher",
"newyear",
"newsitems",
"nextdaysrelative",
"nfogal",
"njwilliams",
"nonrepeating",
Expand All @@ -239,8 +249,10 @@
"pmin",
"Português",
"PRECIP",
"precips",
"Problema",
"psieg",
"ptype",
"pubdate",
"radokristof",
"rajniszp",
Expand All @@ -255,12 +267,14 @@
"Rosso",
"Rothfusz",
"rrule",
"sameorigin",
"savvadam",
"sdetweil",
"searchstr",
"sendheaders",
"serveronly",
"sexualized",
"showend",
"Sitecode",
"skpanagiotis",
"SMHI",
Expand Down Expand Up @@ -295,8 +309,11 @@
"timeformat",
"titlereplacestr",
"titlesearchstr",
"TOCTOU",
"todaytemp",
"tomzt",
"totalprecip",
"totalsnow",
"trunc",
"ttlms",
"ukmetoffice",
Expand All @@ -317,6 +334,7 @@
"Vorberechnung",
"vppencilsharpener",
"Wallys",
"weatherapi",
"Weatherbit",
"weathercode",
"WEATHERDATA",
Expand All @@ -336,6 +354,7 @@
"Woolridge",
"worktree",
"Wsymb",
"xhvw",
"xlarge",
"xmark",
"xrandr",
Expand Down
2 changes: 1 addition & 1 deletion defaultmodules/calendar/calendar.js
Original file line number Diff line number Diff line change
Expand Up @@ -167,7 +167,7 @@ Module.register("calendar", {
this.selfUpdate();
},

notificationReceived (notification, payload, sender) {
notificationReceived (notification, payload) {
if (notification === "FETCH_CALENDAR") {
this.sendSocketNotification(notification, { url: payload.url, id: this.identifier });
}
Expand Down
1 change: 0 additions & 1 deletion defaultmodules/calendar/calendarfetcher.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
const ical = require("node-ical");
const Log = require("logger");
const { Agent } = require("undici");
const CalendarFetcherUtils = require("./calendarfetcherutils");
const HTTPFetcher = require("#http_fetcher");

Expand Down
2 changes: 1 addition & 1 deletion defaultmodules/calendar/calendarfetcherutils.js
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ const CalendarFetcherUtils = {
// Subtract 1 second so that events that start on the middle of the night will not repeat.
.subtract(1, "seconds");

Object.entries(data).forEach(([key, event]) => {
Object.values(data).forEach((event) => {
if (event.type !== "VEVENT") {
return;
}
Expand Down
2 changes: 1 addition & 1 deletion defaultmodules/compliments/compliments.js
Original file line number Diff line number Diff line change
Expand Up @@ -308,7 +308,7 @@ Module.register("compliments", {
},

// Override notification handler.
notificationReceived (notification, payload, sender) {
notificationReceived (notification, payload) {
if (notification === "CURRENTWEATHER_TYPE") {
this.currentWeatherType = payload.type;
}
Expand Down
2 changes: 1 addition & 1 deletion defaultmodules/newsfeed/newsfeed.js
Original file line number Diff line number Diff line change
Expand Up @@ -411,7 +411,7 @@ Module.register("newsfeed", {
}
},

notificationReceived (notification, payload, sender) {
notificationReceived (notification) {
const before = this.activeItem;
if (notification === "MODULE_DOM_CREATED" && this.config.hideLoading) {
this.hide();
Expand Down
11 changes: 3 additions & 8 deletions defaultmodules/newsfeed/newsfeedfetcher.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ class NewsfeedFetcher {
});

// Wire up HTTPFetcher events
this.httpFetcher.on("response", (response) => this.#handleResponse(response));
this.httpFetcher.on("response", (response) => void this.#handleResponse(response));
this.httpFetcher.on("error", (errorInfo) => this.fetchFailedCallback(this, errorInfo));
}

Expand All @@ -67,7 +67,7 @@ class NewsfeedFetcher {
* Handles successful HTTP response
* @param {Response} response - The fetch Response object
*/
#handleResponse (response) {
async #handleResponse (response) {
this.items = [];
const parser = new FeedMe();

Expand Down Expand Up @@ -106,11 +106,6 @@ class NewsfeedFetcher {

parser.on("end", () => this.broadcastItems());

parser.on("error", (error) => {
Log.error(`${this.url} - Feed parsing failed: ${error.message}`);
this.fetchFailedCallback(this, this.#createParseError(`Feed parsing failed: ${error.message}`, error));
});

parser.on("ttl", (minutes) => {
const ttlms = Math.min(minutes * 60 * 1000, 86400000);
if (ttlms > this.httpFetcher.reloadInterval) {
Expand All @@ -123,7 +118,7 @@ class NewsfeedFetcher {
const nodeStream = response.body instanceof stream.Readable
? response.body
: stream.Readable.fromWeb(response.body);
nodeStream.pipe(iconv.decodeStream(this.encoding)).pipe(parser);
await stream.promises.pipeline(nodeStream, iconv.decodeStream(this.encoding), parser);
} catch (error) {
Log.error(`${this.url} - Stream processing failed: ${error.message}`);
this.fetchFailedCallback(this, this.#createParseError(`Stream processing failed: ${error.message}`, error));
Expand Down
42 changes: 19 additions & 23 deletions defaultmodules/updatenotification/git_helper.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const util = require("node:util");
const exec = util.promisify(require("node:child_process").exec);
const execFile = util.promisify(require("node:child_process").execFile);
const fs = require("node:fs");
const path = require("node:path");
const Log = require("logger");
Expand All @@ -14,14 +14,14 @@ class GitHelper {
return new RegExp(`s*([a-z,0-9]+[.][.][a-z,0-9]+) ${branch}`, "g");
}

async execShell (command) {
const { stdout = "", stderr = "" } = await exec(command);
async execGit (moduleFolder, ...args) {
const { stdout = "", stderr = "" } = await execFile("git", args, { cwd: moduleFolder });

return { stdout, stderr };
}

async isGitRepo (moduleFolder) {
const { stderr } = await this.execShell(`cd ${moduleFolder} && git remote -v`);
const { stderr } = await this.execGit(moduleFolder, "remote", "-v");

if (stderr) {
Log.error(`Failed to fetch git data for ${moduleFolder}: ${stderr}`);
Expand Down Expand Up @@ -51,7 +51,7 @@ class GitHelper {
// Folder has .git and has at least one git remote, watch this folder
this.gitRepos.push({ module: moduleName, folder: moduleFolder });
}
} catch (err) {
} catch {
// Error when directory .git doesn't exist or doesn't have any remotes
// This module is not managed with git, skip
}
Expand All @@ -69,7 +69,7 @@ class GitHelper {

if (repo.module === "MagicMirror") {
// the hash is only needed for the mm repo
const { stderr, stdout } = await this.execShell(`cd ${repo.folder} && git rev-parse HEAD`);
const { stderr, stdout } = await this.execGit(repo.folder, "rev-parse", "HEAD");

if (stderr) {
Log.error(`Failed to get current commit hash for ${repo.module}: ${stderr}`);
Expand All @@ -78,7 +78,7 @@ class GitHelper {
gitInfo.hash = stdout;
}

const { stderr, stdout } = await this.execShell(`cd ${repo.folder} && git status -sb`);
const { stderr, stdout } = await this.execGit(repo.folder, "status", "-sb");

if (stderr) {
Log.error(`Failed to get git status for ${repo.module}: ${stderr}`);
Expand Down Expand Up @@ -123,7 +123,7 @@ class GitHelper {
return gitInfo;
}

const { stderr } = await this.execShell(`cd ${repo.folder} && git fetch -n --dry-run`);
const { stderr } = await this.execGit(repo.folder, "fetch", "-n", "--dry-run");

// example output:
// From https://github.com/MagicMirrorOrg/MagicMirror
Expand All @@ -140,22 +140,22 @@ class GitHelper {

// get behind with refs
try {
const { stdout } = await this.execShell(`cd ${repo.folder} && git rev-list --ancestry-path --count ${refDiff}`);
const { stdout } = await this.execGit(repo.folder, "rev-list", "--ancestry-path", "--count", refDiff);
gitInfo.behind = parseInt(stdout);

// for MagicMirror-Repo and "master" branch avoid getting notified when no tag is in refDiff
// so only releases are reported and we can change e.g. the README.md without sending notifications
if (gitInfo.behind > 0 && gitInfo.module === "MagicMirror" && gitInfo.current === "master") {
let tagList = "";
try {
const { stdout } = await this.execShell(`cd ${repo.folder} && git ls-remote -q --tags --refs`);
const { stdout } = await this.execGit(repo.folder, "ls-remote", "-q", "--tags", "--refs");
tagList = stdout.trim();
} catch (err) {
Log.error(`Failed to get tag list for ${repo.module}: ${err}`);
}
// check if tag is between commits and only report behind > 0 if so
try {
const { stdout } = await this.execShell(`cd ${repo.folder} && git rev-list --ancestry-path ${refDiff}`);
const { stdout } = await this.execGit(repo.folder, "rev-list", "--ancestry-path", refDiff);
let cnt = 0;
for (const ref of stdout.trim().split("\n")) {
if (tagList.includes(ref)) cnt++; // tag found
Expand Down Expand Up @@ -193,19 +193,15 @@ class GitHelper {
return this.gitResultList;
}

async checkUpdates () {
var updates = [];
checkUpdates () {
const updates = [];

const allRepos = await this.gitResultList.map((module) => {
return new Promise((resolve) => {
if (module.behind > 0 && module.module !== "MagicMirror") {
Log.info(`Update found for module: ${module.module}`);
updates.push(module);
}
resolve(module);
});
});
await Promise.all(allRepos);
for (const moduleInfo of this.gitResultList) {
if (moduleInfo.behind > 0 && moduleInfo.module !== "MagicMirror") {
Log.info(`Update found for module: ${moduleInfo.module}`);
updates.push(moduleInfo);
}
}

return updates;
}
Expand Down
4 changes: 2 additions & 2 deletions defaultmodules/updatenotification/update_helper.js
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@ class Updater {
Log.info(`Updating ${module.name}...`);

return new Promise((resolve) => {
Exec(Command, { cwd: modulePath, timeout: this.timeout }, (error, stdout, stderr) => {
Exec(Command, { cwd: modulePath, timeout: this.timeout }, (error, stdout) => {
if (error) {
Log.error(`exec error: ${error}`);
Result.error = true;
Expand Down Expand Up @@ -143,7 +143,7 @@ class Updater {
pm2Restart () {
Log.info("[PM2] restarting MagicMirror...");
const pm2 = require("pm2");
pm2.restart(this.PM2Id, (err, proc) => {
pm2.restart(this.PM2Id, (err) => {
if (err) {
Log.error("[PM2] restart Error", err);
}
Expand Down
6 changes: 3 additions & 3 deletions defaultmodules/weather/current.njk
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@
{% if config.showUVIndex %}
<td class="align-right bright uv-index">
<div class="wi dimmed wi-hot"></div>
{{ current.uv_index }}
{{ current.uvIndex }}
</td>
{% endif %}
</div>
Expand Down Expand Up @@ -78,11 +78,11 @@
</span>
<br />
{% endif %}
{% if config.showPrecipitationAmount and current.precipitationAmount %}
{% if config.showPrecipitationAmount and current.precipitationAmount is defined and current.precipitationAmount is not none %}
<span class="dimmed"> <span class="precipitationLeadText">{{ "PRECIP_AMOUNT" | translate }}</span> {{ current.precipitationAmount | unit("precip", current.precipitationUnits) }} </span>
<br />
{% endif %}
{% if config.showPrecipitationProbability and current.precipitationProbability %}
{% if config.showPrecipitationProbability and current.precipitationProbability is defined and current.precipitationProbability is not none %}
<span class="dimmed"> <span class="precipitationLeadText">{{ "PRECIP_POP" | translate }}</span> {{ current.precipitationProbability }}% </span>
{% endif %}
</div>
Expand Down
Loading
Loading