Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Netzwerke (https://www.delphipraxis.net/14-netzwerke/)
-   -   Delphi Clevercomponents: AccessToken ohne Browser von Azure holen (Maschine zu Maschine) (https://www.delphipraxis.net/216989-clevercomponents-accesstoken-ohne-browser-von-azure-holen-maschine-zu-maschine.html)

haentschman 2. Apr 2025 13:12


Clevercomponents: AccessToken ohne Browser von Azure holen (Maschine zu Maschine)
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallöle...8-)

Hat jemand schon mal den Modus "client_credentials" benutzt? :gruebel:

Hintergrund:
Holen des Tokens für weitere Verwendung ohne Browser...

Fehlermeldungen z.B.:


nur TokenURL:
Zitat:

---------------------------
Benachrichtigung über Debugger-Exception
---------------------------
Im Projekt SEAM.exe ist eine Exception der Klasse EclSocketError mit der Meldung 'Es konnte keine Verbindung hergestellt werden, da der Zielcomputer die Verbindung verweigerte.' aufgetreten.
---------------------------
Anhalten Fortsetzen Kopieren Hilfe
---------------------------
mit TokenURL und AuthorizeURL
Zitat:

{„error“: „invalid_client“, „error_description“: „AADSTS7000215:
Ungültiges Client-Geheimnis angegeben. Stellen Sie sicher, dass es sich bei dem in der Anfrage gesendeten Geheimnis um den Wert des Clientgeheimnisses und nicht um die Clientgeheimnis-ID handelt,
für ein zur Anwendung 'xxxxxxx-79e1-401e-b0f3-xxxxxxxxx' hinzugefügtes Geheimnis. Ablaufverfolgungs-ID: 6226643b-c9ca-4f27-8720-7b551d8b1a00
Korrelations-ID: 0394fa58-10fd-4470-8d15-6cb5ec1be327 Zeitstempel: 2025-04-02 09:16:02Z“,

„error_codes":[7000215],
„timestamp„:“2025-04-02 09:16:02Z“,
„trace_id„:“6226643b-c9ca-4f27-8720-7b551d8b1a00“,
„correlation_id„:“0394fa58-10fd-4470-8d15-6cb5ec1be327“,
„error_uri": ‚https://login.microsoftonline.com/error?code=7000215‘}
Die Werte die übergebe sollten eigentlich stimmen (Copy/Paste). Ich tippe auf falsche Parameter / URL. Oder fehlt noch was? :gruebel:

TestCode:
Delphi-Quellcode:
conAuthorizeURL = 'https://login.microsoftonline.com/%s/oauth2/v2.0/authorize';
conTokenURL = 'https://login.microsoftonline.com/%s/oauth2/v2.0/token';
conScopes = 'https://graph.microsoft.com/.default';
...
OAuth := TclOAuth.Create(nil);
try
  OAuth.AuthUrl := Format(conAuthorizeURL, [TenantID]);
// OAuth.TokenUrl := Format(conTokenURL, [TenantID]);

   OAuth.ClientID := ClientID;
   OAuth.ClientSecret := ClientSecret;
   OAuth.Scope := conScopes;
   OAuth.AuthorizationFlow := afClientCredentialsFlow; // = 'client_credentials' oder?
   OAuth.GetAuthorization;
   Result := OAuth.Token.AccessToken;
finally
  OAuth.Free;
end;
PS: Bei Clever gibt es kein Beispiel OHNE Browser.
PS: Bitte fangt nicht an die KI zu befragen... Alle Modelle (Free und Kommerziell) philosophieren! Was sie TclOAuth für Properties/Proceduren in die Version 11 packen. Unglaublich. :evil:

falsches Beispiel:
Zitat:

procedure GetAzureToken;
var
OAuth2: TclOAuth2;
Response: TclOAuth2Response;
begin
OAuth2 := TclOAuth2.Create(nil);
try
// Set your Azure AD configuration
OAuth2.ClientID := 'your-client-id';
OAuth2.ClientSecret := 'your-client-secret';
OAuth2.AuthURL := 'https://login.microsoftonline.com/your-tenant-id/oauth2/v2.0/authorize';
OAuth2.TokenURL := 'https://login.microsoftonline.com/your-tenant-id/oauth2/v2.0/token';
OAuth2.Scope := 'https://graph.microsoft.com/.default'; // Adjust scope as needed

// For client credentials flow (service-to-service)
Response := OAuth2.GetAccessToken('client_credentials');

// OR for resource owner password flow (when you have username/password)
// Response := OAuth2.GetAccessTokenByPassword('username', 'password');

if Response.ResponseCode = 200 then
begin
ShowMessage('Token obtained: ' + Response.AccessToken);
// Store token for API calls
// You can also use Response.ExpiresIn to manage token expiration
end else
begin
ShowMessage('Error: ' + Response.ErrorMessage);
end;
finally
OAuth2.Free;
end;
end;

Bbommel 2. Apr 2025 14:23

AW: Clevercomponents: AccessToken ohne Browser von Azure holen (Maschine zu Maschine)
 
Liste der Anhänge anzeigen (Anzahl: 1)
Ja, ich nutze Azure bzw. Entra ID mit dem Client-Credential-Flow. Allerdings mit den Delphi-Bordmitteln und nicht mit "Clevercomponents" (kenn ich nicht ;-) ).

Auf den ersten Blick sieht das aber bei dir ja soweit ganz gut aus. Hast du deine Anfrage mal manuell im Postman (oder einem anderen Tool) eingetragen, und bekommst du dann ein Token?

Und: bist du sicher, dass der Hinweis aus der Fehlermeldung nicht berechtigt ist und du nicht tatsächlich das eigentliche Gehemnis und die ID vom Geheimnis verwechselt hast? Passiert immer wieder, ist mir auch selbst schon passiert, deswegen haben wir das in einer Doku für Kunden und Partner auch extra betont. Hab mal einen Screenshot aus der Doku in den Anhang gepackt. Vielleicht liegt es ja doch einfach daran.

haentschman 2. Apr 2025 14:26

AW: Clevercomponents: AccessToken ohne Browser von Azure holen (Maschine zu Maschine)
 
@Bbommel: Danke.

Damit es nicht untergeht im Text...8-)

Lösung:
Fehlermeldung richtig lesen. Es war genau das was die Fehlemeldung sagte: "um den Wert des Clientgeheimnisses und nicht um die Clientgeheimnis-ID". Ich hatte den verkehrten herauskopiert. :oops:
Delphi-Quellcode:
conTokenURL = 'https://login.microsoftonline.com/%s/oauth2/v2.0/token';
conScopes = 'https://graph.microsoft.com/.default';
...
function TSecurity.GetAccessToken(Name: string): string;
var
  Security: ISecurity;
  OAuth: TclOAuth;
begin
  Result := '';

  if FSecurityDict.TryGetValue(Name, Security) then
  begin
    OAuth := TclOAuth.Create(nil);
    try
      OAuth.TokenUrl := Format(conTokenURL, [TToolsCrypt.Decrypt(Security.TenantID)]);
      OAuth.ClientID := TToolsCrypt.Decrypt(Security.ClientID);
      OAuth.ClientSecret := TToolsCrypt.Decrypt(Security.ClientSecret);
      OAuth.Scope := conScopes;
      OAuth.AuthorizationFlow := afClientCredentialsFlow;
      OAuth.GetAuthorization;

      Result := OAuth.Token.AccessToken;
    finally
      OAuth.Free;
    end;
  end;
end;
:wink:


Alle Zeitangaben in WEZ +1. Es ist jetzt 05:15 Uhr.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz