Performing simple FILE Storage REST API operations using CURL
The blog aims to perform simple File storage REST API operations such as Create, Copy, Rename and Delete operations using CURL utility.
Let’s look at some of the CURL command syntax to perform REST API operations and will be making use of SAS as the auth scheme.
We need to take care of the pointers below while performing the operations via CURL:
- Ensure the URL is formed correctly as per the operation you are trying to perform.
- The mandatory header needs to be passed and can be done using “-H” parameter.
- Ensure you are appending/removing extra ‘?’ to the SAS token in the URLs accordingly.
- Http verb can be GET, PUT or DELETE as provided by the CURL specifications.
Note:
If you employ an authentication mechanism different from SAS, please ensure that you are including the required headers.
Create FileShare:
The create share operation creates a new Azure Files share under the specified account.
Create Share (FileREST API) - Azure Files | Microsoft Learn
Syntax:
In the below example screenshot, a PUT operation was performed on the storage account to create a File share name as testfileshare. File Share was created successfully.
Create directory:
The Create Directory operation creates a new directory under the specified share or parent directory.
Create Directory (FileREST API) - Azure Files | Microsoft Learn
Syntax :
In the below example screenshot, a PUT operation was performed on the storage account to create a directory name as testdir1. Directory was created successfully.
Delete Directory:
The Delete Directory operation removes the specified empty directory. Note that the directory must be empty before it can be deleted.
Delete Directory (FileREST API) - Azure Files | Microsoft Learn
Syntax :
In the below example screenshot, we have deleted the directory named myfileshare inside a file share using HTTP verb as DELETE
Create file:
The Create File operation creates a new file or replaces a file. When you call Create File, you only initialize the file. To add content to a file, you call the Put Range operation.
Create File (FileREST API) - Azure Files | Microsoft Learn
Syntax :
In the below example screenshot, we have created a file named filecreate1 inside a directory and File share.
Mandatory headers:
Put Range:
The Put Range operation writes a range of bytes to a file.
Put Range (FileREST API) - Azure Files | Microsoft Learn
Syntax :
Mandatory headers:
In the below example screenshot, We are writing 9 bytes of data i.e. "abcdefghi" to an existing file.
Copy file:
The Copy File operation copies a blob or file to a destination file within the storage account.
Copy File (FileREST API) - Azure Files | Microsoft Learn
Syntax :
In the below example screenshot, we have copied the file named copyfile.txt from Source fileshare testfileshare to destination fileshare myfileshare1. You need to authorize the source file to successfully copy to destination.
Mandatory headers:
Rename file:
The Rename File operation renames a file in a storage account.
Rename File (REST API) - Azure Storage | Microsoft Learn
Syntax URL:
In the below example screenshot, we have renamed the file from filecreate2 to filecreate3.
Mandatory headers:
Note:
To bypass the SSL certification warnings, you have the option to use the "-k" flag, which permits insecure server connections when utilizing SSL. However, it is not recommended.
Conclusion:
If you find yourself needing to test a different API that hasn't been covered in this discussion, you can effortlessly apply a comparable approach. Simply modify the essential header parameters according to the specifications of the particular API you are examining.
This adaptability empowers you to apply these testing methods across a diverse range of APIs, ensuring that you can effectively manage different endpoints by adjusting headers and configurations as necessary.
I trust that this information is beneficial for navigating through various APIs and tailoring your approach to meet their distinct requirements. Best of luck with your testing, exploration, and leveraging of APIs to advance your development initiatives!
If your curl command does not execute or return what you expected it to, We can run the command with the -v or --verbose option to get more information.
When verbose mode is enabled, curl gets more talkative and explains and shows a lot more of its doings.
Example screenshot,
I hope this explanation is helpful!
Reference Links:
Operations on the FileService resource - Azure Files | Microsoft Learn
Operations on the FileShare resource - Azure Files | Microsoft Learn
Operations on directories (FileREST API) - Azure Files | Microsoft Learn
Operations on files (FileREST API) - Azure Files | Microsoft Learn
Published on:
Learn more