PowerShell-Skriptbeispiel mit cloudlink-REST-API
Oversigt: Diese Datei dient nur zu Schulungs-/Informationszwecken. Kann als Referenz beim Schreiben von Cloudlink-Automatisierungsskripten mit PowerShell-Skriptsprache verwendet werden. Dell übernimmt keine Verantwortung für die Ausführung dieser Datei als PowerShell-Skript in der Umgebung des Dell Kunden. Das Skript zeigt eine Möglichkeit, maschinen aufzulisten, die mit Cloudlink und ihren Laufwerken über ein PowerShell-Skript mithilfe von Cloudlink RestAPI-Aufrufen registriert sind. Das Skript ändert den Status eines Systems nicht, sondern zeigt nur Informationen an. Der Zugriff auf den Cloudlink-Node (durch IP-Adresse angegeben) wird mit den Anmeldedaten eines Cloudlink-Benutzers vom Typ "Client" gewährt. ...
Denne artikel gælder for
Denne artikel gælder ikke for
Denne artikel er ikke knyttet til et bestemt produkt.
Det er ikke alle produktversioner, der er identificeret i denne artikel.
Symptomer
Das Skript kann verwendet werden, um Cloudlink-Vorgänge zu automatisieren. In diesem Beispiel listet das Skript Maschinen auf, die bei Cloudlink Center registriert sind.
Årsag
Das Skript kann für Kunden nützlich sein, die mehrere Cloudlink Center haben oder ihr Cloudlink Center mit einem PowerShell-Skript verwalten möchten.
Løsning
# Copyright Dell © 2021, 2022
# Diese Datei dient nur zu Bildungs-/Informationszwecken.
# Kann als Referenz beim Schreiben von Cloudlink-Automatisierungsskripten mit PowerShell-Skriptsprache verwendet werden.
# Dell übernimmt keine Verantwortung dafür, dass diese Datei als PowerShell-Skript in der Umgebung
des Dell Kunden ausgeführt wird# Das Skript zeigt eine Möglichkeit, maschinen aufzulisten, die mit Cloudlink und ihren Laufwerken über ein PowerShell-Skript
# mithilfe von Cloudlink RestAPI-Aufrufen registriert sind.
# Das Skript ändert den Status eines Systems nicht, sondern zeigt nur Informationen an.
# Der Zugriff auf den Cloudlink-Node (durch IP-Adresse angegeben) wird mit den Anmeldedaten eines Cloudlink-Benutzers vom Typ "Client" gewährt.
# Im folgenden Teil wird die Zertifikatvalidierung simuliert. Das Zertifikat ist immer gültig
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
if (-not ([System.Management.Automation.PSTypeName]'ServerCertificateValidationCallback'). Geben Sie)
{
$certCallback = @"
unter Verwendung des Systems ein.
mit System.Net;
unter Verwendung von System.Net.Security
mit System.Security.Cryptography.X509Certificates;
public class ServerCertificateValidationCallback
{
public static void Ignore()
{
if(ServicePointManager.ServerCertificateValidationCallback ==null)
{
ServicePointManager.ServerCertificateValidationCallback +=
delegate
(
Object obj,
X509Certificate certificate,
X509Chain-Kette,
SslPolicyErrors-Fehler
)
{
true zurückgeben;
};
}
}
}
"@
Add-Type $certCallback
}
[ServerCertificateValidationCallback]::Ignore()
$server=''
$client_id=''
$client_secret=''
if ($args[0] -ne $null)
{ $server=$args[0] }
if ($args[1] -ne $null)
{ $client_id=$args[1] }
if ($args[2] -ne $null)
{ $client_secret=$args[2] }
$serverport=$server+":443"
Write-Output "parameters: server=$server, client_id=$client_id, client_secret=$client_secret"
$responsee=Invoke-RestMethod -Uri "https://$server/cloudlink/oauth/token?grant_type=client_credentials&client_id=$client_id&client_secret=$client_secret&scope=all" -Method Get -TimeoutSec 1800
Write-Output "The response received:"
Write-Output "$responsee"
, wenn$.
responsee.access_token)
{ $mytoken=$responsee.access_token
$Type = "application/json"
$resolveSessionHeader = @{'Authorization' = "Bearer $mytoken"}
# Abfrage für die Maschinenliste
$machine_list_query='. https://$serverport/cloudlink/rest/securevm'
$machine_list=Invoke-WebRequest -Method Get -Uri $machine_list_query -Headers $resolveSessionHeader -ContentType $Type
# Listet die Rechner in der Konsole auf
Write-Host "Machine list:" Gelbes $machine_list_txt mit Farbe "Vordergrundfarbe
" = $machine_list | ConvertFrom-Json
$machine_list_txt | FT
#For jeder Maschine, listet die Laufwerke
auf ($machine in $machine_list_txt)
{
$drives_list = $($machine.resources)
Write-Host "$($machine.name) $($machine.ip_address) ($($machine.os_name)) group $($machine.group)" -VordergrundColor Yellow
$drives_list | FT
}
# Diese Datei dient nur zu Bildungs-/Informationszwecken.
# Kann als Referenz beim Schreiben von Cloudlink-Automatisierungsskripten mit PowerShell-Skriptsprache verwendet werden.
# Dell übernimmt keine Verantwortung dafür, dass diese Datei als PowerShell-Skript in der Umgebung
des Dell Kunden ausgeführt wird# Das Skript zeigt eine Möglichkeit, maschinen aufzulisten, die mit Cloudlink und ihren Laufwerken über ein PowerShell-Skript
# mithilfe von Cloudlink RestAPI-Aufrufen registriert sind.
# Das Skript ändert den Status eines Systems nicht, sondern zeigt nur Informationen an.
# Der Zugriff auf den Cloudlink-Node (durch IP-Adresse angegeben) wird mit den Anmeldedaten eines Cloudlink-Benutzers vom Typ "Client" gewährt.
# Im folgenden Teil wird die Zertifikatvalidierung simuliert. Das Zertifikat ist immer gültig
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
if (-not ([System.Management.Automation.PSTypeName]'ServerCertificateValidationCallback'). Geben Sie)
{
$certCallback = @"
unter Verwendung des Systems ein.
mit System.Net;
unter Verwendung von System.Net.Security
mit System.Security.Cryptography.X509Certificates;
public class ServerCertificateValidationCallback
{
public static void Ignore()
{
if(ServicePointManager.ServerCertificateValidationCallback ==null)
{
ServicePointManager.ServerCertificateValidationCallback +=
delegate
(
Object obj,
X509Certificate certificate,
X509Chain-Kette,
SslPolicyErrors-Fehler
)
{
true zurückgeben;
};
}
}
}
"@
Add-Type $certCallback
}
[ServerCertificateValidationCallback]::Ignore()
$server=''
$client_id=''
$client_secret=''
if ($args[0] -ne $null)
{ $server=$args[0] }
if ($args[1] -ne $null)
{ $client_id=$args[1] }
if ($args[2] -ne $null)
{ $client_secret=$args[2] }
$serverport=$server+":443"
Write-Output "parameters: server=$server, client_id=$client_id, client_secret=$client_secret"
$responsee=Invoke-RestMethod -Uri "https://$server/cloudlink/oauth/token?grant_type=client_credentials&client_id=$client_id&client_secret=$client_secret&scope=all" -Method Get -TimeoutSec 1800
Write-Output "The response received:"
Write-Output "$responsee"
, wenn$.
responsee.access_token)
{ $mytoken=$responsee.access_token
$Type = "application/json"
$resolveSessionHeader = @{'Authorization' = "Bearer $mytoken"}
# Abfrage für die Maschinenliste
$machine_list_query='. https://$serverport/cloudlink/rest/securevm'
$machine_list=Invoke-WebRequest -Method Get -Uri $machine_list_query -Headers $resolveSessionHeader -ContentType $Type
# Listet die Rechner in der Konsole auf
Write-Host "Machine list:" Gelbes $machine_list_txt mit Farbe "Vordergrundfarbe
" = $machine_list | ConvertFrom-Json
$machine_list_txt | FT
#For jeder Maschine, listet die Laufwerke
auf ($machine in $machine_list_txt)
{
$drives_list = $($machine.resources)
Write-Host "$($machine.name) $($machine.ip_address) ($($machine.os_name)) group $($machine.group)" -VordergrundColor Yellow
$drives_list | FT
}
Berørte produkter
CloudLink SecureVM, CloudLinkArtikelegenskaber
Artikelnummer: 000202396
Artikeltype: Solution
Senest ændret: 15 maj 2026
Version: 6
Find svar på dine spørgsmål fra andre Dell-brugere
Supportservices
Kontrollér, om din enhed er dækket af supportservices.