Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) Amazon Cognito - Admin Update User AttributesSee more Amazon Cognito ExamplesUpdates 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. For more information, see https://docs.aws.amazon.com/cognito-user-identity-pools/latest/APIReference/API_AdminUpdateUserAttributes.html
#import <CkoRest.h> #import <CkoAuthAws.h> #import <CkoJsonObject.h> #import <CkoStringBuilder.h> // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoRest *rest = [[CkoRest alloc] init]; BOOL success; CkoAuthAws *authAws = [[CkoAuthAws alloc] init]; 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]; // URL: https://cognito-idp.us-west-2.amazonaws.com/ BOOL bTls = YES; int port = 443; BOOL bAutoReconnect = YES; // Use the same region as specified above. success = [rest Connect: @"cognito-idp.us-west-2.amazonaws.com" port: [NSNumber numberWithInt: port] tls: bTls autoReconnect: bAutoReconnect]; if (success != YES) { NSLog(@"%@%d",@"ConnectFailReason: ",[rest.ConnectFailReason intValue]); NSLog(@"%@",rest.LastErrorText); return; } // 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" // } // CkoJsonObject *json = [[CkoJsonObject alloc] init]; [json UpdateString: @"UserAttributes[0].Name" value: @"email_verified"]; [json UpdateString: @"UserAttributes[0].Value" value: @"true"]; [json UpdateString: @"UserAttributes[1].Name" value: @"email"]; [json UpdateString: @"UserAttributes[1].Value" value: @"matt@example.com"]; [json UpdateString: @"UserPoolId" value: @"us-west-2_yt6WzO3SA"]; [json UpdateString: @"Username" value: @"Matt"]; [rest AddHeader: @"Content-Type" value: @"application/x-amz-json-1.0"]; [rest AddHeader: @"X-Amz-Target" value: @"AWSCognitoIdentityProviderService.AdminUpdateUserAttributes"]; [rest AddHeader: @"Accept-Encoding" value: @"identity"]; CkoStringBuilder *sbRequestBody = [[CkoStringBuilder alloc] init]; [json EmitSb: sbRequestBody]; CkoStringBuilder *sbResponseBody = [[CkoStringBuilder alloc] init]; success = [rest FullRequestSb: @"POST" uriPath: @"/" requestBody: sbRequestBody responseBody: sbResponseBody]; if (success != YES) { NSLog(@"%@",rest.LastErrorText); return; } int respStatusCode = [rest.ResponseStatusCode intValue]; NSLog(@"%@%d",@"response status code = ",respStatusCode); if (respStatusCode != 200) { NSLog(@"%@%d",@"Response Status Code = ",respStatusCode); NSLog(@"%@",@"Response Header:"); NSLog(@"%@",rest.ResponseHeader); NSLog(@"%@",@"Response Body:"); NSLog(@"%@",[sbResponseBody GetAsString]); return; } CkoJsonObject *jsonResponse = [[CkoJsonObject alloc] init]; [jsonResponse LoadSb: sbResponseBody]; jsonResponse.EmitCompact = NO; NSLog(@"%@",[jsonResponse Emit]); // If successful, the response status code is 200, and the response body is empty JSON "{}" |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.