Delphi ActiveX
Delphi ActiveX
Amazon Cognito - Admin Update User Attributes
See more Amazon Cognito Examples
Updates the specified user's attributes, including developer attributes, as an administrator. Works on any user.For custom attributes, you must prepend the custom: prefix to the attribute name.
In addition to updating user attributes, this API can also be used to mark phone and email as verified.
Chilkat Delphi ActiveX Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
rest: TChilkatRest;
authAws: TChilkatAuthAws;
bTls: Integer;
port: Integer;
bAutoReconnect: Integer;
json: TChilkatJsonObject;
sbRequestBody: TChilkatStringBuilder;
sbResponseBody: TChilkatStringBuilder;
respStatusCode: Integer;
jsonResponse: TChilkatJsonObject;
begin
success := 0;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
rest := TChilkatRest.Create(Self);
authAws := TChilkatAuthAws.Create(Self);
authAws.AccessKey := 'AWS_ACCESS_KEY';
authAws.SecretKey := 'AWS_SECRET_KEY';
// Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
authAws.Region := 'us-west-2';
authAws.ServiceName := 'cognito-idp';
// SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
rest.SetAuthAws(authAws.ControlInterface);
// URL: https://cognito-idp.us-west-2.amazonaws.com/
bTls := 1;
port := 443;
bAutoReconnect := 1;
// Use the same region as specified above.
success := rest.Connect('cognito-idp.us-west-2.amazonaws.com',port,bTls,bAutoReconnect);
if (success <> 1) then
begin
Memo1.Lines.Add('ConnectFailReason: ' + IntToStr(rest.ConnectFailReason));
Memo1.Lines.Add(rest.LastErrorText);
Exit;
end;
// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "UserAttributes": [
// {
// "Name": "email_verified",
// "Value": "true"
// },
// {
// "Name": "email",
// "Value": "matt@example.com"
// }
// ],
// "UserPoolId": "us-west-2_yt6WzO3SA",
// "Username": "Matt"
// }
//
json := TChilkatJsonObject.Create(Self);
json.UpdateString('UserAttributes[0].Name','email_verified');
json.UpdateString('UserAttributes[0].Value','true');
json.UpdateString('UserAttributes[1].Name','email');
json.UpdateString('UserAttributes[1].Value','matt@example.com');
json.UpdateString('UserPoolId','us-west-2_yt6WzO3SA');
json.UpdateString('Username','Matt');
rest.AddHeader('Content-Type','application/x-amz-json-1.0');
rest.AddHeader('X-Amz-Target','AWSCognitoIdentityProviderService.AdminUpdateUserAttributes');
rest.AddHeader('Accept-Encoding','identity');
sbRequestBody := TChilkatStringBuilder.Create(Self);
json.EmitSb(sbRequestBody.ControlInterface);
sbResponseBody := TChilkatStringBuilder.Create(Self);
success := rest.FullRequestSb('POST','/',sbRequestBody.ControlInterface,sbResponseBody.ControlInterface);
if (success <> 1) then
begin
Memo1.Lines.Add(rest.LastErrorText);
Exit;
end;
respStatusCode := rest.ResponseStatusCode;
Memo1.Lines.Add('response status code = ' + IntToStr(respStatusCode));
if (respStatusCode <> 200) then
begin
Memo1.Lines.Add('Response Status Code = ' + IntToStr(respStatusCode));
Memo1.Lines.Add('Response Header:');
Memo1.Lines.Add(rest.ResponseHeader);
Memo1.Lines.Add('Response Body:');
Memo1.Lines.Add(sbResponseBody.GetAsString());
Exit;
end;
jsonResponse := TChilkatJsonObject.Create(Self);
jsonResponse.LoadSb(sbResponseBody.ControlInterface);
jsonResponse.EmitCompact := 0;
Memo1.Lines.Add(jsonResponse.Emit());
// If successful, the response status code is 200, and the response body is empty JSON "{}"
end;