executable bit is lost on files when using directoryCopy() on binaries

Description

Test this on a *nix machine. Create a file and use chmod to mark it as executable

Then use Lucee's directoryCopy() function to copy the contents of that folder to another folder.

If you look at the foo file on the file system, you'll see it is no longer executable. This is causing big issues in CommandBox where users may package executable binaries to be installed and the executable flags get dropped which makes the binaries non longer work once they're installed.

I have tested on Adobe CF 2016 and it DOES preserve the executable bits on the files as it should. Note, the java.nio.file.Files class has some nice helper methods to use here.

https://docs.oracle.com/javase/7/docs/api/java/nio/file/Files.html#setPosixFilePermissions(java.nio.file.Path,%20java.util.Set)

https://docs.oracle.com/javase/7/docs/api/java/nio/file/Files.html#getPosixFilePermissions(java.nio.file.Path,%20java.nio.file.LinkOption...)

Environment

None

Activity

Show:

Brad Wood 16 July 2019 at 17:05

Thanks !

Michael Offner 15 July 2019 at 09:30

Pothys - MitrahSoft 14 December 2018 at 15:19

I've analyzed this ticket & confirmed the issue happened. If we copy the executable permission. file using directoryCopy(), the file looses the executable permission sames issue happens during zip the folder.

Fixed

Details

Assignee

Reporter

Priority

Fix versions

New Issue warning screen

Before you create a new Issue, please post to the mailing list first https://dev.lucee.org

Once the issue has been verified, one of the Lucee team will ask you to file an issue

Sprint

Created 13 December 2018 at 20:17
Updated 30 June 2021 at 05:37
Resolved 16 July 2019 at 07:37