Delphi DLL
Delphi DLL
_LANGUAGE_ JCC Payment Systems - Get a User's Credential IDs for CSC
See more JCC Cyprus Examples
Demonstrates how to find the credential ids for a given user to be used with remote signing via the CSC (Cloud Signature Consortium) API.Note: This example requires Chilkat v10.0.2 or greater.
Chilkat Delphi DLL Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Cert, JsonObject;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
jsonCsc: HCkJsonObject;
cert: HCkCert;
i: Integer;
numIds: Integer;
cred_id: PWideChar;
begin
success := False;
// Provide information about the CSC service and our user ID and client credentials.
jsonCsc := CkJsonObject_Create();
CkJsonObject_UpdateString(jsonCsc,'service','CSC');
CkJsonObject_UpdateString(jsonCsc,'baseUrl','https://ras-test.jcc.com.cy/adss/service/ras/csc/v1/');
CkJsonObject_UpdateString(jsonCsc,'userId','YOUR_USER_ID');
CkJsonObject_UpdateString(jsonCsc,'clientId','YOUR_CLIENT_ID');
CkJsonObject_UpdateString(jsonCsc,'clientSecret','YOUR_CLIENT_SECRET');
// The call to SetCloudSigner will do the following internally:
// 1) Calls the "info" endpoint to get information about the remote service and the list of the API methods it supports.
// 2) Calls the "oauth2/token" endpoint to get the OAuth2 authorization token via client credentials (using the clientId and clientSecret).
// 3) Calls the "credentials/list" endpoint to get the list of credentials associated with the userId.
// 4) Calls the "credentials/info" endpoint to retrieve the credential and return the main identity information
// and the public key certificate or the certificate chain associated to it.
// The Chilkat certificate object is loaded with the retrieved certificate.
// The jsonCsc is updated with the information returned from each of the above calls.
cert := CkCert_Create();
success := CkCert_SetCloudSigner(cert,jsonCsc);
if (success = False) then
begin
Memo1.Lines.Add(CkCert__lastErrorText(cert));
Exit;
end;
CkJsonObject_putEmitCompact(jsonCsc,False);
Memo1.Lines.Add(CkJsonObject__emit(jsonCsc));
// We can do the following to get the credential IDs
i := 0;
numIds := CkJsonObject_SizeOfArray(jsonCsc,'credentials_list.credentialIDs');
while i < numIds do
begin
CkJsonObject_putI(jsonCsc,i);
cred_id := CkJsonObject__stringOf(jsonCsc,'credentials_list.credentialIDs[i]');
Memo1.Lines.Add('Credential ID: ' + cred_id);
i := i + 1;
end;
CkJsonObject_Dispose(jsonCsc);
CkCert_Dispose(cert);
end;