Details
-
Bug
-
Status: Open
-
Major
-
Resolution: Unresolved
-
3.0.0
-
None
-
None
Description
With the commit to resolve MENFORCER-364, the rule "requireFileExists" checks that the canonical path of a file is the same as the absolute path.
But not all absolute paths are canonical.
- absolute paths can involve symbolic links
- and they are allowed to have parts which are relative
- /../
- /./
And when it fails to handle a path, it can report that a file does not exist, even though the local system will resolve the path.
A blunt solution might be three separate rules:
- requireFileExists
- the provided path must resolve to a file (which may be a directory or link)
- requireCanonicalFileExists
- the provided path must exist as a canonical file
- requireCasesenstiveFileExists
- the provided path must file a file
- the file name must have the same case (upper//lower) as the
- the parts of the path from the file up must have the same case until they go through a symbolic link
I have used the "nio" package to handle some of stuff before. I will add a comment with some java code I would start with. Since the outcome here is very dependent on the use case you pick, the java will be "meta code" with ??? where you have to know the use case to know the outcome.
but basically, with "nio" you can march up a path checking for symbolic links and such.
Attachments
Issue Links
- links to