###Gitlab: Creazione repository su gitea### #Questo script passa in rassegna tutti i progetti esistenti sul gitlab aziendale e per ognuno crea un repository con indirizzo semplice /egalware/nomeProgetto.git su gitea. #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 #nome file di log $logFile = "GiteaReposCreation.log" #nome file di log old $oldLogFile = "GiteaReposCreation.old" #creazione folder di Log se non esiste CheckLogFolder #rotazione vecchio logFile da .log a .old se esiste RotateOldLog #gitea di destinazione #$target = "steamware" #$target = "nembro" $target = "azzano" if ($target -eq "steamware"){ #destinazione mirror per gitea Steamw $giteaDestination = $giteaSteamw #nome utente gitea Steamw che effettua i mirror push $giteaUser = $giteaSteamwUser #autenticazione replica gitea Steamw $giteaPass = $giteaSteamwPass #access token per autenticazione gitea Steamw da profilo replica $giteaHead = $giteaSteamwHead } if ($target -eq "nembro") { #destinazione mirror per gitea nembro $giteaDestination = $giteaNembro #nome utente gitea nembro che effettua i mirror push $giteaUser = $giteaNembroUser #autenticazione replica gitea nembro $giteaPass = $giteaNembroPass #access token per autenticazione gitea nembro da profilo replica $giteaHead = $giteaNembroHead } if ($target -eq "azzano") { #destinazione mirror per gitea azzano $giteaDestination = $giteaAzzano #nome utente gitea azzano che effettua i mirror push $giteaUser = $giteaAzzanoUser #autenticazione replica gitea nemazzanobro $giteaPass = $giteaAzzanoPass #access token per autenticazione gitea azzano da profilo replica $giteaHead = $giteaAzzanoHead } #scrivo intestazione e inizio analisi WriteLogOutput $logFile 0 "--------------------" Switch ($logLevel) { 0 { WriteLogOutput $logFile 0 "LOG SINTETICO GITEA" } 1 { WriteLogOutput $logFile 0 "LOG ERRORI GITEA" } 2 { WriteLogOutput $logFile 0 "LOG FULL GITEA" } 3 { WriteLogOutput $logFile 0 "LOG AMPOLLOSO GITEA" } } 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 startProj a endProj for ($projectCount = $startProj; $projectCount -le $endProj; $projectCount++){ $callGitlabUrl = "https://gitlab.steamware.net/api/v4/projects/" + $projectCount try { $gitlabResponse = Invoke-WebRequest -URI $callGitlabUrl -Headers $gitlabHead -ContentType "application/json" -UseBasicParsing $parsedGitlabResponse = $gitlabResponse.Content | ConvertFrom-Json #scrivo il numero del progetto nel terminale e su file WriteLogOutput $logFile 1 "" WriteLogOutput $logFile 1 "--------------------" WriteLogOutput $logFile 1 "**PROGETTO $projectCount**" foreach ($gitlabItem in $parsedGitlabResponse) { WriteLogOutput $logFile 1 "Gitlab Project Name: $($gitlabItem.name)" $callGiteaUrl = "https://" + $giteaDestination + "/api/v1/orgs/Egalware/repos" #dichiaro un body da convertire in JSON con il nome del repo da creare (prendo path o name a seconda delle necessità) $giteaBody = @{ name = $($gitlabItem.path); #name = $($gitlabItem.name); } # Converting my hash to json format $GiteaJSON = $giteaBody | ConvertTo-Json try { $giteaResponse = Invoke-WebRequest -URI $callGiteaUrl -Method POST -Headers $giteaHead -ContentType "application/json" -Body $GiteaJSON $parsedGiteaResponse = $giteaResponse.Content | ConvertFrom-Json foreach ($giteaItem in $parsedGiteaResponse) { WriteLogOutput $logFile 1 "Gitea New Project Name: $($giteaItem.name)" WriteLogOutput $logFile 1 "Status: $($giteaResponse.StatusDescription)" WriteLogOutput $logFile 1 "When: $($giteaItem.created_at)" } } catch { $parsedError = $_ | ConvertFrom-Json WriteLogOutput $logFile 3 $($parsedError.message) } } } #scrivo se trovo un errore durante il try/catch catch { $parsedError = $_ | ConvertFrom-Json WriteLogOutput $logFile 3 "" WriteLogOutput $logFile 3 "--------------------" WriteLogOutput $logFile 3 "**ERRORE NEL PROGETTO $projectCount**" 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 "Fine Esecuzione Script: $endTime" WriteLogOutput $logFile 0 "" WriteLogOutput $logFile 0 "Durata Esecuzione Script: $durataScript secondi" WriteLogOutput $logFile 0 ""