| At line 1 changed one line | 
| Glacier | 
| \\ | 
| !!Amazon Glacier Integration\\ | 
| \\ | 
| Amazon Glacier is a cloud-based storage service designed for long-term data archiving and backup. It offers secure, durable, and low-cost storage for infrequently accessed data. For more information, visit: [Amazon Glacier Link|https://docs.aws.amazon.com/glacier/index.html#lang/en_us].\\ | 
| ---- | 
| __⚠️ Important__: Dependency jar files must be downloaded and placed in your __CrushFTP Install Folder/plugins/ lib__. ⚠️ Restart is required to load the new Glacier dependency jar. [ Download Link|aws-java-sdk.jar]\\ | 
| ---- | 
| __⚠️ Proxy Configuration__: If your server accesses the internet through a proxy, make sure that the required Glacier domains are whitelisted.\\ | 
| ---- | 
| \\ | 
| The __URL__ should look like this (replace the placeholders with your actual values):\\ | 
| {{{ | 
| glacier://{ACCESS_KEY_ID}:{SECRET_KEY_ID}@glacier.{REGION}.amazonaws.com/ | 
| }}}\\ | 
| Make sure to insert your Access Key, Secret key, and AWS region to form a valid connection URL for Glacier.\\ | 
| \\ | 
| [attachments|glacier_vfs.png]\\ | 
| \\ | 
| Select the appropriate region from the Server dropdown menu. The default region is __us-east-1__.\\ | 
| Enter the Vault Name in the corresponding field. If you leave it empty, the system will automatically list all available Vaults in the selected region. Note that uploads are only allowed inside a Vault folder.\\ | 
| CrushFTP uses a special __glacier__ folder to simulate the folder structure. Files uploaded here are represented as XML pointers referencing the actual archive in Glacier. Each archive includes a description in this format:\\ | 
| {{{ | 
| <m><v>4</v><p>[Base64 encoded path]</p><lm>[the current date]</lm></m> | 
| }}}\\ | 
| \\ | 
| You can turn off the XML reference storage by enabling the __Delete local representation after upload__ option.\\\ | 
| When this is checked, the XML pointer file will be automatically deleted one second after the upload, leaving only the archived data in Glacier.\\\ | 
| \\ | 
| !!! Glacier task | 
| \\ | 
| If you already have archives in Glacier that were ⚠️ __not uploaded through CrushFTP__, you can use this task to rebuild the simulated folder and file structure (XML Pointers) that CrushFTP uses.\\ | 
| This process happens in two steps: first, it creates an Amazon Glacier Inventory retrieval job. Once this job is completed (typically in 3–5 hours), it downloads the inventory and uses it to generate CrushFTP’s simulated folder structure and file references.\\ | 
| For more details, see: [Amazon Valult Inventory Link|https://docs.aws.amazon.com/amazonglacier/latest/dev/vault-inventory.html]\\ | 
| \\ | 
| [attachments|glacier_task.png]\\ | 
| \\ | 
| __⚠️ Important__: The CrushTask must be run at __least twice__:\\ | 
| \\ | 
| __The first run__: It creates the Amazon inventory job, and the job ID returned by Amazon will be stored in the __glacier_info.XML__ file located in the Cache folder.\\ | 
| By default, this Cache folder points to the CrushFTP job folder, which can be found or customized in the task settings. This file is used later to track and complete the inventory retrieval process.\\ | 
| {{{ | 
| <?xml version="1.0" encoding="UTF-8"?> | 
| <GlacierTask type="properties"> | 
| <job_id>Amazon job id</job_id> | 
| </GlacierTask> | 
| }}}\\ | 
| \\ | 
| __The second run__: It checks the status of the Amazon job and downloads the inventory once the job is finished. If the __glacier_info.XML__ file exists, the task uses the stored __Amazon job ID__ to check the current status of the job.\\ | 
| You can set up an __Email task__ after the Glacier task to notify the job result, using the Amazon job status variable.\\ | 
| Possible values for the job status are: __In progress__, __Failed__, or __Succeeded__.\\ | 
| \\__ | 
| {{{ | 
| {glacier_job_satus} | 
| }}}\\ | 
| \\ | 
| Once the Amazon job status is Succeeded, the task will download the Glacier Vault Inventory and use it to create CrushFTP’s simulated glacier folder and file structure. These files act as XML pointers referencing your archived data in Glacier.\\ | 
| Each archive entry will include a description in the following format:\\ | 
| {{{ | 
| <m><v>...</v><p>[Base64 encoded path]</p> ....</m> | 
| }}}\\ | 
| This structure allows CrushFTP to represent your Glacier archives in a way that mimics a traditional folder and file system.\\ | 
| \\ | 
| __⚠️ Note__: If your Glacier archive descriptions do not follow the required format, CrushFTP will still create the XML pointers, but it will use the archive description as the file name instead of placing the file in a simulated folder structure.\\ | 
| This means the files will appear flat (without folders), named directly after the description stored with each archive.\\\ | 
| \\ |