diff --git a/electron/main.ts b/electron/main.ts
index 0454c4917..abe2a48d2 100644
--- a/electron/main.ts
+++ b/electron/main.ts
@@ -1,6 +1,8 @@
import { app, BrowserWindow, protocol, screen } from 'electron'
import { join } from 'path'
+import { setupNetworkService } from './services/network'
+
export const ROOT_PATH = {
dist: join(__dirname, '..'),
}
@@ -15,10 +17,9 @@ function createWindow(): void {
mainWindow = new BrowserWindow({
icon: join(ROOT_PATH.dist, 'pwa-512x512.png'),
webPreferences: {
- webSecurity: false,
- contextIsolation: false,
- nodeIntegration: true,
- allowRunningInsecureContent: true,
+ preload: join(ROOT_PATH.dist, 'electron/preload.js'),
+ contextIsolation: true,
+ nodeIntegration: false,
},
width,
height,
@@ -60,6 +61,8 @@ protocol.registerSchemesAsPrivileged([
},
])
+setupNetworkService()
+
app.whenReady().then(createWindow)
app.on('before-quit', () => {
diff --git a/electron/preload.ts b/electron/preload.ts
new file mode 100644
index 000000000..bfdd3fe8c
--- /dev/null
+++ b/electron/preload.ts
@@ -0,0 +1,5 @@
+import { contextBridge, ipcRenderer } from 'electron'
+
+contextBridge.exposeInMainWorld('electronAPI', {
+ getNetworkInfo: () => ipcRenderer.invoke('get-network-info'),
+})
diff --git a/electron/services/network.ts b/electron/services/network.ts
new file mode 100644
index 000000000..991b0f60f
--- /dev/null
+++ b/electron/services/network.ts
@@ -0,0 +1,39 @@
+import { ipcMain } from 'electron'
+import { networkInterfaces } from 'os'
+
+/**
+ * Information about the network
+ */
+interface NetworkInfo {
+ /**
+ * The subnet of the local machine
+ */
+ subnet: string
+}
+
+/**
+ * Get the network information
+ * @returns {NetworkInfo} The network information
+ */
+const getNetworkInfo = (): NetworkInfo => {
+ const nets = networkInterfaces()
+
+ for (const name of Object.keys(nets)) {
+ for (const net of nets[name] ?? []) {
+ // Skip over non-IPv4 and internal addresses
+ if (net.family === 'IPv4' && !net.internal) {
+ // Return the subnet (e.g., if IP is 192.168.1.5, return 192.168.1)
+ return { subnet: net.address.split('.').slice(0, 3).join('.') }
+ }
+ }
+ }
+
+ throw new Error('No network interface found.')
+}
+
+/**
+ * Setup the network service
+ */
+export const setupNetworkService = (): void => {
+ ipcMain.handle('get-network-info', getNetworkInfo)
+}
diff --git a/src/App.vue b/src/App.vue
index fc19580ca..94af043d2 100644
--- a/src/App.vue
+++ b/src/App.vue
@@ -315,15 +315,17 @@
+