first commit
This commit is contained in:
commit
12419bda5c
3
app.log
Normal file
3
app.log
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[2025-12-04 18:33:16] [INFO] Début du script
|
||||||
|
[2025-12-04 18:33:53] [INFO] Début du script
|
||||||
|
[2025-12-04 18:33:53] [INFO] Début du script
|
||||||
55
app.ps1
Normal file
55
app.ps1
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Script de synchronisation des listes de diffusion interne vers Brevo via API
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
1- Le script récupére les groupes à synchroniser depuis le fichier groups.json
|
||||||
|
2- puis récupére les informations (courriel, prénom et nom) des membres de chaque groupe ainsi que l'ID Brevo qui
|
||||||
|
correspond au groupe AD.
|
||||||
|
3- Recuperation de la liste des membres de la liste Brevo
|
||||||
|
4- Comparaison liste Brevo - groupe AD
|
||||||
|
5- opération pour faire correspondre la liste avec le groupe Brevo (ajout, suppresion)
|
||||||
|
|
||||||
|
.NOTES
|
||||||
|
Auteur : Tristan Poiré
|
||||||
|
Date : 04/12/2025
|
||||||
|
Version : 1.0
|
||||||
|
#>
|
||||||
|
|
||||||
|
#---------------------------
|
||||||
|
# Début du script
|
||||||
|
#---------------------------
|
||||||
|
Import-Module ActiveDirectory
|
||||||
|
|
||||||
|
# Vérifie si le module ActiveDirectory est chargé
|
||||||
|
if (-not (Get-Module -ListAvailable -Name ActiveDirectory)) {
|
||||||
|
Write-Error "Le module ActiveDirectory n'est pas installé."
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
# Logging
|
||||||
|
# Définir le fichier de log globalement pour ce module
|
||||||
|
$Global:LogFile = ".\app.log"
|
||||||
|
|
||||||
|
$groupsFile = "groups.json"
|
||||||
|
$groups = Get-Content $groupsFile | ConvertFrom-Json
|
||||||
|
|
||||||
|
# Récupérer tous les fichiers .ps1 dans le dossier modules
|
||||||
|
$moduleFiles = Get-ChildItem -Path ".\modules" -Filter "*.ps1"
|
||||||
|
foreach ($file in $moduleFiles) {
|
||||||
|
. $file.FullName
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($group in $groups) {
|
||||||
|
|
||||||
|
$GetUsers = GetUsersFromGroup -GroupCN $($group.Nom)
|
||||||
|
if ($GetUsers.Success === $false)
|
||||||
|
{
|
||||||
|
Write-Output $GetUsers.Value
|
||||||
|
Write-Log $GetUsers.Value
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
Write-Output $GetUsers.Value
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
4
groups.json
Normal file
4
groups.json
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[
|
||||||
|
{ "Nom": "GR_DNA_-_Design_graphique_-_LE_HAVRE-1", "Id": "9" },
|
||||||
|
{ "Nom": "GR_DNA_-_Design_graphique_-_LE_HAVRE-2", "Id": "10" }
|
||||||
|
]
|
||||||
26
modules/AdService.ps1
Normal file
26
modules/AdService.ps1
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
function GetUsersFromGroup {
|
||||||
|
[CmdletBinding()]
|
||||||
|
param(
|
||||||
|
[Parameter(Mandatory=$true)]
|
||||||
|
[string]$GroupCN
|
||||||
|
)
|
||||||
|
|
||||||
|
try {
|
||||||
|
# Récupère les membres du groupe
|
||||||
|
$members = Get-ADGroupMember -Identity $GroupCN -Recursive | Where-Object { $_.objectClass -eq "user" }
|
||||||
|
|
||||||
|
# Retourne le SamAccountName de chaque utilisateur
|
||||||
|
$result = [PSCustomObject]@{
|
||||||
|
Success = $true
|
||||||
|
Value = $members | Select-Object -ExpandProperty SamAccountName
|
||||||
|
}
|
||||||
|
return $result
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
$result = [PSCustomObject]@{ Success = $false
|
||||||
|
Value = "Erreur lors de la récupération des utilisateurs du groupe '$GroupCN' : $_"
|
||||||
|
}
|
||||||
|
return $result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
0
modules/ApiService.ps1
Normal file
0
modules/ApiService.ps1
Normal file
36
modules/LogService.ps1
Normal file
36
modules/LogService.ps1
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
Service de logging pour les scripts PowerShell.
|
||||||
|
.DESCRIPTION
|
||||||
|
Fournit une fonction Write-Log qui logge des messages avec timestamp, niveau et fichier de log.
|
||||||
|
#>
|
||||||
|
|
||||||
|
# Définir le fichier de log globalement pour ce module
|
||||||
|
$Global:LogFile = ".\app.log"
|
||||||
|
|
||||||
|
function Write-Log {
|
||||||
|
[CmdletBinding()]
|
||||||
|
param(
|
||||||
|
[Parameter(Mandatory=$true)]
|
||||||
|
[string]$Message,
|
||||||
|
|
||||||
|
[Parameter(Mandatory=$false)]
|
||||||
|
[ValidateSet("INFO", "WARN", "ERROR")]
|
||||||
|
[string]$Level = "INFO"
|
||||||
|
)
|
||||||
|
|
||||||
|
# Timestamp
|
||||||
|
$timestamp = Get-Date -Format "yyyy-MM-dd HH:mm:ss"
|
||||||
|
$line = "[$timestamp] [$Level] $Message"
|
||||||
|
|
||||||
|
# Affiche à la console
|
||||||
|
Write-Output $line
|
||||||
|
|
||||||
|
# Écrit dans le fichier de log
|
||||||
|
try {
|
||||||
|
Add-Content -Path $Global:LogFile -Value $line
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
Write-Warning "Impossible d'écrire dans le fichier de log : $_"
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user