###Gitlab: forzo push verso i mirror dei singoli progetti### #Questo script passa in rassegna tutti i progetti esistenti sul gitlab aziendale e per ognuno verifica lo stato dei mirror, poi forza il push di tutti. #importo file contenente configurazioni . .\ApiGit\ApiGitResources\ApiScriptsConfig.ps1 #importo file contenente funzioni . .\ApiGit\ApiGitResources\ApiScriptsFunctions.ps1 #rilevo time per log inizio analisi $startTime = (Get-Date).toString("yyyy/MM/dd HH:mm:ss") # avvio stopwatch $mainStopWatch = [system.diagnostics.stopwatch]::StartNew() #contatore ciclo do while $startProj = 1 #numero massimo di progetti da analizzare $endProj = 300 #conteggio progetti trovati $existingProjects = 0 #contatore mirror trovati $mirrorCount = 0 #nome file di log $logFile = "GitlabForcePushMirror.log" #nome file di log old $oldLogFile = "GitlabForcePushMirror.old" #creazione folder di Log se non esiste CheckLogFolder #rotazione vecchio logFile da .log a .old se esiste RotateOldLog #scrivo intestazione e inizio analisi WriteLogOutput $logFile 0 "--------------------" Switch ($logLevel) { 0 { WriteLogOutput $logFile 0 "LOG SINTETICO GITLAB FORCE PUSH MIRROR" } 1 { WriteLogOutput $logFile 0 "LOG ERRORI GITLAB FORCE PUSH MIRROR" } 2 { WriteLogOutput $logFile 0 "LOG FULL GITLAB FORCE PUSH MIRROR" } 3 { WriteLogOutput $logFile 0 "LOG AMPOLLOSO GITLAB FORCE PUSH MIRROR" } } WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "Percorso log: $logFolder" WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "Inizio Esecuzione Script: $startTime" #ciclo principale for che cicla da 1 a N projectNumber for ($projectCount = $startProj; $projectCount -le $endProj; $projectCount++) { #chiamata api che restituisce informazioni sullo stato dei mirror $callUrl = "https://gitlab.steamware.net/api/v4/projects/" + $projectCount + "/remote_mirrors" WriteLogOutput $logFile 1 "" WriteLogOutput $logFile 1 "--------------------" WriteLogOutput $logFile 1 "**PROGETTO $projectCount**" try { #parsing della risposta api convertita da json $Response = Invoke-WebRequest -URI $callUrl -Headers $gitlabHead -ContentType "application/json" -UseBasicParsing $parsedResponse = $Response.Content | ConvertFrom-Json #per ogni mirror forzo il push foreach ($item in $parsedResponse) { #compongo URL per chiamata POST per forzare PUSH $callUrlForcePush = "https://gitlab.steamware.net/api/v4/projects/" + $projectCount + "/remote_mirrors/" + $item.id + "/sync" $PushResponse = Invoke-WebRequest -URI $callUrlForcePush -Method POST -Headers $gitlabHead -ContentType "application/json" -UseBasicParsing if ($PushResponse.StatusCode -eq 204){ WriteLogOutput $logFile 0 $("Mirror Push: Success - " + $item.url) } else { WriteLogOutput $logFile 0 $("Mirror Push: Unknown - " + $item.url) } $mirrorCount = $mirrorCount + 1 } $existingProjects = $existingProjects + 1 } #scrivo se trovo un errore durante il try/catch catch { $parsedError = $_ | ConvertFrom-Json WriteLogOutput $logFile 3 $($parsedError.message) } } #fine ciclo principale # fermo stopwatch e calcolo durata script $mainStopWatch.Stop() $durataScript = $mainStopWatch.Elapsed.TotalSeconds #rilevo time per log fine analisi $endTime = (Get-Date).toString("yyyy/MM/dd HH:mm:ss") #scrivo a video le statistiche WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "PROGETTI ANALIZZATI: $existingProjects" WriteLogOutput $logFile 0 "MIRRORING TOTALI: $mirrorCount" WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "Fine Esecuzione Script: $endTime" WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "Durata Esecuzione Script: $durataScript secondi" WriteLogOutput $logFile 0 ""