diklabu-Seafile.psm1
$global:sftoken <# .Synopsis Anmelden an Seafile .DESCRIPTION Anmelden an Seafile .EXAMPLE login-Seafile -url http://localhost:8000 -credentails (get-cretendials admin) #> function Login-Seafile { [CmdletBinding()] Param ( # URL des Moodle Systems [Parameter(Position=0)] [String]$url, # Credentials f. das Moodle Systems [Parameter(Position=1)] [PSCredential]$credential ) Begin { if (-not $url -or -not $credential) { if ($Global:logins["seafile"]) { $url=$Global:logins["seafile"].location; $password = $Global:logins["seafile"].password | ConvertTo-SecureString -Key $global:keys $credential = New-Object System.Management.Automation.PsCredential($Global:logins["seafile"].user,$password) } else { Write-Error "Bitte url und credentials angeben!" return; } } $base=$url $url = $url+"api2/auth-token/" $data=echo "" | Select-Object -Property "username","password" $data.username=$credential.userName $data.password=$credential.GetNetworkCredential().Password $out="username=$($data.username)&password=$($data.password)" $r=Invoke-RestMethod -Method POST -Uri $url -Body $out if ($r.token) { Write-Verbose "Login erfolgreich" $global:seafile=$base } else { Write-Verbose "Login fehlgeschlagen" } Set-Keystore -key "seafile" -server $base -credential $credential $global:sftoken=$r.token $r } } <# .Synopsis Abfrage des Seafile Servers .DESCRIPTION Abfrage des Seafile Servers .EXAMPLE get-Seafile #> function Get-Seafile { [CmdletBinding()] Param ( ) Begin { $Global:logins["seafile"] } } <# .Synopsis Neue Gruppen anlegen .DESCRIPTION Neue Gruppen anlegen .EXAMPLE New-SFGroup -name Test Legt eine neue Gruppe mit dem Namen Test an! .EXAMPLE "Test","Test2" | New-SFGroup Legt eine neue Gruppen mit den Namen Test und Test2 an! #> function New-SFGroup { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$name, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="Token "+$global:sftoken; } Process { $body="name=$name" $url = $global:seafile+"api/v2.1/groups/" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll eine neue Gruppe mit dem Namen $name angelegt werden? (J/N)" if ($q -ne "J") { return } } $r=Invoke-RestMethod -Method POST -Body $body -Uri $url -Headers $headers Write-Verbose "Erzeuge neue Gruppe mit dem Namen $name" $r } else { Write-Verbose "Würde neue Gruppe mit dem Namen $name erzeugen" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ if ($errorcode -eq 400) { Write-Error "400: Die Gruppe mit dem Namen $name existiert bereits"; } else { Write-Error $_ } } } } <# .Synopsis Gruppen abfragen .DESCRIPTION Gruppen abfragen .EXAMPLE Get-SFGroups #> function Get-SFGroups { [CmdletBinding()] Param ( [Parameter(Position=0)] [int]$perPage=100 ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["Authorization"]="TOKEN "+$global:sftoken; $url = $global:seafile+"api/v2.1/groups/?page=1&per_page=$perPage" $r=Invoke-RestMethod -Method GET -Uri $url -Headers $headers Write-Verbose "Abfrage alles SF Gruppen" $r } } <# .Synopsis Gruppen löschen .DESCRIPTION Gruppen in Seafile löschen .EXAMPLE Delete-SFGroup -id 1 Löscht die Gruppe mit der ID 1 .EXAMPLE 1,2,3 | Delete-SFGroup Löscht die Gruppen mit denb IDs 1,2,3 #> function Delete-SFGroup { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [int]$id, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"api/v2.1/groups/$id/" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll die SF Gruppe mit ID $id gelöscht werden? (J/N)?" if ($q -ne "J") { return } } $r=Invoke-RestMethod -Method DELETE -Uri $url -Headers $headers Write-Verbose "Lösche Gruppe mit ID $id" $r } else { Write-Verbose "Würde Gruppe mit ID $id löschen" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ if ($errorcode -eq 400) { Write-Error "400: Die Gruppe mit der ID $id existiert nicht"; } elseif ($errorcode -eq 404) { Write-Error "404: Die Gruppe mit der ID $id existiert nicht"; } elseif ($errorcode -eq 403) { Write-Error "403: Die Gruppe mit der ID $id kann nicht gelöscht werden"; } else { Write-Error $_ } } } } <# .Synopsis Benutzer zu einer Gruppe hinzufügen .DESCRIPTION Fügt Benutzer zu einer Seafile Gruppe hinzu .EXAMPLE Add-SFGroupmember -email tuttas@mmbbs.de -id 1 Fügt den Benutzer tuttas@mmbbs.de der Gruppe mit der ID 1 hinzu .EXAMPLE "tuttas@mmbbs.de","kemmries@mmbbs.de" | Add-SFGroupmember -id 1 Fügt die Benutzer der Gruppe mit der ID 1 hinzu #> function Add-SFGroupmember { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$email, [Parameter(Mandatory=$true,ValueFromPipelineByPropertyName=$true,Position=1)] [int]$id, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"api/v2.1/groups/$id/members/" $body="email=$email" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll Benutzer $email zur Gruppe mit ID $id hinzugefügt werden? (J/N)" if ($q -ne "J") { return } } $r=Invoke-RestMethod -Method POST -Uri $url -Body $body -Headers $headers Write-Verbose "Füge $email zur Gruppe mit ID $id hinzu" $r } else { Write-Verbose "Würde $email zur Gruppe mit ID $id hinzufügen!" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ if ($errorcode -eq 400) { Write-Error "400: Die Gruppe mit der ID $id existiert nicht, oder Benutzer mit EMail $email nicht gefunden, oder ist bereits in der Gruppe"; } elseif ($errorcode -eq 403) { Write-Error "403: Nur Administratoren können Gruppenmitglieder hinzufügen"; } elseif ($errorcode -eq 404) { Write-Error "404: Die Gruppe mit der ID $id existiert nicht, oder Benutzer mit EMail $email nicht gefunden"; } else { Write-Error $_ } } } } <# .Synopsis Benutzer aus einer Gruppe entfernen .DESCRIPTION Entfernt einen Benutzer aus einer Seafile Gruppe .EXAMPLE Remove-SFGroupmember -email tuttas@mmbbs.de -id 1 Löscht den Benutzer tuttas@mmbbs.de aus der Gruppe mit der ID 1 .EXAMPLE "tuttas@mmbbs.de","kemmries@mmbbs.de" | Remove-SFGroupmember -id 1 Löscht die Benutzer aus der Gruppe mit der ID 1 #> function Remove-SFGroupmember { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$email, [Parameter(Mandatory=$true,ValueFromPipelineByPropertyName=$true,Position=1)] [int]$id, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"/api/v2.1/groups/$id/members/$email/" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll Benutzer $email aus der Gruppe mit der ID $id entfernt werden? (J/N)" if ($q -ne "J") { return; } } $r=Invoke-RestMethod -Method DELETE -Uri $url -Headers $headers Write-Verbose "Lösche $email aus Gruppe mit ID = $id" $r } else { Write-Verbose "Würde $email aus Gruppe mit ID = $id entfernen!" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ if ($errorcode -eq 400) { Write-Error "400: Die Gruppe mit der ID $id existiert nicht, oder Benutzer mit EMail $email nicht gefunden"; } elseif ($errorcode -eq 403) { Write-Error "403: Nur Administratoren können Gruppenmitglieder hinzufügen"; $_ } elseif ($errorcode -eq 404) { Write-Error "400: Die Gruppe mit der ID $id existiert nicht"; } else { Write-Error $_ } } } } <# .Synopsis Benutzer eine Gruppe anzeigen .DESCRIPTION Zeigt die Seafile Benutzer in einer Gruppe an .EXAMPLE Get-SFGroupmember -id 1 Zeit die Mitglieder der Gruppe mit der ID 1 .EXAMPLE 1,2 | Get-SFGroupmember Zeit die Mitglieder der Gruppe mit den IDs 1 u. 2 #> function Get-SFGroupmember { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0, ParameterSetName='byId')] [int]$id, [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0, ParameterSetName='byName')] [string]$KName ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { if ($KName) { $gr = Get-SFGroups | Where-Object {$_.name -eq $KName} if (!$gr) { Write-Warning "Kann die Klasse $KName nicht im SF finden !" } else { $id=$gr.id } } $url = $global:seafile+"/api/v2.1/groups/$id/members/" try { $r=Invoke-RestMethod -Method GET -Uri $url -Headers $headers Write-Verbose "Abfrage der Gruppenmitglieder der Gruppe ID=$id" $r } catch { $errorcode = $_.Exception.Response.StatusCode.value__ if ($errorcode -eq 404) { Write-Error "404: Die Gruppe mit der ID $id existiert nicht!"; } else { Write-Error $_ } } } } <# .Synopsis Neuen Seafile Benutzer anlegen .DESCRIPTION Legt einen neuen Seafile Benutzer an .EXAMPLE New-SFUser -email s3@mmbbs.de -password mmbbs Legt einen neuen Benutzer mit der EMail Adresse s3@mmbbs.de und dem Kennwort mmbbs an! .EXAMPLE "s3@mmbbs.de","s4@mmbbs.de" | New-SFUser -password mmbbs Legt die genannten Benutzer mit der EMAIL Adressen an und vergibt das Kennwort "mmbbs" #> function New-SFUser { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$email, [Parameter(Mandatory=$true,ValueFromPipelineByPropertyName=$true,Position=1)] [String]$password, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"/api2/accounts/$email/" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll neuer Benutzer mit EMail $email angelegt werden? (J/N)" if ($q -ne "J") { return; } } $body = "password=$password" $r=Invoke-RestMethod -Method PUT -Body $body -Uri $url -Headers $headers Write-Verbose "Erzeuge neuen User $email und dem Kennwoprt $password" $r } else { Write-Verbose "Würde neuen User $email und dem Kennwoprt $password erzeugen" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ Write-Error $_ } } } <# .Synopsis Seafile Benutzer löschen .DESCRIPTION Löscht einen Seafile Benutzer .EXAMPLE Delete-SFUser -email s3@mmbbs.de Löscht Benutzer mit der EMail Adresse s3@mmbbs.de ! .EXAMPLE "s3@mmbbs.de","s4@mmbbs.de" | Delete-SFUser Löscht die genannten Benutzer mit der EMAIL Adressen #> function Delete-SFUser { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$email, [switch]$force, [switch]$whatif ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"/api2/accounts/$email/" try { if (-not $whatif) { if (-not $force) { $q = Read-Host "Soll neuer Benutzer mit EMail $email angelegt werden? (J/N)" if ($q -ne "J") { return; } } $r=Invoke-RestMethod -Method DELETE -Uri $url -Headers $headers Write-Verbose "Lösche User $email !" $r } else { Write-Verbose "Würde User $email löschen" } } catch { $errorcode = $_.Exception.Response.StatusCode.value__ Write-Error $_ } } } <# .Synopsis Zeigt die Seafile Benutzer an .DESCRIPTION Zeigt alle Seafile Benutzer an .EXAMPLE Get-SFUsers Zeigt die Seafile Benutzer an #> function Get-SFUsers { [CmdletBinding()] Param ( [Parameter(Position=0)] [int]$start=-1, [Parameter(Position=1)] [int]$limit=-1, [Parameter(Position=2)] [ValidateSet('LDAP','DB','LDAPImport')] [String]$scope ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; $url = $global:seafile+"/api2/accounts/" $url+="?start=$start&limit=$limit" if ($scope) { $url+="&scope=$scope" } try { $r=Invoke-RestMethod -Method GET -Uri $url -Headers $headers Write-Verbose "Abfrage aller Seafilebenutzer" $r } catch { $null } } } <# .Synopsis Zeigt Informationen zu einem User .DESCRIPTION Zeigt Informationen zu einem User .EXAMPLE Get-SFUser -email tuttas@mmbbs.de Zeigt die Informationen zum SF User tuttas@mmbbs.de an .EXAMPLE "tuttas@mmbbs.de","kemmries@mmbbs.de" | Get-SFUser Zeigt die Informationen zu den SF User tuttas@mmbbs.de und kemmries@mmbbs.de an #> function Get-SFUser { [CmdletBinding()] Param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,ValueFromPipelineByPropertyName=$true,Position=0)] [String]$email ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" return } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; } Process { $url = $global:seafile+"api2/accounts/$email/" try { $r=Invoke-RestMethod -Method GET -Uri $url -Headers $headers Write-Verbose "Abfrage des Seafilebenutzers $email" $r } catch { $null } } } <# .Synopsis Synchonisiert die Seafilebenutzer mit einer Gruppe .DESCRIPTION Synchronisiert die Seafile Benutzer mit der Gruppe, d.h. Wenn Benutzer bereits in der Gruppe ist wird nichts unternommen. Ist der Benutzer nicht in der , wird er eingetragen. Benutzer die in der Gruppe sind, jedoch nicht hinzugefügt wurden, werden gelöscht. .EXAMPLE Sync-SFGroupMenber -groupid 12 -usermails tuttas@mmbbs.de,hecht@mmbbs.de Die Gruppe mit der ID 12 enthält die Benutzer tuttas und hecht .EXAMPLE "tuttas@mmbbs.de","hecht@mmbbs.de" | Sync-SFGroupMember -groupid 9 Die Gruppe mit der ID 9 enthält die Benutzer tuttas und hecht #> function Sync-SFGroupMember { [CmdletBinding()] Param ( # Group ID [Parameter(Mandatory=$true, Position=0, ParameterSetName='byId')] [int]$groupid, # Group Name [Parameter(Mandatory=$true, Position=0, ParameterSetName='byName')] [String]$KName, # ID der Benutzers [Parameter(Mandatory=$true, ValueFromPipeLine=$true, ValueFromPipelineByPropertyName=$true, Position=1)] [alias("EMAIL")] [String[]]$usermails, [switch]$force, [switch]$whatif, # Benutzer die nicht gefunden werden, werden angelegt [switch]$createUsers=$false, # Default Password, [string]$password="mmbbs" ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" break; } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; if ($KName) { $gr = Get-SFGroups | Where-Object {$_.name -eq $KName} $groupid=$gr.id } try { $members= Get-SFGroupmember -id $groupid | where-Object {-not $_.is_admin}| Select-Object -Property email | Get-SFUser $istMember = @{}; foreach ($m in $members) { $istMember[$m.email]=$m } } catch { Write-Error "$($_.Exception.GetType().FullName) $($_.Exception.Message)" break; } } Process { $usermails | ForEach-Object { Start-Sleep -Milliseconds 500 $usermail = $_ if ($istMember[$usermail]) { Write-Verbose "Der Benutzer mit der Email $usermail befindet sich bereits in der Gruppe mit der ID $groupid" $istMember.Remove($usermail) } else { $user= Get-SFUser -email $usermail if (!$user) { Write-Verbose "Der Benutzer mit der EMail $usermail existiert nicht im Seafile System"; if ($createUsers) { if (!$force) { $q=Read-Host "Soll der Benutzer $usermail angelegt werden? (J/N)"; if ($q -eq "J") { $user=New-SFUser -email $usermail -password $password -force:$force } } else { Write-Verbose "Der Benutzer mit der EMail $usermail wird im Seafile System angelegt"; $user=New-SFUser -email $usermail -password $password -force:$force } } } if (!$force -and $user) { $q=Read-Host "Soll der Benutzer mit der EMail $usermail in die Gruppe mit der ID $groupid aufgenommen werden? (J/N)" if ($q -eq "J") { Write-Verbose "Benutzer mit EMail $usermail wird in Gruppe mit ID $groupid aufgenommen" $r=Add-SFGroupmember -email $usermail -id $groupid -force } } elseif ($user) { Write-Verbose "Benutzer mit EMail $usermail wird in Gruppe mit ID $groupid aufgenommen" $r=Add-SFGroupmember -email $usermail -id $groupid -force } } } } End { if (!$whatif) { if ($istMember.Count -ne 0) { if ($force) { $r=$istMember.Values | Remove-SFGroupmember -id $groupid -force } else { $r=$istMember.Values | Remove-SFGroupmember -id $groupid } } } } } <# .Synopsis Synchonisiert die Seafile Gruppen .DESCRIPTION Synchronisiert die Seafile Gruppe, d.h. Wenn eine Gruppe nicht existiert wird diese angeleght. Wenn eine Gruppe existiert, aber nicht mehr benötigt wird, wird diese gelöscht .EXAMPLE Sync-SFGroups -groups FIAE17J,FIAE17K Die Gruppen FIAE17J und FIAE17K werden angelegt, falls sie nicht bereits existierem, alle anderen Gruppen werden gelöscht .EXAMPLE "FIAE17J,FIAE17K" | Sync-SFGroupMember -nodelete Die Gruppen FIAE17J und FIAE17K werden angelegt, falls sie nicht bereits existierem, alle anderen Gruppen bleiben erhalten #> function Sync-SFGroups { [CmdletBinding()] Param ( # LIste mit Gruppennamen [Parameter(Mandatory=$true, ValueFromPipeLine=$true, ValueFromPipelineByPropertyName=$true, Position=0)] [alias("KName")] [String[]]$groups, [switch]$force, [switch]$whatif, [switch]$nodelete ) Begin { if (-not $global:sftoken) { Write-Error "Sie sind nicht an Seafile angemeldet, veruchen Sie es mit Login-Seafile" break; } $headers=@{} $headers["content-Type"]="application/x-www-form-urlencoded" $headers["Authorization"]="TOKEN "+$global:sftoken; try { $ist= Get-SFGroups $istGroups = @{}; foreach ($m in $ist) { $istGroups[$m.id]=$m } } catch { Write-Error "$($_.Exception.GetType().FullName) $($_.Exception.Message)" break; } } Process { $groups | ForEach-Object { Start-Sleep -Milliseconds 300 $group=$_ Write-Verbose "Bearbeite gruppe $group" $gr=$istGroups.Keys | % { if ($istGroups.Item($_).name -eq $group) {$istGroups.Item($_)} } if ($gr){ Write-Verbose "Die Gruppe $($gr.name) existiert bereits in Seafile mit der ID $($gr.id)" $istGroups.Remove($gr.id); } else { Write-Verbose "Die Gruppe $group existiert noch nicht in Seafile und wird dort angelegt !" $g=New-SFGroup -name $group -force:$force } } } End { if (!$whatif) { if (!$nodelete) { Write-Verbose "Lösche Gruppen die nicht in der Soll-Liste enthalten sind" if ($istGroups.Count -ne 0) { $istGroups.Keys | % { if (-not $force) { $q = Read-Host "Soll die Gruppe $($istGroups.Item($_).name) mit der id $($istGroups.Item($_).id) aus Seafile gelöscht werden? (J/N)" if ($q -eq "J") { $r=Delete-SFGroup -id $($istGroups.Item($_).id) -force } } else { $r=Delete-SFGroup -id $($istGroups.Item($_).id) -force Write-Verbose "Lösche die Gruppe $($istGroups.Item($_).name) mit der id $($istGroups.Item($_).id) aus Seafile!" } } } } } } } |