Export/Import throwing ZipArchive::open(): Argument #1 ($filename) cannot be empty in ZipArchive->open()

Created on 9 February 2023, about 2 years ago

Problem/Motivation

During bulk export/import. Errors are being thrown for the libzip library no longer accepting empty files. The import functionality stops the user completely and it looks really broken. The issue has been found already and there is a dependency in core for it to be fixed. But until then, is there no work around or to get this to not stop the user during importing? They need to keep refreshing the page to get the import to work correctly.

Steps to reproduce

1. Go to the Import page
2. Choose a previously exported zip file with the assets
3. Press Import

Page throws white screen of death with:
The website encountered an unexpected error. Please try again later.
ValueError: ZipArchive::open(): Argument #1 ($filename) cannot be empty in ZipArchive->open() (line 31 of core/lib/Drupal/Core/Archiver/Zip.php).
ZipArchive->open('') (Line: 31)
Drupal\Core\Archiver\Zip->__construct() (Line: 57)
Drupal\Core\Archiver\ArchiverManager->createInstance('Zip', Array) (Line: 73)
Drupal\Core\Archiver\ArchiverManager->getInstance(Array) (Line: 159)
Drupal\single_content_sync\ContentSyncHelper->createZipInstance('/mnt/tmp/mtndecoupledode15/content-bulk-export-09_02_2023-11_19_0.zip') (Line: 467)
Drupal\single_content_sync\ContentImporter->importFromZip('/mnt/tmp/mtndecoupledode15/content-bulk-export-09_02_2023-11_19_0.zip') (Line: 127)
Drupal\single_content_sync\Form\ContentImportForm->submitForm(Array, Object)
call_user_func_array(Array, Array) (Line: 114)
Drupal\Core\Form\FormSubmitter->executeSubmitHandlers(Array, Object) (Line: 52)
Drupal\Core\Form\FormSubmitter->doSubmitForm(Array, Object) (Line: 595)
Drupal\Core\Form\FormBuilder->processForm('single_content_sync_import_form', Array, Object) (Line: 323)
Drupal\Core\Form\FormBuilder->buildForm(Object, Object) (Line: 73)
Drupal\Core\Controller\FormController->getContentResult(Object, Object)
call_user_func_array(Array, Array) (Line: 123)
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 580)
Drupal\Core\Render\Renderer->executeInRenderContext(Object, Object) (Line: 124)
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->wrapControllerExecutionInRenderContext(Array, Array) (Line: 97)
Drupal\Core\EventSubscriber\EarlyRenderingControllerWrapperSubscriber->Drupal\Core\EventSubscriber\{closure}() (Line: 169)
Symfony\Component\HttpKernel\HttpKernel->handleRaw(Object, 1) (Line: 81)
Symfony\Component\HttpKernel\HttpKernel->handle(Object, 1, 1) (Line: 42)
Drupal\force_password_change\Service\ForcePasswordChangeRedirectMiddleware->handle(Object, 1, 1) (Line: 58)
Drupal\Core\StackMiddleware\Session->handle(Object, 1, 1) (Line: 48)
Drupal\Core\StackMiddleware\KernelPreHandle->handle(Object, 1, 1) (Line: 106)
Drupal\page_cache\StackMiddleware\PageCache->pass(Object, 1, 1) (Line: 85)
Drupal\page_cache\StackMiddleware\PageCache->handle(Object, 1, 1) (Line: 48)
Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle(Object, 1, 1) (Line: 51)
Drupal\Core\StackMiddleware\NegotiationMiddleware->handle(Object, 1, 1) (Line: 23)
Stack\StackedHttpKernel->handle(Object, 1, 1) (Line: 713)
Drupal\Core\DrupalKernel->handle(Object) (Line: 19)

Proposed resolution

Remaining tasks

User interface changes

API changes

Data model changes

🐛 Bug report
Status

Active

Version

1.3

Component

Code

Created by

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @idesigntocode
  • 🇺🇸United States briantschu West Orange, NJ

    I think this is a duplicate of 🐛 PHP 8.1.x. compaitibility Fixed , which was merged into version 1.3.x-dev. Does using the dev version of the module, or applying the patches mentioned in comment #4 on that issue ( #3324392-4: PHP 8.1.x. compaitibility ) fix the error for you?

  • Status changed to Postponed: needs info about 2 years ago
  • 🇺🇦Ukraine nginex

    I could not reproduce this issue, it's kind of weird that method createZipInstance accepts correct file path to your zip, but afterwards it gets lost in Drupal core methods.

    Please let me know what Drupal core version do you use?

  • I also had the same problem on PHP 8.0 and 8.1.
    Works without a problem on 7.4
    Drupal version: 9.5.3

  • Hi @briantschu which core patch are you referring to?

    Hi @nginex I'm using 9.5.2 need to bump it to 9.5.3.

    I'm on PHP 8.0

  • Status changed to Active about 2 years ago
  • 🇺🇦Ukraine nginex

    Going to check with drupal 9.5.x as suggested

  • Status changed to Closed: cannot reproduce about 2 years ago
  • 🇺🇦Ukraine nginex

    I could not reproduce the issue. I used clean drupal core 9.5.3 installation with php 8.1

    I recommend you to debug getInstance method of ArchiverManager.php class.

    I assume that the code below returns empty value, there might be some issue with handling temporary files on your system.

    $this->fileSystem->realpath($configuration['filepath'])
    
  • 🇦🇷Argentina drupal-son

    Hi @nginex,

    I have the same problem.
    I'm using Single Content Sync 1.4.3, Drupal Core 9.5.11 and PHP 8.1.24
    I'm using Acquia hosting.
    I'm not using any Drupal Core patch for this purpose though.

    The weird thing is that the import works fine on dev, qa and uat environments but fails on prod environment.
    All the environments have the same configuration deployed.

    I can export on uat and import into dev or qa but I get the error when importing into prod.

    ValueError: ZipArchive::open(): Argument #1 ($filename) cannot be empty in ZipArchive->open() (line 31 of /mnt/www/html/MYCONTAINER/app/MYAPP/docroot/core/lib/Drupal/Core/Archiver/Zip.php)
    #0 /mnt/www/html/MYCONTAINER/app/MYAPP/docroot/core/lib/Drupal/Core/Archiver/Zip.php(31): ZipArchive->open('')

    I can see on the imported environment (dev, qa, and even prod) at `/admin/content/files` that my file has been uploaded as a temporary status.

    Thanks.

  • 🇦🇷Argentina drupal-son

    I can add more info, I guess this might be something related with how and where the temporary files are stored.
    Each Acquia environment have a different Drupal temporary folder configured, it works for all envs except for prod.
    Might be something at the folder level, permissions, symlink or something on how Acquia is handling that temporary folder at `mnt/tmp/MYCONTAINERENV` directory.

    Does this ring any bell?

    Thanks

  • 🇮🇳India ashraf.hussain Bangalore

    Not sure why the ticket was closed, I am also facing the same issue as mentioned in above comment 🐛 Export/Import throwing ZipArchive::open(): Argument #1 ($filename) cannot be empty in ZipArchive->open() Active .
    Importing zip file works fine on dev, qa and uat environments but fails on prod environment.

  • 🇺🇦Ukraine nginex

    @ashraf.hussain what is your temporary file path on prod and other envs? is there a difference?

  • 🇮🇳India ashraf.hussain Bangalore

    Thanks @nginex for your response. I have checked the tmp path are same for dev, stage, uat, prod environment and set according to Acquia Cloud Platform.
    Its in the below format:
    /mnt/tmp/[sitename]
    e.g.
    Dev: /mnt/tmp/mysitedev
    Staging:/mnt/tmp/mysitestg
    Uat: /mnt/tmp/mysitedev
    Prod: /mnt/tmp/mysite

    https://docs.acquia.com/acquia-cloud-platform/docs/manage-apps/files/tem...

    You can replicate the issue in n Acquia Production environment.

  • 🇺🇦Ukraine nginex

    Unfortunately I don't have a project hosted on Acquia to test it.

    Do you import the zip file via UI or drush?

    If UI, maybe it worth trying to replace

    '#upload_location' => "temporary://import/zip",

    by

    '#upload_location' => "public://import/zip",

    Then the issue might gone

  • 🇮🇳India ashraf.hussain Bangalore

    Thanks @nginex for the suggestion.

  • 🇺🇦Ukraine nginex

    I'm going to make it configurable

  • 🇮🇳India ashraf.hussain Bangalore

    Hi @nginex , I changed to public://import/zip, while it imported correctly in Staging, but when I move to Production, it is giving the below error now. Not sure why it is looking for the file in temporary when file is uploaded in Public now.

    php-error web-43497 [26-Feb-2025 21:36:23 America/Los_Angeles] Uncaught PHP Exception Drupal\Core\File\Exception\FileNotExistsException: "File 'temporary://import/zip/0ab2a388-6deb-4d89-8b52-16437905c9c3/assets/public/images/blogs/featured/xyz2720.png' could not be copied because it does not exist." at /mnt/www/html/marketing7/docroot/core/lib/Drupal/Core/File/FileSystem.php line 444 request_id="v-c7fa6322-f4cc-11ef-9ff6-df04d90c7bb8"

  • 🇺🇦Ukraine nginex

    @ashraf.hussain

    I will try to provide a patch today, so it takes into account whole flow

  • 🇺🇦Ukraine nginex

    The patch is ready.

    I made export and import directory file schema configurable.

    Steps to test:

    1. Apply patch
    2. Execute drush updb && drush cr
    3. Visit /admin/config/content/single-content-sync and change import directory schema to Public files.
    4. Test import content on live once you release this change to live env.

  • 🇺🇦Ukraine nginex

    will change priority because the issue in only applicable for live env on Acquia Cloud Platform hosting.

  • 🇮🇳India ashraf.hussain Bangalore

    Thank you @nginex , I have applied the patch and it is working fine.

    • nginex committed 848e236c on 1.4.x
      Issue #3340563: Make export and import directory file schema...
  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024