Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(.NET Core C#) Amazon Glacier Set Vault Access PolicyDemonstrates how to set an access policy for a vault (will overwrite the existing policy).
// This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. Chilkat.Rest rest = new Chilkat.Rest(); // Connect to the Amazon AWS REST server in the desired region. bool bTls = true; int port = 443; bool bAutoReconnect = true; bool success = rest.Connect("glacier.us-west-2.amazonaws.com",port,bTls,bAutoReconnect); // Provide AWS credentials. Chilkat.AuthAws authAws = new Chilkat.AuthAws(); authAws.AccessKey = "AWS_ACCESS_KEY"; authAws.SecretKey = "AWS_SECRET_KEY"; authAws.ServiceName = "glacier"; authAws.Region = "us-west-2"; success = rest.SetAuthAws(authAws); // -------------------------------------------------------------------------- // Note: The above REST connection and setup of the AWS credentials // can be done once. After connecting, any number of REST calls can be made. // The "auto reconnect" property passed to rest.Connect indicates that if // the connection is lost, a REST method call will automatically reconnect // if needed. // -------------------------------------------------------------------------- // For more information, see Glacier Set Vault Access Policy Reference Documentation // rest.AddHeader("x-amz-glacier-version","2012-06-01"); // Create the following JSON // Use this online tool to generate the code from sample JSON: // Generate Code to Create JSON // { // "Version": "2012-10-17", // "Statement": [ // { // "Sid": "Define-owner-access-rights", // "Effect": "Allow", // "Principal": { // "AWS": "arn:aws:iam::AWS_ACCOUNT_ID:root" // }, // "Action": "glacier:DeleteArchive", // "Resource": "arn:aws:glacier:us-west-2:AWS_ACCOUNT_ID:vaults/chilkat" // } // ] // } Chilkat.JsonObject jsonPolicy = new Chilkat.JsonObject(); jsonPolicy.UpdateString("Version","2012-10-17"); jsonPolicy.UpdateString("Statement[0].Sid","Define-owner-access-rights"); jsonPolicy.UpdateString("Statement[0].Effect","Allow"); jsonPolicy.UpdateString("Statement[0].Principal.AWS","arn:aws:iam::AWS_ACCOUNT_ID:root"); jsonPolicy.UpdateString("Statement[0].Action","glacier:DeleteArchive"); // Notice here the name of the vault: "chilkat". Change it to your vault name. Also use your actual AWS account ID. jsonPolicy.UpdateString("Statement[0].Resource","arn:aws:glacier:us-west-2:AWS_ACCOUNT_ID:vaults/chilkat"); // Wrap the above JSON in this JSON: // { // "Policy": "{ ... the above JSON ... }" // } Chilkat.JsonObject json = new Chilkat.JsonObject(); json.UpdateString("Policy",jsonPolicy.Emit()); Chilkat.StringBuilder sbRequestBody = new Chilkat.StringBuilder(); json.EmitSb(sbRequestBody); Chilkat.StringBuilder sbResponseBody = new Chilkat.StringBuilder(); success = rest.FullRequestSb("PUT","/AWS_ACCOUNT_ID/vaults/chilkat/access-policy",sbRequestBody,sbResponseBody); if (success != true) { Debug.WriteLine(rest.LastErrorText); return; } int respStatusCode = rest.ResponseStatusCode; if (respStatusCode >= 400) { Debug.WriteLine("Response Status Code = " + Convert.ToString(respStatusCode)); Debug.WriteLine("Response Header:"); Debug.WriteLine(rest.ResponseHeader); Debug.WriteLine("Response Body:"); Debug.WriteLine(sbResponseBody.GetAsString()); return; } // Success is indicated by a 204 response status with an empty response body. Debug.WriteLine("response status code = " + Convert.ToString(respStatusCode)); |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.