# Requires -Modules @{ModuleName='Microsoft.Graph.Applications';ModuleVersion='1.19.0'}, @{ModuleName='Microsoft.Graph.Mail';ModuleVersion='1.19.0'} # ============================================================================== # KONFIGURÁCIÓ # ============================================================================== # Adatok az Azure App Regisztrációból # Tennant ID : caee3499-03f8-4175-9fa8-a935248d0ece $TENANT_ID = "caee3499-03f8-4175-9fa8-a935248d0ece" # Client Id : 3a08b279-1fc3-419f-a77e-31f12a0f65f7 $CLIENT_ID = "3a08b279-1fc3-419f-a77e-31f12a0f65f7" # Key : Rk-8Q~nJ.sZ-xUiNxtEDdzVgoFFosODLVHX~jdrh (érték, nem Secret ID) $CLIENT_SECRET = "Rk-8Q~nJ.sZ-xUiNxtEDdzVgoFFosODLVHX~jdrh" # Figyelt postafiók $USER_EMAIL = "i.meszely@aps-hh.de" # Microsoft Graph API végpontok (alapértelmezett, nem kell módosítani) $GRAPH_API_ENDPOINT = "https://graph.microsoft.com/v1.0" # Scopes needed for the application # Mail.ReadWrite for reading, marking as read, and eventually moving emails $SCOPES = @("Mail.ReadWrite") # ============================================================================== # FÜGGVÉNYEK # ============================================================================== Function Connect-GraphAPI { <# .SYNOPSIS Csatlakozik a Microsoft Graph API-hoz kliens hitelesítő adatokkal. .DESCRIPTION Ez a függvény megpróbál csatlakozni a Microsoft Graph API-hoz az Azure AD alkalmazás regisztrációjában megadott kliens hitelesítő adatok (Tenant ID, Client ID, Client Secret) segítségével. Sikeres kapcsolat esetén egy Access Token-t ad vissza. Hiba esetén null-t ad vissza és hibaüzenetet ír ki. .OUTPUTS Access Token (String) vagy $null #> [CmdletBinding()] Param() Write-Host "Graph API-hoz való csatlakozás megkezdése..." -ForegroundColor Cyan try { # Ellenőrizzük, hogy a szükséges modulok telepítve vannak-e $requiredModules = @("Microsoft.Graph.Applications", "Microsoft.Graph.Mail") foreach ($module in $requiredModules) { if (-not (Get-Module -ListAvailable -Name $module)) { Write-Warning "A(z) '$module' PowerShell modul nincs telepítve. Kérjük telepítse futtatás előtt: Install-Module $module" return $null } } # Csatlakozás a Graph API-hoz kliens hitelesítő adatokkal # A -Scopes paraméterben az alkalmazásengedélyek neveit kell megadni $connectResult = Connect-MgGraph -TenantId $TENANT_ID -ClientId $CLIENT_ID -ClientSecret $CLIENT_SECRET -Scopes $SCOPES -ErrorAction Stop if ($connectResult) { Write-Host "Sikeresen csatlakozott a Graph API-hoz." -ForegroundColor Green # Lekérjük az Access Token-t $token = (Get-MsalToken).AccessToken return $token } else { Write-Error "Nem sikerült csatlakozni a Graph API-hoz." return $null } } catch { Write-Error "Hiba történt a Graph API-hoz való csatlakozás során: $($_.Exception.Message)" Write-Host "Kérjük, ellenőrizze a konfigurációs beállításokat (TENANT_ID, CLIENT_ID, CLIENT_SECRET) és az alkalmazásengedélyeket az Azure AD-ben." -ForegroundColor Yellow return $null } } # ============================================================================== # FŐ LOGIKA # ============================================================================== function Main { $accessToken = Connect-GraphAPI if (-not $accessToken) { Write-Error "Nem sikerült Access Token-t szerezni. Kilépés." return } Write-Host "Access Token sikeresen lekérve. Kész a Graph API hívásokhoz." -ForegroundColor Green # Itt fogjuk később implementálni az e-mailek feldolgozását } # Fő függvény meghívása Main