Sample code for 30+ languages & platforms
AutoIt

S3 Rename File

See more Amazon S3 (new) Examples

Demonstrates how to rename a file on Amazon S3.

Renaming an object (file) in AWS S3 using the AWS S3 API involves copying the object to a new location with the desired name and then deleting the original object.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.

$oRest = ObjCreate("Chilkat.Rest")

; Connect to the Amazon AWS REST server in the desired region.
Local $bTls = True
Local $iPort = 443
Local $bAutoReconnect = True
$bSuccess = $oRest.Connect("s3-us-west-2.amazonaws.com",$iPort,$bTls,$bAutoReconnect)

; Provide AWS credentials.
$oAuthAws = ObjCreate("Chilkat.AuthAws")
$oAuthAws.AccessKey = "AWS_ACCESS_KEY"
$oAuthAws.SecretKey = "AWS_SECRET_KEY"
$oAuthAws.ServiceName = "s3"

; This particular bucket is in the Oregon region, as opposed to the US Standard,
; therefore the Region must be set appropriately.
; Also note that we connected to "s3-us-west-2.amazonaws.com".
$oAuthAws.Region = "us-west-2"

$oRest.SetAuthAws($oAuthAws)

; Set the bucket name via the HOST header.
; In this case, the bucket name is "chilkat.qa".
; Note that the Host header should use "bucketName.s3.amazonaws.com", not "bucketName.s3-us-west-2.amazonaws.com"
$oRest.Host = "chilkat.qa.s3.amazonaws.com"

; Copy /images/sea_creatures/starfish.jpg to /images/sea_creatures/starfish3.jpg
; Notice here that the x-amz-copy-source includes the bucket in the source path,
; but the target path passed to FullRequestNoBody does NOT contain the bucket (because the bucket
; was already specified in the Host header).
$oRest.AddHeader("x-amz-copy-source","/chilkat.qa/images/sea_creatures/starfish.jpg")

$oSbResponse = ObjCreate("Chilkat.StringBuilder")
$bSuccess = $oRest.FullRequestNoBodySb("PUT","/images/sea_creatures/starfish3.jpg",$oSbResponse)
If ($bSuccess = False) Then
    ConsoleWrite($oRest.LastErrorText & @CRLF)
    Exit
EndIf

; When successful, the S3 Storage service will respond with a 200 or 204 response code,
; with an XML body.  
If ($oRest.ResponseStatusCode <> 200) Then
    ; Examine the request/response to see what happened.
    ConsoleWrite("response status code = " & $oRest.ResponseStatusCode & @CRLF)
    ConsoleWrite("response status text = " & $oRest.ResponseStatusText & @CRLF)
    ConsoleWrite("response header: " & $oRest.ResponseHeader & @CRLF)
    ConsoleWrite("response body: " & $oSbResponse.GetAsString() & @CRLF)
    ConsoleWrite("---" & @CRLF)
    ConsoleWrite("LastRequestStartLine: " & $oRest.LastRequestStartLine & @CRLF)
    ConsoleWrite("LastRequestHeader: " & $oRest.LastRequestHeader & @CRLF)
EndIf

ConsoleWrite($oSbResponse.GetAsString() & @CRLF)
ConsoleWrite("Copy Successful." & @CRLF)

; --------------------------------------
; Now we can delete the original file..
; --------------------------------------

; We no longer want to send the x-amz-copy-source header.  Remove it.
$oRest.RemoveHeader("x-amz-copy-source")

$bSuccess = $oRest.FullRequestNoBodySb("DELETE","/images/sea_creatures/starfish.jpg",$oSbResponse)
If ($bSuccess = False) Then
    ConsoleWrite($oRest.LastErrorText & @CRLF)
    Exit
EndIf

; If successfully deleted, the response status code is 204 and the response body text will be empty.
Local $iStatusCode = $oRest.ResponseStatusCode
ConsoleWrite("Response status code = " & $iStatusCode & @CRLF)
ConsoleWrite("Response text = " & @CRLF)
ConsoleWrite($oSbResponse.GetAsString() & @CRLF)