Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/georg-jung/blazorwol
A simple blazor application that enables you to do Wake-on-LAN / send magic packets in the network where it is hosted.
https://github.com/georg-jung/blazorwol
blazor blazor-server entity-framework-core wake-on-lan
Last synced: 19 days ago
JSON representation
A simple blazor application that enables you to do Wake-on-LAN / send magic packets in the network where it is hosted.
- Host: GitHub
- URL: https://github.com/georg-jung/blazorwol
- Owner: georg-jung
- License: mit
- Created: 2019-12-12T21:57:58.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-02-24T18:18:06.000Z (almost 2 years ago)
- Last Synced: 2024-12-20T16:03:14.473Z (19 days ago)
- Topics: blazor, blazor-server, entity-framework-core, wake-on-lan
- Language: C#
- Size: 370 KB
- Stars: 31
- Watchers: 4
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Blazor Wake-on-LAN
[![CI](https://github.com/georg-jung/BlazorWoL/actions/workflows/ci.yml/badge.svg)](https://github.com/georg-jung/BlazorWoL/actions/workflows/ci.yml)
This is a [Wake-on-LAN](https://en.wikipedia.org/wiki/Wake-on-LAN) app for your network, written in server-side blazor. I developed it for internal use at my workplace and because I wanted to build a small, limited-scope but fully-working and done-right blazor app. [Getting started](#getting-started) is as easy as downloading and running. Feel free to improve/fork/PR this if you think I could have done anything better.
## Getting Started
### With Docker
You can start a BlazorWoL docker container like this:
```bash
docker run -e "ConnectionStrings__SqliteConnection=Data Source=/blazorwol/db.sqlite" -v /var/blazorwol:/blazorwol --network host --name blazorwol ghcr.io/georg-jung/blazorwol:latest
```Please note that this does not work on Windows, even with WSL, as docker host networking is required.
### By downloading binaries
1. [Download](#download) and unzip the [latest release](https://github.com/georg-jung/BlazorWoL/releases/latest/).
2. Run the application by starting `WoL.exe`
3. Open the shown location in a browser (probably `localhost:5000`) and add your first host.You can add the application to IIS for more serious hosting. You can set up T-SQL as a backend for backup etc.. See the [`appsettings.json` file](WoL/appsettings.json) for details. If you host this in IIS you might want to [configure it to be always running](https://serverfault.com/a/823531), otherwise the first request after some idle time will take seconds.
## Download
The platform-specific releases have no prerequisits. Just unpack and double-click. The framework dependend release is smaller and portable but requires [.Net 7 Runtime to be installed](https://dotnet.microsoft.com/download/dotnet-core).
* [Windows x86](https://github.com/georg-jung/BlazorWoL/releases/latest/download/win-x86.zip)
* This app does not take advantage of 64bit, so I chose to deploy x86 due to the smaller footprint.
* [Windows x86 IIS](https://github.com/georg-jung/BlazorWoL/releases/latest/download/win-x86-iis.zip)
* All files listed here except from the *Runtime Dependent* one are self contained. Thus, you don't need to have the .Net runtime installed. They are published as single file executables too (you get one ~85mb exe file instead of hundreds of smaller files). To be able to host a .Net application in IIS it must not be published as a single file. So, if you want to host BlazorWoL in IIS, you may choose this download.
* [Windows ARM](https://github.com/georg-jung/BlazorWoL/releases/latest/download/win-arm.zip)
* [Linux x64](https://github.com/georg-jung/BlazorWoL/releases/latest/download/linux-x64.zip)
* [Runtime Dependent (.Net 7.0)](https://github.com/georg-jung/BlazorWoL/releases/latest/download/fdd.zip) *previously known as framework dependent*## Features
![Screenshot](screenshot-01-index.png)
* Wake arbitrary hosts on the network of the server where this is hosted via [Magic Packet](https://superuser.com/a/1066637)
* Add new hosts via the webinterface using either their hostname or their mac address.
* Detect the online status of saved hosts. To determine, they are at the same time [ping](https://en.wikipedia.org/wiki/Ping_(networking_utility))ed and we try to establish a TCP connection on port 3389. This port [is used](https://serverfault.com/a/12006) by the Microsoft Remote Desktop Protocol. This way, we can work with hosts that don't answer normal pings.
* Delete existing hosts from the list.
* When waking a host, the application repeatedly tries to reach the host and updates you about the status. You see immediately when the host finished booting so that you can connect via ssh/RDP/etc..## Showcase
This application uses the following techniques and might be suitable as a simple but full-fledged example of how they work:
* [Blazor](https://dotnet.microsoft.com/apps/aspnet/web-apps/blazor)
* Components and Pages in Razor
* UI-Server-interaction which would typically require AJAX/writing JavaScript. See the `Wake` page and the *Status* column of the index page.
* .Net 7
* [Entity Framework Core](https://docs.microsoft.com/en-us/ef/core/) Code First
* Automatic Migrations
* Supports T-SQL and SQLite, selection by connection string in `appsettings.json`
* Dependency Injection using [`Microsoft.Extensions.DependencyInjection`](https://www.nuget.org/packages/Microsoft.Extensions.DependencyInjection/)
* Continuous Integration and Continuous Deployment using GitHub Actions.
* Docker image creation and push
* Zipped executables in GitHub Release
* Dependency updates are partly automated using [Dependabot](https://dependabot.com/).
* Usage of Microsoft.Extensions.Logging with event ids and custom parameters.
* Usage of Application Insights to keep track of logged application events in production.
* Git height based versioning using [NBGV](https://github.com/dotnet/nerdbank.gitversioning).## Known Limitations
* Adding hosts by hostname is currently impossible on platforms except Windows and Linux, as there is no appropriate ARP API.